Skip to content
This repository has been archived by the owner on Jun 19, 2023. It is now read-only.

Commit

Permalink
test: test ReadAt if implemented
Browse files Browse the repository at this point in the history
(I plan on adding support to the http client, at least)
  • Loading branch information
Stebalien committed Sep 11, 2019
1 parent 114c623 commit ae83868
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 0 deletions.
2 changes: 2 additions & 0 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,5 @@ require (
github.com/multiformats/go-multiaddr v0.0.4
github.com/multiformats/go-multihash v0.0.7
)

go 1.12
82 changes: 82 additions & 0 deletions tests/unixfs.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ func (tp *TestSuite) TestUnixfs(t *testing.T) {
t.Run("TestLsNonUnixfs", tp.TestLsNonUnixfs)
t.Run("TestAddCloses", tp.TestAddCloses)
t.Run("TestGetSeek", tp.TestGetSeek)
t.Run("TestGetReadAt", tp.TestGetReadAt)
}

// `echo -n 'hello, world!' | ipfs add`
Expand Down Expand Up @@ -996,3 +997,84 @@ func (tp *TestSuite) TestGetSeek(t *testing.T) {
test(dataSize-50, io.SeekStart, 100, 50, true)
test(-5, io.SeekEnd, 100, 5, true)
}

func (tp *TestSuite) TestGetReadAt(t *testing.T) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
api, err := tp.makeAPI(ctx)
if err != nil {
t.Fatal(err)
}

dataSize := int64(100000)
tf := files.NewReaderFile(io.LimitReader(rand.New(rand.NewSource(1403768328)), dataSize))

p, err := api.Unixfs().Add(ctx, tf, options.Unixfs.Chunker("size-100"))
if err != nil {
t.Fatal(err)
}

r, err := api.Unixfs().Get(ctx, p)
if err != nil {
t.Fatal(err)
}

f, ok := r.(interface {
files.File
io.ReaderAt
})
if !ok {
t.Skip("ReaderAt not implemented")
}

orig := make([]byte, dataSize)
if _, err := io.ReadFull(f, orig); err != nil {
t.Fatal(err)
}
f.Close()

origR := bytes.NewReader(orig)

r, err = api.Unixfs().Get(ctx, p)
if err != nil {
t.Fatal(err)
}

test := func(offset int64, read int, expect int64, shouldEof bool) {
t.Run(fmt.Sprintf("readat%d-r%d-%d", offset, read, expect), func(t *testing.T) {
origBuf := make([]byte, read)
origRead, err := origR.ReadAt(origBuf, offset)
if err != nil && err != io.EOF {
t.Fatalf("orig: %s", err)
}
buf := make([]byte, read)
r, err := f.ReadAt(buf, offset)
if shouldEof {
if err != io.EOF {
t.Fatal("expected EOF, got: ", err)
}
} else if err != nil {
t.Fatal("got: ", err)
}

if int64(r) != expect {
t.Fatal("read wrong amount of data")
}
if r != origRead {
t.Fatal("read different amount of data than bytes.Reader")
}
if !bytes.Equal(buf, origBuf) {
fmt.Fprintf(os.Stderr, "original:\n%s\n", hex.Dump(origBuf))
fmt.Fprintf(os.Stderr, "got:\n%s\n", hex.Dump(buf))
t.Fatal("data didn't match")
}
})
}

test(3, 10, 10, false)
test(13, 10, 10, false)
test(513, 10, 10, false)
test(350, 100, 100, false)
test(0, int(dataSize), dataSize, false)
test(dataSize-50, 100, 50, true)
}

0 comments on commit ae83868

Please sign in to comment.