Use io.SeekStart/End/Current constants now for go1.7+ #2154

This commit is contained in:
Nick Craig-Wood 2018-04-06 19:53:06 +01:00
parent 80588a5a6b
commit e5be471ce0
24 changed files with 64 additions and 63 deletions

View file

@ -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 {

View file

@ -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
} }
} }

View file

@ -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
} }

View file

@ -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"))
} }

View file

@ -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)
} }

View file

@ -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 {

View file

@ -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)

View file

@ -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
} }

View file

@ -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)

View file

@ -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
} }

View file

@ -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")
} }

View file

@ -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
} }

View file

@ -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)
} }

View file

@ -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)
} }

View file

@ -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)
} }

View file

@ -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)

View file

@ -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

View file

@ -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)
} }

View file

@ -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")

View file

@ -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))

View file

@ -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

View file

@ -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

View file

@ -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
} }

View file

@ -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()