test: Update conflict tests

This commit is contained in:
Jakob Borg 2018-03-04 14:52:04 +01:00
parent 3949b750f5
commit 74b820f287

View File

@ -127,10 +127,9 @@ func TestConflictsDefault(t *testing.T) {
} }
rc.AwaitSync("default", sender, receiver) rc.AwaitSync("default", sender, receiver)
// The conflict is expected on the s2 side due to how we calculate which // Expect one conflict file, created on either side.
// file is the winner (based on device ID)
files, err := filepath.Glob("s2/*sync-conflict*") files, err := filepath.Glob("s?/*sync-conflict*")
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
@ -252,19 +251,26 @@ func TestConflictsInitialMerge(t *testing.T) {
rc.AwaitSync("default", sender, receiver) rc.AwaitSync("default", sender, receiver)
// Do it once more so the conflict copies propagate to both sides.
sender.Rescan("default")
receiver.Rescan("default")
rc.AwaitSync("default", sender, receiver)
checkedStop(t, sender) checkedStop(t, sender)
checkedStop(t, receiver) checkedStop(t, receiver)
log.Println("Verifying...") log.Println("Verifying...")
// s1 should have three-four files (there's a conflict from s2 which may or may not have synced yet) // s1 should have four files (there's a conflict)
files, err := filepath.Glob("s1/file*") files, err := filepath.Glob("s1/file*")
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
if len(files) < 3 || len(files) > 4 { if len(files) != 4 {
t.Errorf("Expected 3-4 files in s1 instead of %d", len(files)) t.Errorf("Expected 4 files in s1 instead of %d", len(files))
} }
// s2 should have four files (there's a conflict) // s2 should have four files (there's a conflict)
@ -345,7 +351,7 @@ func TestConflictsIndexReset(t *testing.T) {
t.Errorf("Expected 3 files in s1 instead of %d", len(files)) t.Errorf("Expected 3 files in s1 instead of %d", len(files))
} }
// s2 should have three // s2 should have three files
files, err = filepath.Glob("s2/file*") files, err = filepath.Glob("s2/file*")
if err != nil { if err != nil {
@ -440,3 +446,88 @@ func TestConflictsIndexReset(t *testing.T) {
t.Errorf("Expected 2 'file2' files in s2 instead of %d", len(files)) t.Errorf("Expected 2 'file2' files in s2 instead of %d", len(files))
} }
} }
func TestConflictsSameContent(t *testing.T) {
log.Println("Cleaning...")
err := removeAll("s1", "s2", "h1/index*", "h2/index*")
if err != nil {
t.Fatal(err)
}
err = os.Mkdir("s1", 0755)
if err != nil {
t.Fatal(err)
}
err = os.Mkdir("s2", 0755)
if err != nil {
t.Fatal(err)
}
// Two files on s1
err = ioutil.WriteFile("s1/file1", []byte("hello\n"), 0644)
if err != nil {
t.Fatal(err)
}
err = ioutil.WriteFile("s1/file2", []byte("hello\n"), 0644)
if err != nil {
t.Fatal(err)
}
// Two files on s2, content differs in file1 only, timestamps differ on both.
err = ioutil.WriteFile("s2/file1", []byte("goodbye\n"), 0644)
if err != nil {
t.Fatal(err)
}
err = ioutil.WriteFile("s2/file2", []byte("hello\n"), 0644)
if err != nil {
t.Fatal(err)
}
ts := time.Now().Add(-time.Hour)
os.Chtimes("s2/file1", ts, ts)
os.Chtimes("s2/file2", ts, ts)
// Let them sync
sender := startInstance(t, 1)
defer checkedStop(t, sender)
receiver := startInstance(t, 2)
defer checkedStop(t, receiver)
sender.ResumeAll()
receiver.ResumeAll()
log.Println("Syncing...")
rc.AwaitSync("default", sender, receiver)
// Let conflict copies propagate
sender.Rescan("default")
receiver.Rescan("default")
rc.AwaitSync("default", sender, receiver)
log.Println("Verifying...")
// s1 should have three files
files, err := filepath.Glob("s1/file*")
if err != nil {
t.Fatal(err)
}
if len(files) != 3 {
t.Errorf("Expected 3 files in s1 instead of %d", len(files))
}
// s2 should have three files
files, err = filepath.Glob("s2/file*")
if err != nil {
t.Fatal(err)
}
if len(files) != 3 {
t.Errorf("Expected 3 files in s2 instead of %d", len(files))
}
}