diff --git a/blockservice/blockservice.go b/blockservice/blockservice.go index 33f69141c..2f320b139 100644 --- a/blockservice/blockservice.go +++ b/blockservice/blockservice.go @@ -366,12 +366,20 @@ func (s *Session) getSession() exchange.Fetcher { // GetBlock gets a block in the context of a request session func (s *Session) GetBlock(ctx context.Context, c cid.Cid) (blocks.Block, error) { - return getBlock(ctx, c, s.bs, s.getSession) // hash security + var f func() exchange.Fetcher + if s.sessEx != nil { + f = s.getSession + } + return getBlock(ctx, c, s.bs, f) // hash security } // GetBlocks gets blocks in the context of a request session func (s *Session) GetBlocks(ctx context.Context, ks []cid.Cid) <-chan blocks.Block { - return getBlocks(ctx, ks, s.bs, s.getSession) // hash security + var f func() exchange.Fetcher + if s.sessEx != nil { + f = s.getSession + } + return getBlocks(ctx, ks, s.bs, f) // hash security } var _ BlockGetter = (*Session)(nil) diff --git a/blockservice/blockservice_test.go b/blockservice/blockservice_test.go index dfd12fc43..36cdf0330 100644 --- a/blockservice/blockservice_test.go +++ b/blockservice/blockservice_test.go @@ -119,3 +119,31 @@ func (fe *fakeSessionExchange) NewSession(ctx context.Context) exchange.Fetcher } return fe.session } + +func TestNilExchange(t *testing.T) { + ctx := context.Background() + ctx, cancel := context.WithCancel(ctx) + defer cancel() + + bgen := butil.NewBlockGenerator() + block := bgen.Next() + + bs := blockstore.NewBlockstore(dssync.MutexWrap(ds.NewMapDatastore())) + bserv := NewWriteThrough(bs, nil) + sess := NewSession(ctx, bserv) + _, err := sess.GetBlock(ctx, block.Cid()) + if err != ErrNotFound { + t.Fatal("expected block to not be found") + } + err = bs.Put(block) + if err != nil { + t.Fatal(err) + } + b, err := sess.GetBlock(ctx, block.Cid()) + if err != nil { + t.Fatal(err) + } + if b.Cid() != block.Cid() { + t.Fatal("got the wrong block") + } +}