2014-11-16 20:13:20 +00:00
|
|
|
// Copyright (C) 2014 The Syncthing Authors.
|
2014-09-29 19:43:32 +00:00
|
|
|
//
|
2015-03-07 20:36:35 +00: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,
|
2017-02-09 06:52:18 +00:00
|
|
|
// You can obtain one at https://mozilla.org/MPL/2.0/.
|
2014-08-19 10:43:50 +00:00
|
|
|
|
2014-11-24 09:58:57 +00:00
|
|
|
package versioner
|
2014-08-19 10:43:50 +00:00
|
|
|
|
2014-11-25 21:27:10 +00:00
|
|
|
import (
|
2015-04-26 14:41:04 +00:00
|
|
|
"math"
|
2024-01-12 09:46:18 +00:00
|
|
|
"os"
|
2014-11-25 21:27:10 +00:00
|
|
|
"path/filepath"
|
2024-01-12 09:46:18 +00:00
|
|
|
"strings"
|
2014-11-25 21:27:10 +00:00
|
|
|
"testing"
|
2015-04-26 14:41:04 +00:00
|
|
|
"time"
|
2017-08-19 14:36:56 +00:00
|
|
|
|
2020-08-24 11:14:30 +00:00
|
|
|
"github.com/syncthing/syncthing/lib/config"
|
|
|
|
|
2017-08-19 14:36:56 +00:00
|
|
|
"github.com/syncthing/syncthing/lib/fs"
|
2014-11-25 21:27:10 +00:00
|
|
|
)
|
2014-11-24 09:58:57 +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")},
|
2014-11-24 09:58:57 +00:00
|
|
|
{"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"},
|
2014-11-24 09:58:57 +00:00
|
|
|
|
|
|
|
// 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"},
|
2014-11-24 09:58:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range cases {
|
|
|
|
if tc[0] != "" {
|
|
|
|
// Test tagger
|
2018-01-01 14:39:23 +00:00
|
|
|
tf := TagFilename(tc[0], tc[1])
|
2014-11-24 09:58:57 +00:00
|
|
|
if tf != tc[2] {
|
|
|
|
t.Errorf("%s != %s", tf, tc[2])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test parser
|
2019-11-26 07:39:31 +00:00
|
|
|
tag := extractTag(tc[2])
|
2014-11-24 09:58:57 +00:00
|
|
|
if tag != tc[1] {
|
|
|
|
t.Errorf("%s != %s", tag, tc[1])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-04-26 14:41:04 +00:00
|
|
|
|
|
|
|
func TestSimpleVersioningVersionCount(t *testing.T) {
|
|
|
|
if testing.Short() {
|
|
|
|
t.Skip("Test takes some time, skipping.")
|
|
|
|
}
|
|
|
|
|
2022-04-15 03:44:06 +00:00
|
|
|
dir := t.TempDir()
|
2015-04-26 14:41:04 +00:00
|
|
|
|
2020-06-18 06:15:47 +00:00
|
|
|
cfg := config.FolderConfiguration{
|
|
|
|
FilesystemType: fs.FilesystemTypeBasic,
|
|
|
|
Path: dir,
|
|
|
|
Versioning: config.VersioningConfiguration{
|
|
|
|
Params: map[string]string{
|
|
|
|
"keep": "2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2022-04-10 18:55:05 +00:00
|
|
|
fs := cfg.Filesystem(nil)
|
2017-08-19 14:36:56 +00:00
|
|
|
|
2020-06-18 06:15:47 +00:00
|
|
|
v := newSimple(cfg)
|
2015-04-26 14:41:04 +00:00
|
|
|
|
2017-08-19 14:36:56 +00:00
|
|
|
path := "test"
|
2015-04-26 14:41:04 +00:00
|
|
|
|
|
|
|
for i := 1; i <= 3; i++ {
|
2017-08-19 14:36:56 +00:00
|
|
|
f, err := fs.Create(path)
|
2015-04-26 14:41:04 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
f.Close()
|
2017-08-19 14:36:56 +00:00
|
|
|
if err := v.Archive(path); err != nil {
|
2015-04-26 14:41:04 +00:00
|
|
|
t.Error(err)
|
|
|
|
}
|
2017-08-19 14:36:56 +00:00
|
|
|
|
2023-08-09 07:10:06 +00:00
|
|
|
n, err := fs.DirNames(DefaultPath)
|
2015-04-26 14:41:04 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if float64(len(n)) != math.Min(float64(i), 2) {
|
|
|
|
t.Error("Wrong count")
|
|
|
|
}
|
|
|
|
|
|
|
|
time.Sleep(time.Second)
|
|
|
|
}
|
|
|
|
}
|
2024-01-12 09:46:18 +00:00
|
|
|
|
|
|
|
func TestPathTildes(t *testing.T) {
|
|
|
|
// Test that folder and version paths with leading tildes are expanded
|
|
|
|
// to the user's home directory. (issue #9241)
|
|
|
|
home := t.TempDir()
|
|
|
|
t.Setenv("HOME", home)
|
|
|
|
if vn := filepath.VolumeName(home); vn != "" {
|
|
|
|
// Legacy Windows home stuff
|
|
|
|
t.Setenv("HomeDrive", vn)
|
|
|
|
t.Setenv("HomePath", strings.TrimPrefix(home, vn))
|
|
|
|
}
|
|
|
|
os.Mkdir(filepath.Join(home, "folder"), 0o755)
|
|
|
|
|
|
|
|
cfg := config.FolderConfiguration{
|
|
|
|
FilesystemType: fs.FilesystemTypeBasic,
|
|
|
|
Path: "~/folder",
|
|
|
|
Versioning: config.VersioningConfiguration{
|
|
|
|
FSPath: "~/versions",
|
|
|
|
FSType: fs.FilesystemTypeBasic,
|
|
|
|
Params: map[string]string{
|
|
|
|
"keep": "2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
fs := cfg.Filesystem(nil)
|
|
|
|
v := newSimple(cfg)
|
|
|
|
|
|
|
|
const testPath = "test"
|
|
|
|
|
|
|
|
f, err := fs.Create(testPath)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
f.Close()
|
|
|
|
if err := v.Archive(testPath); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check that there are no entries in the folder directory; this is
|
|
|
|
// specifically to check that there is no directory named "~" there.
|
|
|
|
names, err := fs.DirNames(".")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(names) != 0 {
|
|
|
|
t.Fatalf("found %d files in folder dir, want 0", len(names))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check that the versions directory contains one file that begins with
|
|
|
|
// our test path.
|
|
|
|
des, err := os.ReadDir(filepath.Join(home, "versions"))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
for _, de := range des {
|
|
|
|
names = append(names, de.Name())
|
|
|
|
}
|
|
|
|
if len(names) != 1 {
|
|
|
|
t.Fatalf("found %d files in versions dir, want 1", len(names))
|
|
|
|
}
|
|
|
|
if got := names[0]; !strings.HasPrefix(got, testPath) {
|
|
|
|
t.Fatalf("found versioned file %q, want one that begins with %q", got, testPath)
|
|
|
|
}
|
|
|
|
}
|