1
0

versioner_test.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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. "os"
  11. "path/filepath"
  12. "testing"
  13. "time"
  14. "github.com/syncthing/syncthing/lib/config"
  15. "github.com/syncthing/syncthing/lib/fs"
  16. )
  17. func TestVersionerCleanOut(t *testing.T) {
  18. cfg := config.FolderConfiguration{
  19. FilesystemType: fs.FilesystemTypeBasic,
  20. Path: "testdata",
  21. Versioning: config.VersioningConfiguration{
  22. Params: map[string]string{
  23. "cleanoutDays": "7",
  24. },
  25. },
  26. }
  27. testCasesVersioner := map[string]Versioner{
  28. "simple": newSimple(cfg),
  29. "trashcan": newTrashcan(cfg),
  30. }
  31. var testcases = map[string]bool{
  32. "testdata/.stversions/file1": false,
  33. "testdata/.stversions/file2": true,
  34. "testdata/.stversions/keep1/file1": false,
  35. "testdata/.stversions/keep1/file2": false,
  36. "testdata/.stversions/keep2/file1": false,
  37. "testdata/.stversions/keep2/file2": true,
  38. "testdata/.stversions/keep3/keepsubdir/file1": false,
  39. "testdata/.stversions/remove/file1": true,
  40. "testdata/.stversions/remove/file2": true,
  41. "testdata/.stversions/remove/removesubdir/file1": true,
  42. }
  43. for versionerType, versioner := range testCasesVersioner {
  44. t.Run(fmt.Sprintf("%v versioner trashcan clean up", versionerType), func(t *testing.T) {
  45. os.RemoveAll("testdata")
  46. defer os.RemoveAll("testdata")
  47. oldTime := time.Now().Add(-8 * 24 * time.Hour)
  48. for file, shouldRemove := range testcases {
  49. os.MkdirAll(filepath.Dir(file), 0777)
  50. if err := os.WriteFile(file, []byte("data"), 0644); err != nil {
  51. t.Fatal(err)
  52. }
  53. if shouldRemove {
  54. if err := os.Chtimes(file, oldTime, oldTime); err != nil {
  55. t.Fatal(err)
  56. }
  57. }
  58. }
  59. if err := versioner.Clean(context.Background()); err != nil {
  60. t.Fatal(err)
  61. }
  62. for file, shouldRemove := range testcases {
  63. _, err := os.Lstat(file)
  64. if shouldRemove && !os.IsNotExist(err) {
  65. t.Error(file, "should have been removed")
  66. } else if !shouldRemove && err != nil {
  67. t.Error(file, "should not have been removed")
  68. }
  69. }
  70. if _, err := os.Lstat("testdata/.stversions/keep3"); os.IsNotExist(err) {
  71. t.Error("directory with non empty subdirs should not be removed")
  72. }
  73. if _, err := os.Lstat("testdata/.stversions/remove"); !os.IsNotExist(err) {
  74. t.Error("empty directory should have been removed")
  75. }
  76. })
  77. }
  78. }