syncthing/lib/versioner/simple_test.go

90 lines
1.9 KiB
Go
Raw Normal View History

2014-11-16 21:13:20 +01:00
// Copyright (C) 2014 The Syncthing Authors.
2014-09-29 21:43:32 +02:00
//
2015-03-07 21:36:35 +01:00
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this file,
// You can obtain one at https://mozilla.org/MPL/2.0/.
package versioner
2014-11-25 21:27:10 +00:00
import (
"io/ioutil"
"math"
2014-11-25 21:27:10 +00:00
"path/filepath"
"testing"
"time"
"github.com/syncthing/syncthing/lib/fs"
2014-11-25 21:27:10 +00:00
)
func TestTaggedFilename(t *testing.T) {
cases := [][3]string{
2014-11-25 21:27:10 +00:00
{filepath.Join("foo", "bar.baz"), "tag", filepath.Join("foo", "bar~tag.baz")},
{"bar.baz", "tag", "bar~tag.baz"},
{"bar", "tag", "bar~tag"},
2014-11-25 22:32:18 +00:00
{"~$ufheft2.docx", "20140612-200554", "~$ufheft2~20140612-200554.docx"},
{"alle~4.mgz", "20141106-094415", "alle~4~20141106-094415.mgz"},
// Parsing test only
{"", "tag-only", "foo/bar.baz~tag-only"},
{"", "tag-only", "bar.baz~tag-only"},
2014-11-25 22:32:18 +00:00
{"", "20140612-200554", "~$ufheft2.docx~20140612-200554"},
{"", "20141106-094415", "alle~4.mgz~20141106-094415"},
}
for _, tc := range cases {
if tc[0] != "" {
// Test tagger
tf := TagFilename(tc[0], tc[1])
if tf != tc[2] {
t.Errorf("%s != %s", tf, tc[2])
}
}
// Test parser
tag := ExtractTag(tc[2])
if tag != tc[1] {
t.Errorf("%s != %s", tag, tc[1])
}
}
}
func TestSimpleVersioningVersionCount(t *testing.T) {
if testing.Short() {
t.Skip("Test takes some time, skipping.")
}
dir, err := ioutil.TempDir("", "")
//defer os.RemoveAll(dir)
if err != nil {
t.Error(err)
}
fs := fs.NewFilesystem(fs.FilesystemTypeBasic, dir)
v := NewSimple("", fs, map[string]string{"keep": "2"})
path := "test"
for i := 1; i <= 3; i++ {
f, err := fs.Create(path)
if err != nil {
t.Error(err)
}
f.Close()
if err := v.Archive(path); err != nil {
t.Error(err)
}
n, err := fs.DirNames(".stversions")
if err != nil {
t.Error(err)
}
if float64(len(n)) != math.Min(float64(i), 2) {
t.Error("Wrong count")
}
time.Sleep(time.Second)
}
}