Make rclone check obey the --size-only flag - fixes #419

This commit is contained in:
Nick Craig-Wood 2016-04-07 14:56:27 +01:00
parent b835330714
commit 0f8e7c3843
3 changed files with 43 additions and 20 deletions

View File

@ -192,6 +192,8 @@ Checks the files in the source and destination match. It
compares sizes and MD5SUMs and prints a report of files which compares sizes and MD5SUMs and prints a report of files which
don't match. It doesn't alter the source or destination. don't match. It doesn't alter the source or destination.
`--size-only` may be used to only compare the sizes, not the MD5SUMs.
### rclone dedupe remote:path ### ### rclone dedupe remote:path ###
By default `dedup` interactively finds duplicate files and offers to By default `dedup` interactively finds duplicate files and offers to

View File

@ -684,6 +684,33 @@ func MoveDir(fdst, fsrc Fs) error {
return nil return nil
} }
// checkIdentical checks to see if dst and src are identical
//
// it returns true if differences were found
func checkIdentical(dst, src Object) bool {
Stats.Checking(src)
defer Stats.DoneChecking(src)
if src.Size() != dst.Size() {
Stats.Error()
ErrorLog(src, "Sizes differ")
return true
}
if !Config.SizeOnly {
same, _, err := CheckHashes(src, dst)
if err != nil {
// CheckHashes will log and count errors
return true
}
if !same {
Stats.Error()
ErrorLog(src, "Md5sums differ")
return true
}
}
Debug(src, "OK")
return false
}
// Check the files in fsrc and fdst according to Size and hash // Check the files in fsrc and fdst according to Size and hash
func Check(fdst, fsrc Fs) error { func Check(fdst, fsrc Fs) error {
differences := int32(0) differences := int32(0)
@ -753,26 +780,9 @@ func Check(fdst, fsrc Fs) error {
go func() { go func() {
defer checkerWg.Done() defer checkerWg.Done()
for check := range checks { for check := range checks {
dst, src := check[0], check[1] if checkIdentical(check[0], check[1]) {
Stats.Checking(src)
if src.Size() != dst.Size() {
Stats.DoneChecking(src)
Stats.Error()
ErrorLog(src, "Sizes differ")
atomic.AddInt32(&differences, 1) atomic.AddInt32(&differences, 1)
continue
} }
same, _, err := CheckHashes(src, dst)
Stats.DoneChecking(src)
if err != nil {
continue
}
if !same {
Stats.Error()
atomic.AddInt32(&differences, 1)
ErrorLog(src, "Md5sums differ")
}
Debug(src, "OK")
} }
}() }()
} }

View File

@ -1003,8 +1003,13 @@ func TestCheck(t *testing.T) {
fstest.CheckItems(t, r.fremote, file1, file3) fstest.CheckItems(t, r.fremote, file1, file3)
check(3, 2) check(3, 2)
r.WriteObject("potato2", "------------------------------------------------------------", t1) file2r := file2
fstest.CheckItems(t, r.fremote, file1, file2, file3) if fs.Config.SizeOnly {
file2r = r.WriteObject("potato2", "--Some-Differences-But-Size-Only-Is-Enabled-----------------", t1)
} else {
r.WriteObject("potato2", "------------------------------------------------------------", t1)
}
fstest.CheckItems(t, r.fremote, file1, file2r, file3)
check(4, 1) check(4, 1)
r.WriteFile("empty space", "", t2) r.WriteFile("empty space", "", t2)
@ -1012,6 +1017,12 @@ func TestCheck(t *testing.T) {
check(5, 0) check(5, 0)
} }
func TestCheckSizeOnly(t *testing.T) {
fs.Config.SizeOnly = true
defer func() { fs.Config.SizeOnly = false }()
TestCheck(t)
}
func (r *Run) checkWithDuplicates(t *testing.T, items ...fstest.Item) { func (r *Run) checkWithDuplicates(t *testing.T, items ...fstest.Item) {
objects, size, err := fs.Count(r.fremote) objects, size, err := fs.Count(r.fremote)
if err != nil { if err != nil {