2017-03-16 23:37:56 +01:00
|
|
|
|
package local
|
|
|
|
|
|
|
|
|
|
import (
|
2018-01-31 21:18:31 +01:00
|
|
|
|
"os"
|
|
|
|
|
"path"
|
2017-03-16 23:37:56 +01:00
|
|
|
|
"testing"
|
2018-01-31 21:18:31 +01:00
|
|
|
|
"time"
|
2017-03-16 23:37:56 +01:00
|
|
|
|
|
2018-01-31 21:18:31 +01:00
|
|
|
|
"github.com/ncw/rclone/fs/hash"
|
|
|
|
|
"github.com/ncw/rclone/fstest"
|
|
|
|
|
"github.com/ncw/rclone/lib/readers"
|
2017-03-16 23:37:56 +01:00
|
|
|
|
"github.com/stretchr/testify/assert"
|
2018-01-31 21:18:31 +01:00
|
|
|
|
"github.com/stretchr/testify/require"
|
2017-03-16 23:37:56 +01:00
|
|
|
|
)
|
|
|
|
|
|
2018-01-31 21:18:31 +01:00
|
|
|
|
// TestMain drives the tests
|
|
|
|
|
func TestMain(m *testing.M) {
|
|
|
|
|
fstest.TestMain(m)
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-16 23:37:56 +01:00
|
|
|
|
func TestMapper(t *testing.T) {
|
|
|
|
|
m := newMapper()
|
|
|
|
|
assert.Equal(t, m.m, map[string]string{})
|
|
|
|
|
assert.Equal(t, "potato", m.Save("potato", "potato"))
|
|
|
|
|
assert.Equal(t, m.m, map[string]string{})
|
|
|
|
|
assert.Equal(t, "-r'áö", m.Save("-r?'a´o¨", "-r'áö"))
|
|
|
|
|
assert.Equal(t, m.m, map[string]string{
|
|
|
|
|
"-r'áö": "-r?'a´o¨",
|
|
|
|
|
})
|
|
|
|
|
assert.Equal(t, "potato", m.Load("potato"))
|
|
|
|
|
assert.Equal(t, "-r?'a´o¨", m.Load("-r'áö"))
|
2018-04-09 16:27:58 +02:00
|
|
|
|
}
|
2018-01-31 21:18:31 +01:00
|
|
|
|
|
2018-04-09 16:27:58 +02:00
|
|
|
|
// Test copy with source file that's updating
|
|
|
|
|
func TestUpdatingCheck(t *testing.T) {
|
2018-01-31 21:18:31 +01:00
|
|
|
|
r := fstest.NewRun(t)
|
|
|
|
|
defer r.Finalise()
|
|
|
|
|
filePath := "sub dir/local test"
|
|
|
|
|
r.WriteFile(filePath, "content", time.Now())
|
|
|
|
|
|
|
|
|
|
fd, err := os.Open(path.Join(r.LocalName, filePath))
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatalf("failed opening file %q: %v", filePath, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fi, err := fd.Stat()
|
2018-05-04 16:19:50 +02:00
|
|
|
|
require.NoError(t, err)
|
2018-01-31 21:18:31 +01:00
|
|
|
|
o := &Object{size: fi.Size(), modTime: fi.ModTime()}
|
|
|
|
|
wrappedFd := readers.NewLimitedReadCloser(fd, -1)
|
|
|
|
|
hash, err := hash.NewMultiHasherTypes(hash.Supported)
|
2018-05-04 16:19:50 +02:00
|
|
|
|
require.NoError(t, err)
|
2018-01-31 21:18:31 +01:00
|
|
|
|
in := localOpenFile{
|
|
|
|
|
o: o,
|
|
|
|
|
in: wrappedFd,
|
|
|
|
|
hash: hash,
|
|
|
|
|
fd: fd,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
buf := make([]byte, 1)
|
|
|
|
|
_, err = in.Read(buf)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
r.WriteFile(filePath, "content updated", time.Now())
|
|
|
|
|
_, err = in.Read(buf)
|
|
|
|
|
require.Errorf(t, err, "can't copy - source file is being updated")
|
2018-04-09 16:27:58 +02:00
|
|
|
|
|
|
|
|
|
// turn the checking off and try again
|
|
|
|
|
|
|
|
|
|
*noCheckUpdated = true
|
|
|
|
|
defer func() {
|
|
|
|
|
*noCheckUpdated = false
|
|
|
|
|
}()
|
|
|
|
|
|
|
|
|
|
r.WriteFile(filePath, "content updated", time.Now())
|
|
|
|
|
_, err = in.Read(buf)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
2017-03-16 23:37:56 +01:00
|
|
|
|
}
|