Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

R4R: Slashing, validator set, and governance simulation #1783

Merged
merged 80 commits into from
Aug 16, 2018
Merged
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
80 commits
Select commit Hold shift + click to select a range
15a5cd5
Simulate time passing
cwgoes Jul 20, 2018
2a04c04
Print out final height & time
cwgoes Jul 20, 2018
79e870a
Simulate validator set changes
cwgoes Jul 20, 2018
a1ea7cc
Simulate different block loads
cwgoes Jul 20, 2018
727b7bd
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 23, 2018
9c55ec5
Random SigningValidators
cwgoes Jul 23, 2018
782fcd7
Simple random Byzantine evidence
cwgoes Jul 23, 2018
e4d0b17
Option to skip RequestBeginBlock randomization
cwgoes Jul 23, 2018
0f85d6c
Initial genesis validator in simulation
cwgoes Jul 23, 2018
d2709e2
Helpful printouts
cwgoes Jul 23, 2018
6c07f4a
Better load simulation
cwgoes Jul 23, 2018
01264b9
Nicer logs
cwgoes Jul 23, 2018
d7f1553
Linter fixes; 'make format'
cwgoes Jul 23, 2018
738009c
Delay RequestBeginBlock.SigningValidators one block; nicer formatting
cwgoes Jul 24, 2018
b032b8e
Period invariant checks
cwgoes Jul 24, 2018
2bf2c9a
SimulateMsgUnrevoke
cwgoes Jul 24, 2018
e69f7fc
Simulated x/gov msgs, more initially bonded
cwgoes Jul 25, 2018
3a4aed5
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 25, 2018
9a07c07
Linter fixes; 'make format'
cwgoes Jul 25, 2018
be70a21
Somehow nondeterministic
cwgoes Jul 25, 2018
d151988
Debugging contd.
cwgoes Jul 25, 2018
f0cff46
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 25, 2018
5058379
Fix nondeterminism but now we found a bug!
cwgoes Jul 25, 2018
8cacb96
Debugging contd.
cwgoes Jul 26, 2018
d9000fb
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 26, 2018
7a02762
More debugging
cwgoes Jul 26, 2018
ce52253
Debugging contd.
cwgoes Jul 27, 2018
d36d739
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 27, 2018
529b93a
Remove debugging Printfs
cwgoes Jul 27, 2018
14c4642
Debugging contd.
cwgoes Jul 27, 2018
8ccde07
Merge PR #1842: simulation: Use transition matrices for simulating va…
ValarDragon Jul 28, 2018
a2ed2d1
Remove debug Printfs
cwgoes Jul 28, 2018
7fb08f8
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 30, 2018
4036295
Governance simulation contd.
cwgoes Jul 30, 2018
e7a732d
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 31, 2018
2a9061e
dep; make format
cwgoes Jul 31, 2018
462e0cc
NewInt64Coin
cwgoes Jul 31, 2018
afed984
Pass header correctly for slashing
cwgoes Jul 31, 2018
d69107c
Longer timeout; disable inflation
cwgoes Jul 31, 2018
c3b9818
Separate into 'test_sim_modules', 'test_sim_gaia_{fast,slow}'
cwgoes Jul 31, 2018
23d96f0
Misc fixes
cwgoes Jul 31, 2018
fd6594b
Fix teesny-tiny spelling mistake
cwgoes Jul 31, 2018
2163e96
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Jul 31, 2018
416e0d7
Past evidence; events for BeginBlock/EndBlock
cwgoes Aug 1, 2018
9a4a42b
Simplify simulation configuration
cwgoes Aug 1, 2018
dfb81f0
Add module simulation for x/gov
cwgoes Aug 1, 2018
6caaebc
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Aug 1, 2018
b1b7d9d
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Aug 3, 2018
ebd394c
Fix BeginBlock on existing deliverState.ctx
cwgoes Aug 3, 2018
03d9378
Minor cleanup
cwgoes Aug 3, 2018
36aa0af
Cleanup x/gov simulation msgs
cwgoes Aug 3, 2018
d9c1d67
Log proposal EndBlocker events
cwgoes Aug 3, 2018
fadfe87
Update PENDING.md
cwgoes Aug 3, 2018
7b2b989
Minor fixes
cwgoes Aug 3, 2018
73d5028
Correct evidence type
cwgoes Aug 3, 2018
a4c7fa7
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Aug 6, 2018
64a2e5b
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Aug 8, 2018
0a3f610
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Aug 8, 2018
bce3f5d
reduce unnecessarsy verbosity
ValarDragon Aug 9, 2018
75f8f15
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Aug 10, 2018
268c0ac
dep ensure -v -update
cwgoes Aug 10, 2018
f18c01d
Merge PR #1994: Delete install.md
zramsay Aug 13, 2018
1a64c87
Merge PR #1995: upgrading ledger goclient lib
jleni Aug 13, 2018
2b703c9
Merge branch 'develop' into cwgoes/slashing-simulation
cwgoes Aug 13, 2018
b40c9e8
Remove simulation from 'make test_cover'
cwgoes Aug 13, 2018
198f0f3
.ABCIValidator() includes address
cwgoes Aug 13, 2018
f172dd6
Minor fixes
cwgoes Aug 13, 2018
63762e9
Remove from CircleCI test_cover (why is this different)
cwgoes Aug 13, 2018
11ae0f3
Merge branch 'release/v0.24.0' into cwgoes/slashing-simulation
cwgoes Aug 15, 2018
70cc9bd
Update Gopkg.lock
cwgoes Aug 15, 2018
44c5ae7
Change timeout on 'make test_sim_gaia_fast'
cwgoes Aug 15, 2018
4bd01b0
testing...
cwgoes Aug 15, 2018
6e58500
Merge branch 'release/v0.24.0' into cwgoes/slashing-simulation
cwgoes Aug 15, 2018
1e1f337
Some logs for stake bug
cwgoes Aug 15, 2018
c13dd76
Add more debugging
cwgoes Aug 15, 2018
93060d7
Make randomized simulation deterministic from a given seed (#2059)
ValarDragon Aug 16, 2018
54ee496
Update Gopkg.lock
cwgoes Aug 16, 2018
617a503
Zero inflation on stake module test; additional event
cwgoes Aug 16, 2018
169260f
Remove accidental change from develop
cwgoes Aug 16, 2018
eb3e623
Remove printfs for merge into release/v0.24.0
cwgoes Aug 16, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,11 @@ test_sim:
@echo "Pass the flag 'SimulationNumKeys' to run with the specified number of keys."
@echo "Pass the flag 'SimulationNumBlocks' to run with the specified number of blocks."
@echo "Pass the flag 'SimulationBlockSize' to run with the specified block size (operations per block)."
@go test ./cmd/gaia/app -run TestFullGaiaSimulation -SimulationEnabled=true -SimulationBlockSize=200 -v
@echo "Pass the flag 'SimulationMinTimePerBlock' to run with the specified minimum block time."
@echo "Pass the flag 'SimulationMaxTimePerBlock' to run with the specified maximum block time."
@echo "Pass the flag 'SimulationSigningFraction' to run with the specified chance of a given validator signing a given block."
@echo "Pass the flag 'SimulationEvidenceFraction' to run with the specified chance of finding evidence on a given block."
@go test ./cmd/gaia/app -run TestFullGaiaSimulation -SimulationEnabled=true -v

test_cover:
@bash tests/test_cover.sh
Expand Down
69 changes: 54 additions & 15 deletions cmd/gaia/app/sim_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,47 +8,72 @@ import (

"github.com/stretchr/testify/require"

"github.com/tendermint/tendermint/crypto"
dbm "github.com/tendermint/tendermint/libs/db"
"github.com/tendermint/tendermint/libs/log"

"github.com/cosmos/cosmos-sdk/baseapp"
sdk "github.com/cosmos/cosmos-sdk/types"
banksim "github.com/cosmos/cosmos-sdk/x/bank/simulation"
govsim "github.com/cosmos/cosmos-sdk/x/gov/simulation"
"github.com/cosmos/cosmos-sdk/x/mock/simulation"
slashingsim "github.com/cosmos/cosmos-sdk/x/slashing/simulation"
stake "github.com/cosmos/cosmos-sdk/x/stake"
stakesim "github.com/cosmos/cosmos-sdk/x/stake/simulation"
)

var (
seed int64
numKeys int
numBlocks int
blockSize int
enabled bool
seed int64
numKeys int
numBlocks int
blockSize int
minTimePerBlock int64
maxTimePerBlock int64
signingFraction float64
evidenceFraction float64
enabled bool
)

func init() {
flag.Int64Var(&seed, "SimulationSeed", 42, "Simulation random seed")
flag.IntVar(&numKeys, "SimulationNumKeys", 10, "Number of keys (accounts)")
flag.IntVar(&numBlocks, "SimulationNumBlocks", 100, "Number of blocks")
flag.IntVar(&blockSize, "SimulationBlockSize", 100, "Operations per block")
flag.IntVar(&numKeys, "SimulationNumKeys", 1000, "Number of keys (accounts)")
flag.IntVar(&numBlocks, "SimulationNumBlocks", 1000, "Number of blocks")
flag.IntVar(&blockSize, "SimulationBlockSize", 200, "Operations per block")
flag.Int64Var(&minTimePerBlock, "SimulationMinTimePerBlock", 86400, "Minimum time per block (seconds)")
flag.Int64Var(&maxTimePerBlock, "SimulationMaxTimePerBlock", 2*86400, "Maximum time per block (seconds)")
flag.Float64Var(&signingFraction, "SimulationSigningFraction", 0.7, "Chance a given validator signs a given block")
flag.Float64Var(&evidenceFraction, "SimulationEvidenceFraction", 0.01, "Chance that any evidence is found on a given block")
flag.BoolVar(&enabled, "SimulationEnabled", false, "Enable the simulation")
}

func appStateFn(r *rand.Rand, accs []sdk.AccAddress) json.RawMessage {
func appStateFn(r *rand.Rand, keys []crypto.PrivKey, accs []sdk.AccAddress) json.RawMessage {
var genesisAccounts []GenesisAccount

// Randomly generate some genesis accounts
for _, addr := range accs {
for _, acc := range accs {
coins := sdk.Coins{sdk.Coin{"steak", sdk.NewInt(100)}}
genesisAccounts = append(genesisAccounts, GenesisAccount{
Address: addr,
Address: acc,
Coins: coins,
})
}

// Default genesis state
stakeGenesis := stake.DefaultGenesisState()
stakeGenesis.Pool.LooseTokens = sdk.NewRat(1000)
var validators []stake.Validator
var delegations []stake.Delegation
numInitiallyBonded := int64(50)
Copy link
Contributor

@ValarDragon ValarDragon Aug 3, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it difficult to change this to
numInitiallyBonded := 5 + r.Int64n(90)?

EDIT: Like are there other impacts this may have, so that this should be in a seperate PR? If its just the above simple change should we use it?

for i := 0; i < int(numInitiallyBonded); i++ {
validator := stake.NewValidator(accs[i], keys[i].PubKey(), stake.Description{})
validator.Tokens = sdk.NewRat(100)
validator.DelegatorShares = sdk.NewRat(100)
delegation := stake.Delegation{accs[i], accs[i], sdk.NewRat(100), 0}
validators = append(validators, validator)
delegations = append(delegations, delegation)
}
stakeGenesis.Pool.LooseTokens = sdk.NewRat(int64(100*numKeys) + (numInitiallyBonded * 100))
stakeGenesis.Validators = validators
stakeGenesis.Bonds = delegations
genesis := GenesisState{
Accounts: genesisAccounts,
StakeData: stakeGenesis,
Expand All @@ -74,27 +99,41 @@ func TestFullGaiaSimulation(t *testing.T) {
app := NewGaiaApp(logger, db, nil)
require.Equal(t, "GaiaApp", app.Name())

allInvariants := func(t *testing.T, baseapp *baseapp.BaseApp, log string) {
banksim.NonnegativeBalanceInvariant(app.accountMapper)(t, baseapp, log)
govsim.AllInvariants()(t, baseapp, log)
stakesim.AllInvariants(app.coinKeeper, app.stakeKeeper, app.accountMapper)(t, baseapp, log)
slashingsim.AllInvariants()(t, baseapp, log)
}

// Run randomized simulation
simulation.SimulateFromSeed(
t, app.BaseApp, appStateFn, seed,
[]simulation.TestAndRunTx{
banksim.TestAndRunSingleInputMsgSend(app.accountMapper),
govsim.SimulateMsgSubmitProposal(app.govKeeper, app.stakeKeeper),
govsim.SimulateMsgDeposit(app.govKeeper, app.stakeKeeper),
govsim.SimulateMsgVote(app.govKeeper, app.stakeKeeper),
stakesim.SimulateMsgCreateValidator(app.accountMapper, app.stakeKeeper),
stakesim.SimulateMsgEditValidator(app.stakeKeeper),
stakesim.SimulateMsgDelegate(app.accountMapper, app.stakeKeeper),
stakesim.SimulateMsgBeginUnbonding(app.accountMapper, app.stakeKeeper),
//stakesim.SimulateMsgBeginUnbonding(app.accountMapper, app.stakeKeeper),
stakesim.SimulateMsgCompleteUnbonding(app.stakeKeeper),
stakesim.SimulateMsgBeginRedelegate(app.accountMapper, app.stakeKeeper),
stakesim.SimulateMsgCompleteRedelegate(app.stakeKeeper),
slashingsim.SimulateMsgUnrevoke(app.slashingKeeper),
},
[]simulation.RandSetup{},
[]simulation.Invariant{
banksim.NonnegativeBalanceInvariant(app.accountMapper),
stakesim.AllInvariants(app.coinKeeper, app.stakeKeeper, app.accountMapper),
simulation.PeriodicInvariant(allInvariants, 100, 0),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it make sense to break up these invariants more? i.e. bank invariant every 100, staking/slashing every time?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Possibly! Currently optimized for ease of changing periodicity...

Copy link
Contributor

@ValarDragon ValarDragon Jul 25, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In addition to what I previously suggested, maybe we should have a separate convenient debug full simulation function which takes in the seed and then run the invariants every time. (i.e. I'd prefer if we had a very easy way to see exactly what caused that randomized error once we've found an error)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can search by bisection.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(and also have a way to run the invariants every time, sure)

},
numKeys,
numBlocks,
blockSize,
minTimePerBlock,
maxTimePerBlock,
signingFraction,
evidenceFraction,
)

}
24 changes: 12 additions & 12 deletions docs/sdk/core/examples/app2_test.go
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
package app

import (
"testing"
"github.com/tendermint/tendermint/crypto"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/tendermint/tendermint/crypto"
"testing"

"github.com/stretchr/testify/require"
)
Expand All @@ -17,8 +17,8 @@ func TestEncoding(t *testing.T) {
addr2 := priv2.PubKey().Address().Bytes()

sendMsg := MsgSend{
From: addr1,
To: addr2,
From: addr1,
To: addr2,
Amount: sdk.Coins{{"testCoins", sdk.NewInt(100)}},
}

Expand All @@ -30,8 +30,8 @@ func TestEncoding(t *testing.T) {
}

sendTxBefore := app2Tx{
Msg: sendMsg,
PubKey: priv1.PubKey(),
Msg: sendMsg,
PubKey: priv1.PubKey(),
Signature: sig,
}

Expand All @@ -47,13 +47,13 @@ func TestEncoding(t *testing.T) {
require.Nil(t, err, "Error decoding sendTx")

sendTxAfter := tx1.(app2Tx)

require.Equal(t, sendTxBefore, sendTxAfter, "Transaction changed after encoding/decoding")

issueMsg := MsgIssue{
Issuer: addr1,
Issuer: addr1,
Receiver: addr2,
Coin: sdk.Coin{"testCoin", sdk.NewInt(100)},
Coin: sdk.Coin{"testCoin", sdk.NewInt(100)},
}

signBytes = issueMsg.GetSignBytes()
Expand All @@ -63,8 +63,8 @@ func TestEncoding(t *testing.T) {
}

issueTxBefore := app2Tx{
Msg: issueMsg,
PubKey: priv1.PubKey(),
Msg: issueMsg,
PubKey: priv1.PubKey(),
Signature: sig,
}

Expand All @@ -80,4 +80,4 @@ func TestEncoding(t *testing.T) {

require.Equal(t, issueTxBefore, issueTxAfter, "Transaction changed after encoding/decoding")

}
}
4 changes: 2 additions & 2 deletions docs/sdk/core/examples/app3.go
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
package app

import (
"github.com/tendermint/tendermint/crypto"
cmn "github.com/tendermint/tendermint/libs/common"
dbm "github.com/tendermint/tendermint/libs/db"
"github.com/tendermint/tendermint/libs/log"
"github.com/tendermint/tendermint/crypto"

bapp "github.com/cosmos/cosmos-sdk/baseapp"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/wire"
"github.com/cosmos/cosmos-sdk/x/auth"
"github.com/cosmos/cosmos-sdk/x/bank"
"github.com/cosmos/cosmos-sdk/wire"
)

const (
Expand Down
47 changes: 23 additions & 24 deletions docs/sdk/core/examples/app4_test.go
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
package app

import (
"github.com/stretchr/testify/require"
"os"
"encoding/json"
"testing"
dbm "github.com/tendermint/tendermint/libs/db"
"github.com/tendermint/tendermint/libs/log"
"github.com/stretchr/testify/require"
abci "github.com/tendermint/tendermint/abci/types"
"github.com/tendermint/tendermint/crypto"
dbm "github.com/tendermint/tendermint/libs/db"
"github.com/tendermint/tendermint/libs/log"
"os"
"testing"

bapp "github.com/cosmos/cosmos-sdk/baseapp"
sdk "github.com/cosmos/cosmos-sdk/types"
Expand Down Expand Up @@ -44,7 +44,7 @@ func InitTestChain(bc *bapp.BaseApp, chainID string, addrs ...sdk.AccAddress) {
// Generate basic SpendMsg with one input and output
func GenerateSpendMsg(sender, receiver sdk.AccAddress, amount sdk.Coins) bank.MsgSend {
return bank.MsgSend{
Inputs: []bank.Input{{sender, amount}},
Inputs: []bank.Input{{sender, amount}},
Outputs: []bank.Output{{receiver, amount}},
}
}
Expand All @@ -64,26 +64,26 @@ func TestBadMsg(t *testing.T) {

// Construct transaction
fee := auth.StdFee{
Gas: 1000000000000000,
Gas: 1000000000000000,
Amount: sdk.Coins{{"testCoin", sdk.NewInt(0)}},
}
signBytes := auth.StdSignBytes("test-chain", 0, 0, fee, []sdk.Msg{msg}, "")
sig, err := priv1.Sign(signBytes)
if err != nil {
panic(err)
}
sigs := []auth.StdSignature{auth.StdSignature{
PubKey: priv1.PubKey(),
Signature: sig,
sigs := []auth.StdSignature{{
PubKey: priv1.PubKey(),
Signature: sig,
AccountNumber: 0,
Sequence: 0,
Sequence: 0,
}}

tx := auth.StdTx{
Msgs: []sdk.Msg{msg},
Fee: fee,
Msgs: []sdk.Msg{msg},
Fee: fee,
Signatures: sigs,
Memo: "",
Memo: "",
}

bc.BeginBlock(abci.RequestBeginBlock{Header: abci.Header{ChainID: "test-chain"}})
Expand All @@ -110,26 +110,26 @@ func TestMsgSend(t *testing.T) {
msg := GenerateSpendMsg(addr1, addr2, sdk.Coins{{"testCoin", sdk.NewInt(100)}})

fee := auth.StdFee{
Gas: 1000000000000000,
Gas: 1000000000000000,
Amount: sdk.Coins{{"testCoin", sdk.NewInt(0)}},
}
signBytes := auth.StdSignBytes("test-chain", 0, 0, fee, []sdk.Msg{msg}, "")
sig, err := priv1.Sign(signBytes)
if err != nil {
panic(err)
}
sigs := []auth.StdSignature{auth.StdSignature{
PubKey: priv1.PubKey(),
Signature: sig,
sigs := []auth.StdSignature{{
PubKey: priv1.PubKey(),
Signature: sig,
AccountNumber: 0,
Sequence: 0,
Sequence: 0,
}}

tx := auth.StdTx{
Msgs: []sdk.Msg{msg},
Fee: fee,
Msgs: []sdk.Msg{msg},
Fee: fee,
Signatures: sigs,
Memo: "",
Memo: "",
}

bc.BeginBlock(abci.RequestBeginBlock{})
Expand All @@ -138,5 +138,4 @@ func TestMsgSend(t *testing.T) {

require.True(t, res.IsOK(), res.Log)


}
}
24 changes: 12 additions & 12 deletions x/bank/app_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -112,8 +112,8 @@ func TestMsgSendWithAccounts(t *testing.T) {
expPass: true,
privKeys: []crypto.PrivKey{priv1},
expectedBalances: []expectedBalance{
expectedBalance{addr1, sdk.Coins{sdk.NewCoin("foocoin", 57)}},
expectedBalance{addr2, sdk.Coins{sdk.NewCoin("foocoin", 10)}},
{addr1, sdk.Coins{sdk.NewCoin("foocoin", 57)}},
{addr2, sdk.Coins{sdk.NewCoin("foocoin", 10)}},
},
},
{
Expand Down Expand Up @@ -168,9 +168,9 @@ func TestMsgSendMultipleOut(t *testing.T) {
expPass: true,
privKeys: []crypto.PrivKey{priv1},
expectedBalances: []expectedBalance{
expectedBalance{addr1, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
expectedBalance{addr2, sdk.Coins{sdk.NewCoin("foocoin", 47)}},
expectedBalance{addr3, sdk.Coins{sdk.NewCoin("foocoin", 5)}},
{addr1, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
{addr2, sdk.Coins{sdk.NewCoin("foocoin", 47)}},
{addr3, sdk.Coins{sdk.NewCoin("foocoin", 5)}},
},
},
}
Expand Down Expand Up @@ -210,10 +210,10 @@ func TestSengMsgMultipleInOut(t *testing.T) {
expPass: true,
privKeys: []crypto.PrivKey{priv1, priv4},
expectedBalances: []expectedBalance{
expectedBalance{addr1, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
expectedBalance{addr4, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
expectedBalance{addr2, sdk.Coins{sdk.NewCoin("foocoin", 52)}},
expectedBalance{addr3, sdk.Coins{sdk.NewCoin("foocoin", 10)}},
{addr1, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
{addr4, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
{addr2, sdk.Coins{sdk.NewCoin("foocoin", 52)}},
{addr3, sdk.Coins{sdk.NewCoin("foocoin", 10)}},
},
},
}
Expand Down Expand Up @@ -245,8 +245,8 @@ func TestMsgSendDependent(t *testing.T) {
expPass: true,
privKeys: []crypto.PrivKey{priv1},
expectedBalances: []expectedBalance{
expectedBalance{addr1, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
expectedBalance{addr2, sdk.Coins{sdk.NewCoin("foocoin", 10)}},
{addr1, sdk.Coins{sdk.NewCoin("foocoin", 32)}},
{addr2, sdk.Coins{sdk.NewCoin("foocoin", 10)}},
},
},
{
Expand All @@ -256,7 +256,7 @@ func TestMsgSendDependent(t *testing.T) {
expPass: true,
privKeys: []crypto.PrivKey{priv2},
expectedBalances: []expectedBalance{
expectedBalance{addr1, sdk.Coins{sdk.NewCoin("foocoin", 42)}},
{addr1, sdk.Coins{sdk.NewCoin("foocoin", 42)}},
},
},
}
Expand Down
Loading