2022-08-29 14:25:30 +00:00
|
|
|
// stm: #unit
|
2020-11-04 16:20:25 +00:00
|
|
|
package store
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/filecoin-project/lotus/chain/types"
|
|
|
|
"github.com/filecoin-project/lotus/chain/types/mock"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestHeadChangeCoalescer(t *testing.T) {
|
feat: Add additional test annotations (#8272)
* 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>
2022-03-16 17:37:34 +00:00
|
|
|
//stm: @CHAIN_STORE_COALESCE_HEAD_CHANGE_001
|
2020-11-04 16:20:25 +00:00
|
|
|
notif := make(chan headChange, 1)
|
|
|
|
c := NewHeadChangeCoalescer(func(revert, apply []*types.TipSet) error {
|
|
|
|
notif <- headChange{apply: apply, revert: revert}
|
|
|
|
return nil
|
2020-11-09 11:35:42 +00:00
|
|
|
},
|
|
|
|
100*time.Millisecond,
|
|
|
|
200*time.Millisecond,
|
|
|
|
10*time.Millisecond,
|
|
|
|
)
|
2020-11-04 16:25:54 +00:00
|
|
|
defer c.Close() //nolint
|
2020-11-04 16:20:25 +00:00
|
|
|
|
|
|
|
b0 := mock.MkBlock(nil, 0, 0)
|
|
|
|
root := mock.TipSet(b0)
|
|
|
|
bA := mock.MkBlock(root, 1, 1)
|
|
|
|
tA := mock.TipSet(bA)
|
|
|
|
bB := mock.MkBlock(root, 1, 2)
|
|
|
|
tB := mock.TipSet(bB)
|
|
|
|
tAB := mock.TipSet(bA, bB)
|
|
|
|
bC := mock.MkBlock(root, 1, 3)
|
|
|
|
tABC := mock.TipSet(bA, bB, bC)
|
|
|
|
bD := mock.MkBlock(root, 1, 4)
|
|
|
|
tABCD := mock.TipSet(bA, bB, bC, bD)
|
|
|
|
bE := mock.MkBlock(root, 1, 5)
|
|
|
|
tABCDE := mock.TipSet(bA, bB, bC, bD, bE)
|
|
|
|
|
2020-11-04 16:25:54 +00:00
|
|
|
c.HeadChange(nil, []*types.TipSet{tA}) //nolint
|
|
|
|
c.HeadChange(nil, []*types.TipSet{tB}) //nolint
|
|
|
|
c.HeadChange([]*types.TipSet{tA, tB}, []*types.TipSet{tAB}) //nolint
|
|
|
|
c.HeadChange([]*types.TipSet{tAB}, []*types.TipSet{tABC}) //nolint
|
2020-11-04 16:20:25 +00:00
|
|
|
|
|
|
|
change := <-notif
|
|
|
|
|
|
|
|
if len(change.revert) != 0 {
|
|
|
|
t.Fatalf("expected empty revert set but got %d elements", len(change.revert))
|
|
|
|
}
|
|
|
|
if len(change.apply) != 1 {
|
|
|
|
t.Fatalf("expected single element apply set but got %d elements", len(change.apply))
|
|
|
|
}
|
|
|
|
if change.apply[0] != tABC {
|
|
|
|
t.Fatalf("expected to apply tABC")
|
|
|
|
}
|
|
|
|
|
2020-11-04 16:25:54 +00:00
|
|
|
c.HeadChange([]*types.TipSet{tABC}, []*types.TipSet{tABCD}) //nolint
|
|
|
|
c.HeadChange([]*types.TipSet{tABCD}, []*types.TipSet{tABCDE}) //nolint
|
2020-11-04 16:20:25 +00:00
|
|
|
|
|
|
|
change = <-notif
|
|
|
|
|
|
|
|
if len(change.revert) != 1 {
|
|
|
|
t.Fatalf("expected single element revert set but got %d elements", len(change.revert))
|
|
|
|
}
|
|
|
|
if change.revert[0] != tABC {
|
|
|
|
t.Fatalf("expected to revert tABC")
|
|
|
|
}
|
|
|
|
if len(change.apply) != 1 {
|
|
|
|
t.Fatalf("expected single element apply set but got %d elements", len(change.apply))
|
|
|
|
}
|
|
|
|
if change.apply[0] != tABCDE {
|
|
|
|
t.Fatalf("expected to revert tABC")
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|