empty_dir_tracker_test.go 1.7 KB

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