79453663b3
* Annotate api,proxy_util,blockstore_badger, policy tests * Annotate splitstore: bsbadger / markset * Annotate splitstore feature * Annotate union/timed blockstore tests * Annotate openrpc, diff_adt tests * Annotate error,drand,events tests * Annotate predicates_test * Fix annotations * Annotate tscache, gen tests * Annotate fundmanager test * Annotate repub and selection tests * Annotate statetree_test * Annotate forks_test * Annotate searchwait_test.go * Fix duplicated @@ symbols * Annotate chain stmgr/store tests * Annotate more (types) tests * More tests annotated * Annotate conformance chaos actor tests * Annotate more integration tests * Annotate journal system tests * Annotate more tests. * Annotate gas,head buffer behaviors * Fix markset annotations * doc: test annotations for the markets dagstore wrapper * Annotate miner_api test in dagstore * Annotate more test files * Remove bad annotations from fsrepo * Annotate wdpost system * Remove bad annotations * Renamce "conformance" to "chaos_actor" tests * doc: stm annotations for blockheader & election proof tests * Annotate remaining "A" tests * annotate: stm for error_test * memrepo_test.go * Annotate "b" file tests * message_test.go * doc: stm annotate for fsrepo_test * Annotate "c" file tests * Annotate "D" test files * message_test.go * doc: stm annotate for chain, node/config & client * docs: stm annotate node_test * Annotate u,v,wl tests * doc: stm annotations for various test files * Annotate "T" test files * doc: stm annotate for proxy_util_test & policy_test * doc: stm annotate for various tests * doc: final few stm annotations * Add mempool unit tests * Add two more memPool Add tests * Update submodules * Add check function tests * Add stm annotations, refactor test helper * Annotate api,proxy_util,blockstore_badger, policy tests * Annotate splitstore: bsbadger / markset solving merge conflicts * Annotate splitstore feature * Annotate union/timed blockstore tests * Annotate openrpc, diff_adt tests * Annotate error,drand,events tests * Annotate predicates_test * Fix annotations * Annotate tscache, gen tests * Annotate fundmanager test * Annotate statetree_test * Annotate forks_test * Annotate searchwait_test.go * Fix duplicated @@ symbols * Annotate chain stmgr/store tests * Annotate more (types) tests * More tests annotated * Annotate conformance chaos actor tests * Annotate more integration tests * Annotate journal system tests * Annotate more tests. * Annotate gas,head buffer behaviors solve merge conflict * Fix markset annotations * Annotate miner_api test in dagstore * Annotate more test files * doc: test annotations for the markets dagstore wrapper * Annotate wdpost system * Renamce "conformance" to "chaos_actor" tests * Annotate remaining "A" tests * doc: stm annotations for blockheader & election proof tests * annotate: stm for error_test * Annotate "b" file tests * memrepo_test.go * Annotate "c" file tests * message_test.go * Annotate "D" test files * doc: stm annotate for fsrepo_test * Annotate u,v,wl tests * message_test.go * doc: stm annotate for chain, node/config & client * docs: stm annotate node_test * Annotate "T" test files * doc: stm annotations for various test files * Add mempool unit tests solve merge conflict * doc: stm annotate for proxy_util_test & policy_test * doc: stm annotate for various tests * doc: final few stm annotations * Add two more memPool Add tests * Update submodules * Add check function tests solve conflict * Add stm annotations, refactor test helper solve merge conflict * Change CLI test kinds to "unit" * Fix double merged test * Fix ccupgrade_test merge * Fix lint issues * Add stm annotation to types_Test * Test vectors submodule * Add file annotation to burn_test Co-authored-by: Nikola Divic <divicnikola@gmail.com> Co-authored-by: TheMenko <themenkoprojects@gmail.com>
110 lines
2.3 KiB
Go
110 lines
2.3 KiB
Go
//stm: #unit
|
|
package blockstore
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
blocks "github.com/ipfs/go-block-format"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
var (
|
|
b0 = blocks.NewBlock([]byte("abc"))
|
|
b1 = blocks.NewBlock([]byte("foo"))
|
|
b2 = blocks.NewBlock([]byte("bar"))
|
|
)
|
|
|
|
func TestUnionBlockstore_Get(t *testing.T) {
|
|
//stm: @SPLITSTORE_UNION_BLOCKSTORE_GET_001
|
|
ctx := context.Background()
|
|
m1 := NewMemory()
|
|
m2 := NewMemory()
|
|
|
|
_ = m1.Put(ctx, b1)
|
|
_ = m2.Put(ctx, b2)
|
|
|
|
u := Union(m1, m2)
|
|
|
|
v1, err := u.Get(ctx, b1.Cid())
|
|
require.NoError(t, err)
|
|
require.Equal(t, b1.RawData(), v1.RawData())
|
|
|
|
v2, err := u.Get(ctx, b2.Cid())
|
|
require.NoError(t, err)
|
|
require.Equal(t, b2.RawData(), v2.RawData())
|
|
}
|
|
|
|
func TestUnionBlockstore_Put_PutMany_Delete_AllKeysChan(t *testing.T) {
|
|
//stm: @SPLITSTORE_UNION_BLOCKSTORE_PUT_001, @SPLITSTORE_UNION_BLOCKSTORE_HAS_001
|
|
//stm: @SPLITSTORE_UNION_BLOCKSTORE_PUT_MANY_001, @SPLITSTORE_UNION_BLOCKSTORE_DELETE_001
|
|
//stm: @SPLITSTORE_UNION_BLOCKSTORE_ALL_KEYS_CHAN_001
|
|
ctx := context.Background()
|
|
m1 := NewMemory()
|
|
m2 := NewMemory()
|
|
|
|
u := Union(m1, m2)
|
|
|
|
err := u.Put(ctx, b0)
|
|
require.NoError(t, err)
|
|
|
|
var has bool
|
|
|
|
// write was broadcasted to all stores.
|
|
has, _ = m1.Has(ctx, b0.Cid())
|
|
require.True(t, has)
|
|
|
|
has, _ = m2.Has(ctx, b0.Cid())
|
|
require.True(t, has)
|
|
|
|
has, _ = u.Has(ctx, b0.Cid())
|
|
require.True(t, has)
|
|
|
|
// put many.
|
|
err = u.PutMany(ctx, []blocks.Block{b1, b2})
|
|
require.NoError(t, err)
|
|
|
|
// write was broadcasted to all stores.
|
|
has, _ = m1.Has(ctx, b1.Cid())
|
|
require.True(t, has)
|
|
|
|
has, _ = m1.Has(ctx, b2.Cid())
|
|
require.True(t, has)
|
|
|
|
has, _ = m2.Has(ctx, b1.Cid())
|
|
require.True(t, has)
|
|
|
|
has, _ = m2.Has(ctx, b2.Cid())
|
|
require.True(t, has)
|
|
|
|
// also in the union store.
|
|
has, _ = u.Has(ctx, b1.Cid())
|
|
require.True(t, has)
|
|
|
|
has, _ = u.Has(ctx, b2.Cid())
|
|
require.True(t, has)
|
|
|
|
// deleted from all stores.
|
|
err = u.DeleteBlock(ctx, b1.Cid())
|
|
require.NoError(t, err)
|
|
|
|
has, _ = u.Has(ctx, b1.Cid())
|
|
require.False(t, has)
|
|
|
|
has, _ = m1.Has(ctx, b1.Cid())
|
|
require.False(t, has)
|
|
|
|
has, _ = m2.Has(ctx, b1.Cid())
|
|
require.False(t, has)
|
|
|
|
// check that AllKeysChan returns b0 and b2, twice (once per backing store)
|
|
ch, err := u.AllKeysChan(context.Background())
|
|
require.NoError(t, err)
|
|
|
|
var i int
|
|
for range ch {
|
|
i++
|
|
}
|
|
require.Equal(t, 4, i)
|
|
}
|