Use io.SeekStart/End/Current constants now for go1.7+ #2154
This commit is contained in:
parent
80588a5a6b
commit
e5be471ce0
24 changed files with 64 additions and 63 deletions
4
backend/cache/cache_internal_test.go
vendored
4
backend/cache/cache_internal_test.go
vendored
|
@ -1526,7 +1526,7 @@ func (r *run) randomReader(t *testing.T, size int64) io.ReadCloser {
|
||||||
}
|
}
|
||||||
data := r.randomBytes(t, int64(left))
|
data := r.randomBytes(t, int64(left))
|
||||||
_, _ = f.Write(data)
|
_, _ = f.Write(data)
|
||||||
_, _ = f.Seek(int64(0), 0)
|
_, _ = f.Seek(int64(0), io.SeekStart)
|
||||||
r.tempFiles = append(r.tempFiles, f)
|
r.tempFiles = append(r.tempFiles, f)
|
||||||
|
|
||||||
return f
|
return f
|
||||||
|
@ -1653,7 +1653,7 @@ func (r *run) readDataFromRemote(t *testing.T, f fs.Fs, remote string, offset, e
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return checkSample, err
|
return checkSample, err
|
||||||
}
|
}
|
||||||
_, _ = f.Seek(offset, 0)
|
_, _ = f.Seek(offset, io.SeekStart)
|
||||||
totalRead, err := io.ReadFull(f, checkSample)
|
totalRead, err := io.ReadFull(f, checkSample)
|
||||||
checkSample = checkSample[:totalRead]
|
checkSample = checkSample[:totalRead]
|
||||||
if err == io.EOF || err == io.ErrUnexpectedEOF {
|
if err == io.EOF || err == io.ErrUnexpectedEOF {
|
||||||
|
|
11
backend/cache/handle.go
vendored
11
backend/cache/handle.go
vendored
|
@ -5,7 +5,6 @@ package cache
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -327,13 +326,13 @@ func (r *Handle) Seek(offset int64, whence int) (int64, error) {
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
switch whence {
|
switch whence {
|
||||||
case os.SEEK_SET:
|
case io.SeekStart:
|
||||||
fs.Debugf(r, "moving offset set from %v to %v", r.offset, offset)
|
fs.Debugf(r, "moving offset set from %v to %v", r.offset, offset)
|
||||||
r.offset = offset
|
r.offset = offset
|
||||||
case os.SEEK_CUR:
|
case io.SeekCurrent:
|
||||||
fs.Debugf(r, "moving offset cur from %v to %v", r.offset, r.offset+offset)
|
fs.Debugf(r, "moving offset cur from %v to %v", r.offset, r.offset+offset)
|
||||||
r.offset += offset
|
r.offset += offset
|
||||||
case os.SEEK_END:
|
case io.SeekEnd:
|
||||||
fs.Debugf(r, "moving offset end (%v) from %v to %v", r.cachedObject.Size(), r.offset, r.cachedObject.Size()+offset)
|
fs.Debugf(r, "moving offset end (%v) from %v to %v", r.cachedObject.Size(), r.offset, r.cachedObject.Size()+offset)
|
||||||
r.offset = r.cachedObject.Size() + offset
|
r.offset = r.cachedObject.Size() + offset
|
||||||
default:
|
default:
|
||||||
|
@ -382,10 +381,10 @@ func (w *worker) reader(offset, end int64, closeOpen bool) (io.ReadCloser, error
|
||||||
|
|
||||||
if !closeOpen {
|
if !closeOpen {
|
||||||
if do, ok := r.(fs.RangeSeeker); ok {
|
if do, ok := r.(fs.RangeSeeker); ok {
|
||||||
_, err = do.RangeSeek(offset, os.SEEK_SET, end-offset)
|
_, err = do.RangeSeek(offset, io.SeekStart, end-offset)
|
||||||
return r, err
|
return r, err
|
||||||
} else if do, ok := r.(io.Seeker); ok {
|
} else if do, ok := r.(io.Seeker); ok {
|
||||||
_, err = do.Seek(offset, os.SEEK_SET)
|
_, err = do.Seek(offset, io.SeekStart)
|
||||||
return r, err
|
return r, err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
3
backend/cache/object.go
vendored
3
backend/cache/object.go
vendored
|
@ -4,7 +4,6 @@ package cache
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"io"
|
"io"
|
||||||
"os"
|
|
||||||
"path"
|
"path"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
@ -223,7 +222,7 @@ func (o *Object) Open(options ...fs.OpenOption) (io.ReadCloser, error) {
|
||||||
case *fs.RangeOption:
|
case *fs.RangeOption:
|
||||||
offset, limit = x.Decode(o.Size())
|
offset, limit = x.Decode(o.Size())
|
||||||
}
|
}
|
||||||
_, err = cacheReader.Seek(offset, os.SEEK_SET)
|
_, err = cacheReader.Seek(offset, io.SeekStart)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -781,7 +781,7 @@ func (c *cipher) newDecrypterSeek(open OpenRangeSeek, offset, limit int64) (fh *
|
||||||
}
|
}
|
||||||
fh.open = open // will be called by fh.RangeSeek
|
fh.open = open // will be called by fh.RangeSeek
|
||||||
if doRangeSeek {
|
if doRangeSeek {
|
||||||
_, err = fh.RangeSeek(offset, 0, limit)
|
_, err = fh.RangeSeek(offset, io.SeekStart, limit)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = fh.Close()
|
_ = fh.Close()
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -908,7 +908,7 @@ func (fh *decrypter) RangeSeek(offset int64, whence int, limit int64) (int64, er
|
||||||
if fh.open == nil {
|
if fh.open == nil {
|
||||||
return 0, fh.finish(errors.New("can't seek - not initialised with newDecrypterSeek"))
|
return 0, fh.finish(errors.New("can't seek - not initialised with newDecrypterSeek"))
|
||||||
}
|
}
|
||||||
if whence != 0 {
|
if whence != io.SeekStart {
|
||||||
return 0, fh.finish(errors.New("can only seek from the start"))
|
return 0, fh.finish(errors.New("can only seek from the start"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1016,7 +1016,7 @@ func TestNewDecrypterSeekLimit(t *testing.T) {
|
||||||
if offset+limit > len(plaintext) {
|
if offset+limit > len(plaintext) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
_, err := fh.RangeSeek(int64(offset), 0, int64(limit))
|
_, err := fh.RangeSeek(int64(offset), io.SeekStart, int64(limit))
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
check(fh, offset, limit)
|
check(fh, offset, limit)
|
||||||
|
@ -1083,7 +1083,7 @@ func TestNewDecrypterSeekLimit(t *testing.T) {
|
||||||
}
|
}
|
||||||
fh, err := c.DecryptDataSeek(testOpen, 0, -1)
|
fh, err := c.DecryptDataSeek(testOpen, 0, -1)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
gotOffset, err := fh.RangeSeek(test.offset, 0, test.limit)
|
gotOffset, err := fh.RangeSeek(test.offset, io.SeekStart, test.limit)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, gotOffset, test.offset)
|
assert.Equal(t, gotOffset, test.offset)
|
||||||
}
|
}
|
||||||
|
|
|
@ -159,7 +159,7 @@ func (rx *resumableUpload) transferStatus() (start int64, err error) {
|
||||||
|
|
||||||
// Transfer a chunk - caller must call googleapi.CloseBody(res) if err == nil || res != nil
|
// Transfer a chunk - caller must call googleapi.CloseBody(res) if err == nil || res != nil
|
||||||
func (rx *resumableUpload) transferChunk(start int64, chunk io.ReadSeeker, chunkSize int64) (int, error) {
|
func (rx *resumableUpload) transferChunk(start int64, chunk io.ReadSeeker, chunkSize int64) (int, error) {
|
||||||
_, _ = chunk.Seek(0, 0)
|
_, _ = chunk.Seek(0, io.SeekStart)
|
||||||
req := rx.makeRequest(start, chunk, chunkSize)
|
req := rx.makeRequest(start, chunk, chunkSize)
|
||||||
res, err := rx.f.client.Do(req)
|
res, err := rx.f.client.Do(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -894,7 +894,7 @@ func (o *Object) uploadChunked(in0 io.Reader, commitInfo *files.CommitInfo, size
|
||||||
chunk := readers.NewRepeatableLimitReaderBuffer(in, buf, chunkSize)
|
chunk := readers.NewRepeatableLimitReaderBuffer(in, buf, chunkSize)
|
||||||
err = o.fs.pacer.Call(func() (bool, error) {
|
err = o.fs.pacer.Call(func() (bool, error) {
|
||||||
// seek to the start in case this is a retry
|
// seek to the start in case this is a retry
|
||||||
if _, err = chunk.Seek(0, 0); err != nil {
|
if _, err = chunk.Seek(0, io.SeekStart); err != nil {
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
res, err = o.fs.srv.UploadSessionStart(&files.UploadSessionStartArg{}, chunk)
|
res, err = o.fs.srv.UploadSessionStart(&files.UploadSessionStartArg{}, chunk)
|
||||||
|
@ -930,7 +930,7 @@ func (o *Object) uploadChunked(in0 io.Reader, commitInfo *files.CommitInfo, size
|
||||||
chunk = readers.NewRepeatableLimitReaderBuffer(in, buf, chunkSize)
|
chunk = readers.NewRepeatableLimitReaderBuffer(in, buf, chunkSize)
|
||||||
err = o.fs.pacer.Call(func() (bool, error) {
|
err = o.fs.pacer.Call(func() (bool, error) {
|
||||||
// seek to the start in case this is a retry
|
// seek to the start in case this is a retry
|
||||||
if _, err = chunk.Seek(0, 0); err != nil {
|
if _, err = chunk.Seek(0, io.SeekStart); err != nil {
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
err = o.fs.srv.UploadSessionAppendV2(&appendArg, chunk)
|
err = o.fs.srv.UploadSessionAppendV2(&appendArg, chunk)
|
||||||
|
@ -953,7 +953,7 @@ func (o *Object) uploadChunked(in0 io.Reader, commitInfo *files.CommitInfo, size
|
||||||
chunk = readers.NewRepeatableReaderBuffer(in, buf)
|
chunk = readers.NewRepeatableReaderBuffer(in, buf)
|
||||||
err = o.fs.pacer.Call(func() (bool, error) {
|
err = o.fs.pacer.Call(func() (bool, error) {
|
||||||
// seek to the start in case this is a retry
|
// seek to the start in case this is a retry
|
||||||
if _, err = chunk.Seek(0, 0); err != nil {
|
if _, err = chunk.Seek(0, io.SeekStart); err != nil {
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
entry, err = o.fs.srv.UploadSessionFinish(args, chunk)
|
entry, err = o.fs.srv.UploadSessionFinish(args, chunk)
|
||||||
|
|
|
@ -732,7 +732,7 @@ func (o *Object) Open(options ...fs.OpenOption) (in io.ReadCloser, err error) {
|
||||||
wrappedFd := readers.NewLimitedReadCloser(fd, limit)
|
wrappedFd := readers.NewLimitedReadCloser(fd, limit)
|
||||||
if offset != 0 {
|
if offset != 0 {
|
||||||
// seek the object
|
// seek the object
|
||||||
_, err = fd.Seek(offset, 0)
|
_, err = fd.Seek(offset, io.SeekStart)
|
||||||
// don't attempt to make checksums
|
// don't attempt to make checksums
|
||||||
return wrappedFd, err
|
return wrappedFd, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -1123,7 +1123,7 @@ func (o *Object) uploadFragment(url string, start int64, totalSize int64, chunk
|
||||||
// var response api.UploadFragmentResponse
|
// var response api.UploadFragmentResponse
|
||||||
var resp *http.Response
|
var resp *http.Response
|
||||||
err = o.fs.pacer.Call(func() (bool, error) {
|
err = o.fs.pacer.Call(func() (bool, error) {
|
||||||
_, _ = chunk.Seek(0, 0)
|
_, _ = chunk.Seek(0, io.SeekStart)
|
||||||
resp, err = o.fs.srv.Call(&opts)
|
resp, err = o.fs.srv.Call(&opts)
|
||||||
if resp != nil {
|
if resp != nil {
|
||||||
defer fs.CheckClose(resp.Body, &err)
|
defer fs.CheckClose(resp.Body, &err)
|
||||||
|
|
|
@ -130,12 +130,12 @@ func (u *uploader) init() {
|
||||||
u.totalSize = -1
|
u.totalSize = -1
|
||||||
switch r := u.cfg.body.(type) {
|
switch r := u.cfg.body.(type) {
|
||||||
case io.Seeker:
|
case io.Seeker:
|
||||||
pos, _ := r.Seek(0, 1)
|
pos, _ := r.Seek(0, io.SeekCurrent)
|
||||||
defer func() {
|
defer func() {
|
||||||
_, _ = r.Seek(pos, 0)
|
_, _ = r.Seek(pos, io.SeekStart)
|
||||||
}()
|
}()
|
||||||
|
|
||||||
n, err := r.Seek(0, 2)
|
n, err := r.Seek(0, io.SeekEnd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -905,7 +905,7 @@ func (o *Object) Open(options ...fs.OpenOption) (in io.ReadCloser, err error) {
|
||||||
return nil, errors.Wrap(err, "Open failed")
|
return nil, errors.Wrap(err, "Open failed")
|
||||||
}
|
}
|
||||||
if offset > 0 {
|
if offset > 0 {
|
||||||
off, err := sftpFile.Seek(offset, 0)
|
off, err := sftpFile.Seek(offset, io.SeekStart)
|
||||||
if err != nil || off != offset {
|
if err != nil || off != offset {
|
||||||
return nil, errors.Wrap(err, "Open Seek failed")
|
return nil, errors.Wrap(err, "Open Seek failed")
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
package mount
|
package mount
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"io"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"bazil.org/fuse"
|
"bazil.org/fuse"
|
||||||
|
@ -74,7 +75,7 @@ func (f *File) Open(ctx context.Context, req *fuse.OpenRequest, resp *fuse.OpenR
|
||||||
}
|
}
|
||||||
|
|
||||||
// See if seeking is supported and set FUSE hint accordingly
|
// See if seeking is supported and set FUSE hint accordingly
|
||||||
if _, err = handle.Seek(0, 1); err != nil {
|
if _, err = handle.Seek(0, io.SeekCurrent); err != nil {
|
||||||
resp.Flags |= fuse.OpenNonSeekable
|
resp.Flags |= fuse.OpenNonSeekable
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ func randomSeekTest(size int64, in *os.File, name string) {
|
||||||
}
|
}
|
||||||
log.Printf("Reading %d from %d", blockSize, start)
|
log.Printf("Reading %d from %d", blockSize, start)
|
||||||
|
|
||||||
_, err := in.Seek(start, 0)
|
_, err := in.Seek(start, io.SeekStart)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Seek failed on %q: %v", name, err)
|
log.Fatalf("Seek failed on %q: %v", name, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,11 +32,11 @@ func randomSeekTest(size int64, in1, in2 *os.File, file1, file2 string) {
|
||||||
}
|
}
|
||||||
log.Printf("Reading %d from %d", blockSize, start)
|
log.Printf("Reading %d from %d", blockSize, start)
|
||||||
|
|
||||||
_, err := in1.Seek(start, 0)
|
_, err := in1.Seek(start, io.SeekStart)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Seek failed on %q: %v", file1, err)
|
log.Fatalf("Seek failed on %q: %v", file1, err)
|
||||||
}
|
}
|
||||||
_, err = in2.Seek(start, 0)
|
_, err = in2.Seek(start, io.SeekStart)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Seek failed on %q: %v", file2, err)
|
log.Fatalf("Seek failed on %q: %v", file2, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,7 +68,7 @@ func seekTest(n int, file string) {
|
||||||
}
|
}
|
||||||
log.Printf("%s: Reading %d from %d", file, blockSize, start)
|
log.Printf("%s: Reading %d from %d", file, blockSize, start)
|
||||||
|
|
||||||
_, err = in.Seek(start, 0)
|
_, err = in.Seek(start, io.SeekStart)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Seek failed on %q: %v", file, err)
|
log.Fatalf("Seek failed on %q: %v", file, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -66,7 +66,7 @@ func TestReadChecksum(t *testing.T) {
|
||||||
_, err = io.ReadFull(fd, buf)
|
_, err = io.ReadFull(fd, buf)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
// read at end
|
// read at end
|
||||||
_, err = fd.Seek(int64(len(b)-len(buf)), 0)
|
_, err = fd.Seek(int64(len(b)-len(buf)), io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = io.ReadFull(fd, buf)
|
_, err = io.ReadFull(fd, buf)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
@ -89,7 +89,7 @@ func TestReadSeek(t *testing.T) {
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
// Seek to half way
|
// Seek to half way
|
||||||
_, err = fd.Seek(5, 0)
|
_, err = fd.Seek(5, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
buf, err := ioutil.ReadAll(fd)
|
buf, err := ioutil.ReadAll(fd)
|
||||||
|
@ -97,7 +97,7 @@ func TestReadSeek(t *testing.T) {
|
||||||
assert.Equal(t, buf, []byte("HELLO"))
|
assert.Equal(t, buf, []byte("HELLO"))
|
||||||
|
|
||||||
// Test seeking to the end
|
// Test seeking to the end
|
||||||
_, err = fd.Seek(10, 0)
|
_, err = fd.Seek(10, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
buf, err = ioutil.ReadAll(fd)
|
buf, err = ioutil.ReadAll(fd)
|
||||||
|
@ -105,7 +105,7 @@ func TestReadSeek(t *testing.T) {
|
||||||
assert.Equal(t, buf, []byte(""))
|
assert.Equal(t, buf, []byte(""))
|
||||||
|
|
||||||
// Test seeking beyond the end
|
// Test seeking beyond the end
|
||||||
_, err = fd.Seek(1000000, 0)
|
_, err = fd.Seek(1000000, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
buf, err = ioutil.ReadAll(fd)
|
buf, err = ioutil.ReadAll(fd)
|
||||||
|
@ -113,7 +113,7 @@ func TestReadSeek(t *testing.T) {
|
||||||
assert.Equal(t, buf, []byte(""))
|
assert.Equal(t, buf, []byte(""))
|
||||||
|
|
||||||
// Now back to the start
|
// Now back to the start
|
||||||
_, err = fd.Seek(0, 0)
|
_, err = fd.Seek(0, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
buf, err = ioutil.ReadAll(fd)
|
buf, err = ioutil.ReadAll(fd)
|
||||||
|
|
|
@ -107,9 +107,9 @@ func (cr *ChunkedReader) RangeSeek(offset int64, whence int, length int64) (int6
|
||||||
|
|
||||||
size := cr.o.Size()
|
size := cr.o.Size()
|
||||||
switch whence {
|
switch whence {
|
||||||
case 0:
|
case io.SeekStart:
|
||||||
cr.offset = 0
|
cr.offset = 0
|
||||||
case 2:
|
case io.SeekEnd:
|
||||||
cr.offset = size
|
cr.offset = size
|
||||||
}
|
}
|
||||||
cr.chunkOffset = cr.offset + offset
|
cr.chunkOffset = cr.offset + offset
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
package log
|
package log
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
"reflect"
|
"reflect"
|
||||||
|
@ -71,7 +72,7 @@ func InitLogging() {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Failed to open log file: %v", err)
|
log.Fatalf("Failed to open log file: %v", err)
|
||||||
}
|
}
|
||||||
_, err = f.Seek(0, os.SEEK_END)
|
_, err = f.Seek(0, io.SeekEnd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fs.Errorf(nil, "Failed to seek log file to end: %v", err)
|
fs.Errorf(nil, "Failed to seek log file to end: %v", err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,11 +24,11 @@ func (r *RepeatableReader) Seek(offset int64, whence int) (int64, error) {
|
||||||
var abs int64
|
var abs int64
|
||||||
cacheLen := int64(len(r.b))
|
cacheLen := int64(len(r.b))
|
||||||
switch whence {
|
switch whence {
|
||||||
case 0: //io.SeekStart
|
case io.SeekStart:
|
||||||
abs = offset
|
abs = offset
|
||||||
case 1: //io.SeekCurrent
|
case io.SeekCurrent:
|
||||||
abs = r.i + offset
|
abs = r.i + offset
|
||||||
case 2: //io.SeekEnd
|
case io.SeekEnd:
|
||||||
abs = cacheLen + offset
|
abs = cacheLen + offset
|
||||||
default:
|
default:
|
||||||
return 0, errors.New("fs.RepeatableReader.Seek: invalid whence")
|
return 0, errors.New("fs.RepeatableReader.Seek: invalid whence")
|
||||||
|
|
|
@ -32,7 +32,7 @@ func TestRepeatableReader(t *testing.T) {
|
||||||
|
|
||||||
// Test Seek Back to start
|
// Test Seek Back to start
|
||||||
dst = make([]byte, 10)
|
dst = make([]byte, 10)
|
||||||
pos, err = r.Seek(0, 0)
|
pos, err = r.Seek(0, io.SeekStart)
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
require.Equal(t, 0, int(pos))
|
require.Equal(t, 0, int(pos))
|
||||||
|
|
||||||
|
@ -58,13 +58,13 @@ func TestRepeatableReader(t *testing.T) {
|
||||||
buf = bytes.NewBuffer(b)
|
buf = bytes.NewBuffer(b)
|
||||||
r = NewRepeatableReader(buf)
|
r = NewRepeatableReader(buf)
|
||||||
// Should not allow seek past cache index
|
// Should not allow seek past cache index
|
||||||
pos, err = r.Seek(5, 1)
|
pos, err = r.Seek(5, io.SeekCurrent)
|
||||||
assert.NotNil(t, err)
|
assert.NotNil(t, err)
|
||||||
assert.Equal(t, "fs.RepeatableReader.Seek: offset is unavailable", err.Error())
|
assert.Equal(t, "fs.RepeatableReader.Seek: offset is unavailable", err.Error())
|
||||||
assert.Equal(t, 0, int(pos))
|
assert.Equal(t, 0, int(pos))
|
||||||
|
|
||||||
// Should not allow seek to negative position start
|
// Should not allow seek to negative position start
|
||||||
pos, err = r.Seek(-1, 1)
|
pos, err = r.Seek(-1, io.SeekCurrent)
|
||||||
assert.NotNil(t, err)
|
assert.NotNil(t, err)
|
||||||
assert.Equal(t, "fs.RepeatableReader.Seek: negative position", err.Error())
|
assert.Equal(t, "fs.RepeatableReader.Seek: negative position", err.Error())
|
||||||
assert.Equal(t, 0, int(pos))
|
assert.Equal(t, 0, int(pos))
|
||||||
|
@ -78,15 +78,15 @@ func TestRepeatableReader(t *testing.T) {
|
||||||
// Should seek from index with io.SeekCurrent(1) whence
|
// Should seek from index with io.SeekCurrent(1) whence
|
||||||
dst = make([]byte, 5)
|
dst = make([]byte, 5)
|
||||||
_, _ = r.Read(dst)
|
_, _ = r.Read(dst)
|
||||||
pos, err = r.Seek(-3, 1)
|
pos, err = r.Seek(-3, io.SeekCurrent)
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
require.Equal(t, 2, int(pos))
|
require.Equal(t, 2, int(pos))
|
||||||
pos, err = r.Seek(1, 1)
|
pos, err = r.Seek(1, io.SeekCurrent)
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
require.Equal(t, 3, int(pos))
|
require.Equal(t, 3, int(pos))
|
||||||
|
|
||||||
// Should seek from cache end with io.SeekEnd(2) whence
|
// Should seek from cache end with io.SeekEnd(2) whence
|
||||||
pos, err = r.Seek(-3, 2)
|
pos, err = r.Seek(-3, io.SeekEnd)
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
require.Equal(t, 2, int(pos))
|
require.Equal(t, 2, int(pos))
|
||||||
|
|
||||||
|
|
|
@ -110,7 +110,7 @@ func (fh *ReadFileHandle) seek(offset int64, reopen bool) (err error) {
|
||||||
// Can we seek it directly?
|
// Can we seek it directly?
|
||||||
if do, ok := oldReader.(io.Seeker); !reopen && ok {
|
if do, ok := oldReader.(io.Seeker); !reopen && ok {
|
||||||
fs.Debugf(fh.remote, "ReadFileHandle.seek from %d to %d (io.Seeker)", fh.offset, offset)
|
fs.Debugf(fh.remote, "ReadFileHandle.seek from %d to %d (io.Seeker)", fh.offset, offset)
|
||||||
_, err = do.Seek(offset, 0)
|
_, err = do.Seek(offset, io.SeekStart)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fs.Debugf(fh.remote, "ReadFileHandle.Read io.Seeker failed: %v", err)
|
fs.Debugf(fh.remote, "ReadFileHandle.Read io.Seeker failed: %v", err)
|
||||||
return err
|
return err
|
||||||
|
@ -144,9 +144,9 @@ func (fh *ReadFileHandle) Seek(offset int64, whence int) (n int64, err error) {
|
||||||
}
|
}
|
||||||
size := fh.size
|
size := fh.size
|
||||||
switch whence {
|
switch whence {
|
||||||
case 0:
|
case io.SeekStart:
|
||||||
fh.roffset = 0
|
fh.roffset = 0
|
||||||
case 2:
|
case io.SeekEnd:
|
||||||
fh.roffset = size
|
fh.roffset = size
|
||||||
}
|
}
|
||||||
fh.roffset += offset
|
fh.roffset += offset
|
||||||
|
|
|
@ -87,25 +87,25 @@ func TestReadFileHandleSeek(t *testing.T) {
|
||||||
assert.Equal(t, "0", readString(t, fh, 1))
|
assert.Equal(t, "0", readString(t, fh, 1))
|
||||||
|
|
||||||
// 0 means relative to the origin of the file,
|
// 0 means relative to the origin of the file,
|
||||||
n, err := fh.Seek(5, 0)
|
n, err := fh.Seek(5, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(5), n)
|
assert.Equal(t, int64(5), n)
|
||||||
assert.Equal(t, "5", readString(t, fh, 1))
|
assert.Equal(t, "5", readString(t, fh, 1))
|
||||||
|
|
||||||
// 1 means relative to the current offset
|
// 1 means relative to the current offset
|
||||||
n, err = fh.Seek(-3, 1)
|
n, err = fh.Seek(-3, io.SeekCurrent)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(3), n)
|
assert.Equal(t, int64(3), n)
|
||||||
assert.Equal(t, "3", readString(t, fh, 1))
|
assert.Equal(t, "3", readString(t, fh, 1))
|
||||||
|
|
||||||
// 2 means relative to the end.
|
// 2 means relative to the end.
|
||||||
n, err = fh.Seek(-3, 2)
|
n, err = fh.Seek(-3, io.SeekEnd)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(13), n)
|
assert.Equal(t, int64(13), n)
|
||||||
assert.Equal(t, "d", readString(t, fh, 1))
|
assert.Equal(t, "d", readString(t, fh, 1))
|
||||||
|
|
||||||
// Seek off the end
|
// Seek off the end
|
||||||
n, err = fh.Seek(100, 0)
|
n, err = fh.Seek(100, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
// Get the error on read
|
// Get the error on read
|
||||||
|
@ -116,7 +116,7 @@ func TestReadFileHandleSeek(t *testing.T) {
|
||||||
|
|
||||||
// Check if noSeek is set we get an error
|
// Check if noSeek is set we get an error
|
||||||
fh.noSeek = true
|
fh.noSeek = true
|
||||||
_, err = fh.Seek(0, 0)
|
_, err = fh.Seek(0, io.SeekStart)
|
||||||
assert.Equal(t, ESPIPE, err)
|
assert.Equal(t, ESPIPE, err)
|
||||||
|
|
||||||
// Close
|
// Close
|
||||||
|
|
|
@ -123,11 +123,11 @@ func TestRWFileHandleSeek(t *testing.T) {
|
||||||
assert.Equal(t, fh.opened, false)
|
assert.Equal(t, fh.opened, false)
|
||||||
|
|
||||||
// Check null seeks don't open the file
|
// Check null seeks don't open the file
|
||||||
n, err := fh.Seek(0, 0)
|
n, err := fh.Seek(0, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(0), n)
|
assert.Equal(t, int64(0), n)
|
||||||
assert.Equal(t, fh.opened, false)
|
assert.Equal(t, fh.opened, false)
|
||||||
n, err = fh.Seek(0, 1)
|
n, err = fh.Seek(0, io.SeekCurrent)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(0), n)
|
assert.Equal(t, int64(0), n)
|
||||||
assert.Equal(t, fh.opened, false)
|
assert.Equal(t, fh.opened, false)
|
||||||
|
@ -135,25 +135,25 @@ func TestRWFileHandleSeek(t *testing.T) {
|
||||||
assert.Equal(t, "0", rwReadString(t, fh, 1))
|
assert.Equal(t, "0", rwReadString(t, fh, 1))
|
||||||
|
|
||||||
// 0 means relative to the origin of the file,
|
// 0 means relative to the origin of the file,
|
||||||
n, err = fh.Seek(5, 0)
|
n, err = fh.Seek(5, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(5), n)
|
assert.Equal(t, int64(5), n)
|
||||||
assert.Equal(t, "5", rwReadString(t, fh, 1))
|
assert.Equal(t, "5", rwReadString(t, fh, 1))
|
||||||
|
|
||||||
// 1 means relative to the current offset
|
// 1 means relative to the current offset
|
||||||
n, err = fh.Seek(-3, 1)
|
n, err = fh.Seek(-3, io.SeekCurrent)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(3), n)
|
assert.Equal(t, int64(3), n)
|
||||||
assert.Equal(t, "3", rwReadString(t, fh, 1))
|
assert.Equal(t, "3", rwReadString(t, fh, 1))
|
||||||
|
|
||||||
// 2 means relative to the end.
|
// 2 means relative to the end.
|
||||||
n, err = fh.Seek(-3, 2)
|
n, err = fh.Seek(-3, io.SeekEnd)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, int64(13), n)
|
assert.Equal(t, int64(13), n)
|
||||||
assert.Equal(t, "d", rwReadString(t, fh, 1))
|
assert.Equal(t, "d", rwReadString(t, fh, 1))
|
||||||
|
|
||||||
// Seek off the end
|
// Seek off the end
|
||||||
n, err = fh.Seek(100, 0)
|
n, err = fh.Seek(100, io.SeekStart)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
// Get the error on read
|
// Get the error on read
|
||||||
|
@ -290,7 +290,7 @@ func TestRWFileHandleMethodsWrite(t *testing.T) {
|
||||||
assert.Equal(t, "file1", node.Name())
|
assert.Equal(t, "file1", node.Name())
|
||||||
|
|
||||||
offset := func() int64 {
|
offset := func() int64 {
|
||||||
n, err := fh.Seek(0, 1)
|
n, err := fh.Seek(0, io.SeekCurrent)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
return n
|
return n
|
||||||
}
|
}
|
||||||
|
@ -362,7 +362,7 @@ func TestRWFileHandleWriteAt(t *testing.T) {
|
||||||
defer cleanup(t, r, vfs)
|
defer cleanup(t, r, vfs)
|
||||||
|
|
||||||
offset := func() int64 {
|
offset := func() int64 {
|
||||||
n, err := fh.Seek(0, 1)
|
n, err := fh.Seek(0, io.SeekCurrent)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
return n
|
return n
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
package vfs
|
package vfs
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
@ -58,7 +59,7 @@ func TestVFSbaseHandle(t *testing.T) {
|
||||||
_, err = fh.Readdirnames(0)
|
_, err = fh.Readdirnames(0)
|
||||||
assert.Equal(t, ENOSYS, err)
|
assert.Equal(t, ENOSYS, err)
|
||||||
|
|
||||||
_, err = fh.Seek(0, 0)
|
_, err = fh.Seek(0, io.SeekStart)
|
||||||
assert.Equal(t, ENOSYS, err)
|
assert.Equal(t, ENOSYS, err)
|
||||||
|
|
||||||
_, err = fh.Stat()
|
_, err = fh.Stat()
|
||||||
|
|
Loading…
Reference in a new issue