navidrome/scanner/change_detector_test.go

121 lines
3.2 KiB
Go
Raw Normal View History

2020-01-16 22:53:48 +01:00
package scanner
import (
"io/ioutil"
"os"
"path/filepath"
2020-01-16 22:53:48 +01:00
"time"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
)
var _ = Describe("ChangeDetector", func() {
var testFolder string
var scanner *ChangeDetector
lastModifiedSince := time.Time{}
2020-01-16 22:53:48 +01:00
BeforeEach(func() {
2020-01-24 01:44:08 +01:00
testFolder, _ = ioutil.TempDir("", "navidrome_tests")
2020-02-03 02:44:56 +01:00
err := os.MkdirAll(testFolder, 0777)
2020-01-16 22:53:48 +01:00
if err != nil {
panic(err)
}
scanner = NewChangeDetector(testFolder)
2020-01-16 22:53:48 +01:00
})
It("detects changes recursively", func() {
// Scan empty folder
changed, deleted, err := scanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(ConsistOf("."))
// Add one subfolder
lastModifiedSince = nowWithDelay()
2020-02-03 02:44:56 +01:00
err = os.MkdirAll(filepath.Join(testFolder, "a"), 0777)
2020-01-16 22:53:48 +01:00
if err != nil {
panic(err)
}
changed, deleted, err = scanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(ConsistOf(".", P("a")))
2020-01-16 22:53:48 +01:00
// Add more subfolders
lastModifiedSince = nowWithDelay()
2020-02-03 02:44:56 +01:00
err = os.MkdirAll(filepath.Join(testFolder, "a", "b", "c"), 0777)
2020-01-16 22:53:48 +01:00
if err != nil {
panic(err)
}
changed, deleted, err = scanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(ConsistOf(P("a"), P("a/b"), P("a/b/c")))
2020-01-16 22:53:48 +01:00
// Scan with no changes
lastModifiedSince = nowWithDelay()
changed, deleted, err = scanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(BeEmpty())
// New file in subfolder
lastModifiedSince = nowWithDelay()
_, err = os.Create(filepath.Join(testFolder, "a", "b", "empty.txt"))
2020-01-16 22:53:48 +01:00
if err != nil {
panic(err)
}
changed, deleted, err = scanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(ConsistOf(P("a/b")))
2020-01-16 22:53:48 +01:00
// Delete file in subfolder
lastModifiedSince = nowWithDelay()
err = os.Remove(filepath.Join(testFolder, "a", "b", "empty.txt"))
2020-01-16 22:53:48 +01:00
if err != nil {
panic(err)
}
changed, deleted, err = scanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(ConsistOf(P("a/b")))
2020-01-16 22:53:48 +01:00
// Delete subfolder
lastModifiedSince = nowWithDelay()
err = os.Remove(filepath.Join(testFolder, "a", "b", "c"))
2020-01-16 22:53:48 +01:00
if err != nil {
panic(err)
}
changed, deleted, err = scanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(ConsistOf(P("a/b/c")))
Expect(changed).To(ConsistOf(P("a/b")))
2020-01-16 22:53:48 +01:00
// Only returns changes after lastModifiedSince
lastModifiedSince = nowWithDelay()
newScanner := NewChangeDetector(testFolder)
changed, deleted, err = newScanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(BeEmpty())
Expect(changed).To(BeEmpty())
f, err := os.Create(filepath.Join(testFolder, "a", "b", "new.txt"))
2020-01-18 17:00:20 +01:00
f.Close()
changed, deleted, err = newScanner.Scan(lastModifiedSince)
2020-01-16 22:53:48 +01:00
Expect(err).To(BeNil())
Expect(deleted).To(BeEmpty())
Expect(changed).To(ConsistOf(P("a/b")))
2020-01-16 22:53:48 +01:00
})
})
// I hate time-based tests....
func nowWithDelay() time.Time {
now := time.Now()
time.Sleep(50 * time.Millisecond)
return now
}