tests/sync: adjust transfer counts for chunker

This commit is contained in:
Ivan Andreev 2019-09-05 23:29:35 +03:00 committed by Nick Craig-Wood
parent be674faff1
commit 1e4691f951

View file

@ -5,6 +5,7 @@ package sync
import ( import (
"context" "context"
"runtime" "runtime"
"strings"
"testing" "testing"
"time" "time"
@ -311,7 +312,7 @@ func TestSyncBasedOnCheckSum(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
// We should have transferred exactly one file. // We should have transferred exactly one file.
assert.Equal(t, int64(1), accounting.GlobalStats().GetTransfers()) assert.Equal(t, toyFileTransfers(r), accounting.GlobalStats().GetTransfers())
fstest.CheckItems(t, r.Fremote, file1) fstest.CheckItems(t, r.Fremote, file1)
// Change last modified date only // Change last modified date only
@ -345,7 +346,7 @@ func TestSyncSizeOnly(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
// We should have transferred exactly one file. // We should have transferred exactly one file.
assert.Equal(t, int64(1), accounting.GlobalStats().GetTransfers()) assert.Equal(t, toyFileTransfers(r), accounting.GlobalStats().GetTransfers())
fstest.CheckItems(t, r.Fremote, file1) fstest.CheckItems(t, r.Fremote, file1)
// Update mtime, md5sum but not length of file // Update mtime, md5sum but not length of file
@ -379,7 +380,7 @@ func TestSyncIgnoreSize(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
// We should have transferred exactly one file. // We should have transferred exactly one file.
assert.Equal(t, int64(1), accounting.GlobalStats().GetTransfers()) assert.Equal(t, toyFileTransfers(r), accounting.GlobalStats().GetTransfers())
fstest.CheckItems(t, r.Fremote, file1) fstest.CheckItems(t, r.Fremote, file1)
// Update size but not date of file // Update size but not date of file
@ -419,7 +420,7 @@ func TestSyncIgnoreTimes(t *testing.T) {
// We should have transferred exactly one file even though the // We should have transferred exactly one file even though the
// files were identical. // files were identical.
assert.Equal(t, int64(1), accounting.GlobalStats().GetTransfers()) assert.Equal(t, toyFileTransfers(r), accounting.GlobalStats().GetTransfers())
fstest.CheckItems(t, r.Flocal, file1) fstest.CheckItems(t, r.Flocal, file1)
fstest.CheckItems(t, r.Fremote, file1) fstest.CheckItems(t, r.Fremote, file1)
@ -598,7 +599,7 @@ func TestSyncDoesntUpdateModtime(t *testing.T) {
fstest.CheckItems(t, r.Fremote, file1) fstest.CheckItems(t, r.Fremote, file1)
// We should have transferred exactly one file, not set the mod time // We should have transferred exactly one file, not set the mod time
assert.Equal(t, int64(1), accounting.GlobalStats().GetTransfers()) assert.Equal(t, toyFileTransfers(r), accounting.GlobalStats().GetTransfers())
} }
func TestSyncAfterAddingAFile(t *testing.T) { func TestSyncAfterAddingAFile(t *testing.T) {
@ -1019,11 +1020,46 @@ func TestSyncWithTrackRenames(t *testing.T) {
assert.Equal(t, int64(3), accounting.GlobalStats().GetChecks()) // 2 file checks + 1 move assert.Equal(t, int64(3), accounting.GlobalStats().GetChecks()) // 2 file checks + 1 move
} }
} else { } else {
assert.Equal(t, int64(2), accounting.GlobalStats().GetChecks()) // 2 file checks if toyFileChecks(r) != -1 {
assert.Equal(t, int64(1), accounting.GlobalStats().GetTransfers()) // 0 copy assert.Equal(t, toyFileChecks(r), accounting.GlobalStats().GetChecks())
}
assert.Equal(t, toyFileTransfers(r), accounting.GlobalStats().GetTransfers())
} }
} }
func toyFileChecks(r *fstest.Run) int64 {
remote := r.Fremote.Name()
// Numbers below are calculated for a 14 byte file.
if !strings.HasPrefix(remote, "TestChunker") {
return 2
}
// Chunker makes more internal checks.
var checks int
switch {
case strings.Contains(remote, "Chunk3b"): // chunk 3 bytes
checks = 6
case strings.Contains(remote, "Chunk50b"): // chunk 50 bytes
checks = 3
case strings.Contains(remote, "ChunkerChunk"): // unknown chunk size
return -1
default:
checks = 3 // large chunks (eventually no chunking)
}
if strings.HasSuffix(remote, "S3") {
checks++ // Extra check because S3 emulates Move as Copy+Delete.
}
return int64(checks)
}
func toyFileTransfers(r *fstest.Run) int64 {
remote := r.Fremote.Name()
transfers := 1
if strings.HasPrefix(remote, "TestChunker") && strings.HasSuffix(remote, "S3") {
transfers++ // Extra Copy because S3 emulates Move as Copy+Delete.
}
return int64(transfers)
}
// Test a server side move if possible, or the backup path if not // Test a server side move if possible, or the backup path if not
func testServerSideMove(t *testing.T, r *fstest.Run, withFilter, testDeleteEmptyDirs bool) { func testServerSideMove(t *testing.T, r *fstest.Run, withFilter, testDeleteEmptyDirs bool) {
FremoteMove, _, finaliseMove, err := fstest.RandomRemote() FremoteMove, _, finaliseMove, err := fstest.RandomRemote()
@ -1600,7 +1636,7 @@ func TestSyncUTFNorm(t *testing.T) {
// We should have transferred exactly one file, but kept the // We should have transferred exactly one file, but kept the
// normalized state of the file. // normalized state of the file.
assert.Equal(t, int64(1), accounting.GlobalStats().GetTransfers()) assert.Equal(t, toyFileTransfers(r), accounting.GlobalStats().GetTransfers())
fstest.CheckItems(t, r.Flocal, file1) fstest.CheckItems(t, r.Flocal, file1)
file1.Path = file2.Path file1.Path = file2.Path
fstest.CheckItems(t, r.Fremote, file1) fstest.CheckItems(t, r.Fremote, file1)