forked from TrueCloudLab/rclone
lib/readers: add NoSeeker to adapt io.Reader to io.ReadSeeker
This commit is contained in:
parent
d61328e459
commit
e8f3f98aa0
2 changed files with 53 additions and 0 deletions
22
lib/readers/noseeker.go
Normal file
22
lib/readers/noseeker.go
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
package readers
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"io"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
errCantSeek = errors.New("can't Seek")
|
||||||
|
)
|
||||||
|
|
||||||
|
// NoSeeker adapts an io.Reader into an io.ReadSeeker.
|
||||||
|
//
|
||||||
|
// However if Seek() is called it will return an error.
|
||||||
|
type NoSeeker struct {
|
||||||
|
io.Reader
|
||||||
|
}
|
||||||
|
|
||||||
|
// Seek the stream - returns an error
|
||||||
|
func (r NoSeeker) Seek(offset int64, whence int) (abs int64, err error) {
|
||||||
|
return 0, errCantSeek
|
||||||
|
}
|
31
lib/readers/noseeker_test.go
Normal file
31
lib/readers/noseeker_test.go
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
package readers
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"io"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestNoSeeker(t *testing.T) {
|
||||||
|
r := bytes.NewBufferString("hello")
|
||||||
|
rs := NoSeeker{Reader: r}
|
||||||
|
|
||||||
|
// Check read
|
||||||
|
b := make([]byte, 4)
|
||||||
|
n, err := rs.Read(b)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Equal(t, 4, n)
|
||||||
|
assert.Equal(t, []byte("hell"), b)
|
||||||
|
|
||||||
|
// Check seek
|
||||||
|
_, err = rs.Seek(0, io.SeekCurrent)
|
||||||
|
assert.Equal(t, errCantSeek, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// check interfaces
|
||||||
|
var (
|
||||||
|
_ io.Reader = NoSeeker{}
|
||||||
|
_ io.Seeker = NoSeeker{}
|
||||||
|
)
|
Loading…
Reference in a new issue