empty_dir_tracker_test.go 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. // Copyright (C) 2017 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. "path/filepath"
  9. "testing"
  10. "github.com/d4l3k/messagediff"
  11. )
  12. // TestEmptyDirs models the following .stversions structure:
  13. // .stversions/
  14. // ├── keep1
  15. // │   └── file1
  16. // ├── keep2
  17. // │   └── keep21
  18. // │   └── keep22
  19. // │   └── file1
  20. // ├── remove1
  21. // └── remove2
  22. // └── remove21
  23. // └── remove22
  24. func TestEmptyDirs(t *testing.T) {
  25. var paths = []struct {
  26. path string
  27. isFile bool
  28. }{
  29. {".", false},
  30. {"keep1", false},
  31. {"keep1/file1", true},
  32. {"keep2", false},
  33. {"keep2/keep21", false},
  34. {"keep2/keep21/keep22", false},
  35. {"keep2/keep21/keep22/file1", true},
  36. {"remove1", false},
  37. {"remove2", false},
  38. {"remove2/remove21", false},
  39. {"remove2/remove21/remove22", false},
  40. }
  41. var expected = []string{
  42. "remove2/remove21/remove22",
  43. "remove2/remove21",
  44. "remove2",
  45. "remove1",
  46. }
  47. // For compatibility with Windows
  48. for i, p := range paths {
  49. paths[i].path = filepath.FromSlash(p.path)
  50. }
  51. for i, p := range expected {
  52. expected[i] = filepath.FromSlash(p)
  53. }
  54. dirTracker := make(emptyDirTracker)
  55. for _, p := range paths {
  56. if p.isFile {
  57. dirTracker.addFile(p.path)
  58. } else {
  59. dirTracker.addDir(p.path)
  60. }
  61. }
  62. result := dirTracker.emptyDirs()
  63. if diff, equal := messagediff.PrettyDiff(expected, result); !equal {
  64. t.Errorf("Incorrect empty directories list; got %v, expected %v\n%v", result, expected, diff)
  65. }
  66. }