1
0

versioner_test.go 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. // Copyright (C) 2020 The Syncthing Authors.
  2. //
  3. // This Source Code Form is subject to the terms of the Mozilla Public
  4. // License, v. 2.0. If a copy of the MPL was not distributed with this file,
  5. // You can obtain one at https://mozilla.org/MPL/2.0/.
  6. package versioner
  7. import (
  8. "context"
  9. "fmt"
  10. "io/ioutil"
  11. "os"
  12. "path/filepath"
  13. "testing"
  14. "time"
  15. "github.com/syncthing/syncthing/lib/config"
  16. "github.com/syncthing/syncthing/lib/fs"
  17. )
  18. func TestVersionerCleanOut(t *testing.T) {
  19. cfg := config.FolderConfiguration{
  20. FilesystemType: fs.FilesystemTypeBasic,
  21. Path: "testdata",
  22. Versioning: config.VersioningConfiguration{
  23. Params: map[string]string{
  24. "cleanoutDays": "7",
  25. },
  26. },
  27. }
  28. testCasesVersioner := map[string]Versioner{
  29. "simple": newSimple(cfg),
  30. "trashcan": newTrashcan(cfg),
  31. }
  32. var testcases = map[string]bool{
  33. "testdata/.stversions/file1": false,
  34. "testdata/.stversions/file2": true,
  35. "testdata/.stversions/keep1/file1": false,
  36. "testdata/.stversions/keep1/file2": false,
  37. "testdata/.stversions/keep2/file1": false,
  38. "testdata/.stversions/keep2/file2": true,
  39. "testdata/.stversions/keep3/keepsubdir/file1": false,
  40. "testdata/.stversions/remove/file1": true,
  41. "testdata/.stversions/remove/file2": true,
  42. "testdata/.stversions/remove/removesubdir/file1": true,
  43. }
  44. for versionerType, versioner := range testCasesVersioner {
  45. t.Run(fmt.Sprintf("%v versioner trashcan clean up", versionerType), func(t *testing.T) {
  46. os.RemoveAll("testdata")
  47. defer os.RemoveAll("testdata")
  48. oldTime := time.Now().Add(-8 * 24 * time.Hour)
  49. for file, shouldRemove := range testcases {
  50. os.MkdirAll(filepath.Dir(file), 0777)
  51. if err := ioutil.WriteFile(file, []byte("data"), 0644); err != nil {
  52. t.Fatal(err)
  53. }
  54. if shouldRemove {
  55. if err := os.Chtimes(file, oldTime, oldTime); err != nil {
  56. t.Fatal(err)
  57. }
  58. }
  59. }
  60. if err := versioner.Clean(context.Background()); err != nil {
  61. t.Fatal(err)
  62. }
  63. for file, shouldRemove := range testcases {
  64. _, err := os.Lstat(file)
  65. if shouldRemove && !os.IsNotExist(err) {
  66. t.Error(file, "should have been removed")
  67. } else if !shouldRemove && err != nil {
  68. t.Error(file, "should not have been removed")
  69. }
  70. }
  71. if _, err := os.Lstat("testdata/.stversions/keep3"); os.IsNotExist(err) {
  72. t.Error("directory with non empty subdirs should not be removed")
  73. }
  74. if _, err := os.Lstat("testdata/.stversions/remove"); !os.IsNotExist(err) {
  75. t.Error("empty directory should have been removed")
  76. }
  77. })
  78. }
  79. }