Skip to content

Commit

Permalink
Merge pull request ipfs/go-ipfs-blockstore#47 from shazow/blockstore-…
Browse files Browse the repository at this point in the history
…put-tst

Add test to maintain Put contract of calling Has first

This commit was moved from ipfs/go-ipfs-blockstore@6486d67
  • Loading branch information
Stebalien authored Feb 25, 2020
2 parents f821f8a + fdc5711 commit cf01195
Showing 1 changed file with 32 additions and 0 deletions.
32 changes: 32 additions & 0 deletions blockstore/blockstore_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,38 @@ func TestPutThenGetSizeBlock(t *testing.T) {
}
}

type countHasDS struct {
ds.Datastore
hasCount int
}

func (ds *countHasDS) Has(key ds.Key) (exists bool, err error) {
ds.hasCount += 1
return ds.Datastore.Has(key)
}

func TestPutUsesHas(t *testing.T) {
// Some datastores rely on the implementation detail that Put checks Has
// first, to avoid overriding existing objects' metadata. This test ensures
// that Blockstore continues to behave this way.
// Please ping https://github.com/ipfs/go-ipfs-blockstore/pull/47 if this
// behavior is being removed.
ds := &countHasDS{
Datastore: ds.NewMapDatastore(),
}
bs := NewBlockstore(ds_sync.MutexWrap(ds))
bl := blocks.NewBlock([]byte("some data"))
if err := bs.Put(bl); err != nil {
t.Fatal(err)
}
if err := bs.Put(bl); err != nil {
t.Fatal(err)
}
if ds.hasCount != 2 {
t.Errorf("Blockstore did not call Has before attempting Put, this breaks compatibility")
}
}

func TestHashOnRead(t *testing.T) {
orginalDebug := u.Debug
defer (func() {
Expand Down

0 comments on commit cf01195

Please sign in to comment.