From 3e7f535beae601d334186f7316af957bc24bd865 Mon Sep 17 00:00:00 2001 From: "Santiago M. Mola" Date: Fri, 11 Nov 2016 16:31:04 +0100 Subject: utils/fs: add ReadAt to memory file and tests. (#122) * memory files now implement io.ReaderAt. * tests now check ReadAt behaviour. --- utils/fs/memory/memory.go | 12 +++++++++++- utils/fs/os/os.go | 2 +- utils/fs/test/fs_suite.go | 34 ++++++++++++++++++++++++++++++++++ 3 files changed, 46 insertions(+), 2 deletions(-) (limited to 'utils/fs') diff --git a/utils/fs/memory/memory.go b/utils/fs/memory/memory.go index 08a9599..ef54c37 100644 --- a/utils/fs/memory/memory.go +++ b/utils/fs/memory/memory.go @@ -189,6 +189,16 @@ func newFile(base, fullpath string, flag int) *file { } func (f *file) Read(b []byte) (int, error) { + n, err := f.ReadAt(b, f.position) + if err != nil { + return 0, err + } + + f.position += int64(n) + return n, err +} + +func (f *file) ReadAt(b []byte, off int64) (int, error) { if f.IsClosed() { return 0, fs.ErrClosed } @@ -197,7 +207,7 @@ func (f *file) Read(b []byte) (int, error) { return 0, errors.New("read not supported") } - n, err := f.content.ReadAt(b, f.position) + n, err := f.content.ReadAt(b, off) f.position += int64(n) return n, err diff --git a/utils/fs/os/os.go b/utils/fs/os/os.go index 4f4e651..5f9df67 100644 --- a/utils/fs/os/os.go +++ b/utils/fs/os/os.go @@ -178,6 +178,6 @@ func (f *osFile) Close() error { return f.file.Close() } -func (f *osFile) ReadAt(p []byte, off int64) (n int, err error) { +func (f *osFile) ReadAt(p []byte, off int64) (int, error) { return f.file.ReadAt(p, off) } diff --git a/utils/fs/test/fs_suite.go b/utils/fs/test/fs_suite.go index 8c413bf..5aa99e6 100644 --- a/utils/fs/test/fs_suite.go +++ b/utils/fs/test/fs_suite.go @@ -379,3 +379,37 @@ func (s *FilesystemSuite) TestJoin(c *C) { func (s *FilesystemSuite) TestBase(c *C) { c.Assert(s.Fs.Base(), Not(Equals), "") } + +func (s *FilesystemSuite) TestReadAtOnReadWrite(c *C) { + f, err := s.Fs.Create("foo") + c.Assert(err, IsNil) + _, err = f.Write([]byte("abcdefg")) + c.Assert(err, IsNil) + rf, ok := f.(io.ReaderAt) + c.Assert(ok, Equals, true) + b := make([]byte, 3) + n, err := rf.ReadAt(b, 2) + c.Assert(err, IsNil) + c.Assert(n, Equals, 3) + c.Assert(string(b), Equals, "cde") + c.Assert(f.Close(), IsNil) +} + +func (s *FilesystemSuite) TestReadAtOnReadOnly(c *C) { + f, err := s.Fs.Create("foo") + c.Assert(err, IsNil) + _, err = f.Write([]byte("abcdefg")) + c.Assert(err, IsNil) + c.Assert(f.Close(), IsNil) + + f, err = s.Fs.Open("foo") + c.Assert(err, IsNil) + rf, ok := f.(io.ReaderAt) + c.Assert(ok, Equals, true) + b := make([]byte, 3) + n, err := rf.ReadAt(b, 2) + c.Assert(err, IsNil) + c.Assert(n, Equals, 3) + c.Assert(string(b), Equals, "cde") + c.Assert(f.Close(), IsNil) +} -- cgit