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: #unit
|
2020-07-28 23:16:47 +00:00
|
|
|
package paychmgr
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/ipfs/go-cid"
|
|
|
|
ds "github.com/ipfs/go-datastore"
|
|
|
|
ds_sync "github.com/ipfs/go-datastore/sync"
|
|
|
|
"github.com/stretchr/testify/require"
|
2022-06-14 15:00:51 +00:00
|
|
|
|
|
|
|
"github.com/filecoin-project/go-state-types/big"
|
|
|
|
tutils "github.com/filecoin-project/specs-actors/support/testing"
|
2020-07-28 23:16:47 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestPaychSettle(t *testing.T) {
|
2021-12-14 15:56:16 +00:00
|
|
|
//stm: @TOKEN_PAYCH_WAIT_READY_001, @TOKEN_PAYCH_SETTLE_001, @TOKEN_PAYCH_LIST_CHANNELS_001
|
2020-07-28 23:16:47 +00:00
|
|
|
ctx := context.Background()
|
|
|
|
store := NewStore(ds_sync.MutexWrap(ds.NewMapDatastore()))
|
|
|
|
|
|
|
|
expch := tutils.NewIDAddr(t, 100)
|
|
|
|
expch2 := tutils.NewIDAddr(t, 101)
|
|
|
|
from := tutils.NewIDAddr(t, 101)
|
|
|
|
to := tutils.NewIDAddr(t, 102)
|
|
|
|
|
2020-08-11 14:20:05 +00:00
|
|
|
mock := newMockManagerAPI()
|
|
|
|
defer mock.close()
|
2020-07-28 23:16:47 +00:00
|
|
|
|
2020-08-11 14:20:05 +00:00
|
|
|
mgr, err := newManager(store, mock)
|
2020-07-28 23:16:47 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
amt := big.NewInt(10)
|
2022-01-06 15:04:39 +00:00
|
|
|
_, mcid, err := mgr.GetPaych(ctx, from, to, amt, onChainReserve)
|
2020-07-28 23:16:47 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Send channel create response
|
|
|
|
response := testChannelResponse(t, expch)
|
2020-08-11 14:20:05 +00:00
|
|
|
mock.receiveMsgResponse(mcid, response)
|
2020-07-28 23:16:47 +00:00
|
|
|
|
|
|
|
// Get the channel address
|
|
|
|
ch, err := mgr.GetPaychWaitReady(ctx, mcid)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, expch, ch)
|
|
|
|
|
|
|
|
// Settle the channel
|
|
|
|
_, err = mgr.Settle(ctx, ch)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Send another request for funds to the same from/to
|
|
|
|
// (should create a new channel because the previous channel
|
|
|
|
// is settling)
|
|
|
|
amt2 := big.NewInt(5)
|
2022-01-06 15:04:39 +00:00
|
|
|
_, mcid2, err := mgr.GetPaych(ctx, from, to, amt2, onChainReserve)
|
2020-07-28 23:16:47 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotEqual(t, cid.Undef, mcid2)
|
|
|
|
|
|
|
|
// Send new channel create response
|
|
|
|
response2 := testChannelResponse(t, expch2)
|
2020-08-11 14:20:05 +00:00
|
|
|
mock.receiveMsgResponse(mcid2, response2)
|
2020-07-28 23:16:47 +00:00
|
|
|
|
|
|
|
// Make sure the new channel is different from the old channel
|
|
|
|
ch2, err := mgr.GetPaychWaitReady(ctx, mcid2)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotEqual(t, ch, ch2)
|
2020-08-06 12:47:48 +00:00
|
|
|
|
|
|
|
// There should now be two channels
|
2021-12-14 17:01:45 +00:00
|
|
|
cis, err := mgr.ListChannels(ctx)
|
2020-08-06 12:47:48 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Len(t, cis, 2)
|
2020-07-28 23:16:47 +00:00
|
|
|
}
|