From 6ce26f984750933121fbcce4aa7b519d0bd70653 Mon Sep 17 00:00:00 2001 From: Assaf Morami Date: Wed, 13 Jul 2022 18:35:19 +0300 Subject: [PATCH] Test CosmosMsg::Custom Plus remove reflect_test.go which will never be used that way because we never allow CustomMsg --- .../shared/cosmwasm-v010-types/src/types.rs | 23 +- x/compute/internal/keeper/reflect_test.go | 447 ------------------ .../internal/keeper/secret_contracts_test.go | 31 ++ x/compute/internal/keeper/staking_test.go | 20 + .../testdata/test-contract/src/contract.rs | 13 +- .../v1-sanity-contract/src/contract.rs | 8 +- .../testdata/v1-sanity-contract/src/msg.rs | 2 + 7 files changed, 80 insertions(+), 464 deletions(-) delete mode 100644 x/compute/internal/keeper/reflect_test.go diff --git a/cosmwasm/enclaves/shared/cosmwasm-v010-types/src/types.rs b/cosmwasm/enclaves/shared/cosmwasm-v010-types/src/types.rs index 5fe472d8c..54bb82dde 100644 --- a/cosmwasm/enclaves/shared/cosmwasm-v010-types/src/types.rs +++ b/cosmwasm/enclaves/shared/cosmwasm-v010-types/src/types.rs @@ -143,7 +143,7 @@ pub struct ContractResult { #[serde(rename_all = "snake_case")] // This should be in correlation with cosmwasm-std/init_handle's CosmosMsg // See https://github.com/serde-rs/serde/issues/1296 why we cannot add De-Serialize trait bounds to T -pub enum CosmosMsg +pub enum CosmosMsg where T: Clone + fmt::Debug + PartialEq, { @@ -154,21 +154,14 @@ where Gov(GovMsg), } -/// Added this here for reflect tests.... +/// An empty struct that serves as a placeholder in different places, +/// such as contracts that don't set a custom message. +/// +/// It is designed to be expressable in correct JSON and JSON Schema but +/// contains no meaningful data. Previously we used enums without cases, +/// but those cannot represented as valid JSON Schema (https://github.com/CosmWasm/cosmwasm/issues/451) #[derive(Serialize, Deserialize, Clone, Debug, PartialEq)] -#[serde(rename_all = "snake_case")] -/// CustomMsg is an override of CosmosMsg::Custom to show this works and can be extended in the contract -pub enum CustomMsg { - Debug(String), - Raw(Binary), - Empty {}, -} - -impl Into> for CustomMsg { - fn into(self) -> CosmosMsg { - CosmosMsg::Custom(self) - } -} +pub struct Empty {} #[derive(Serialize, Deserialize, Clone, Debug, PartialEq)] #[serde(rename_all = "snake_case")] diff --git a/x/compute/internal/keeper/reflect_test.go b/x/compute/internal/keeper/reflect_test.go deleted file mode 100644 index 4a9866760..000000000 --- a/x/compute/internal/keeper/reflect_test.go +++ /dev/null @@ -1,447 +0,0 @@ -package keeper - -import ( - "encoding/hex" - "encoding/json" - "fmt" - "io/ioutil" - "strings" - "testing" - - "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/require" - - "github.com/cosmos/cosmos-sdk/codec" - codectypes "github.com/cosmos/cosmos-sdk/codec/types" - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - authkeeper "github.com/cosmos/cosmos-sdk/x/auth/keeper" - bankkeeper "github.com/cosmos/cosmos-sdk/x/bank/keeper" - banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" - - wasmTypes "github.com/enigmampc/SecretNetwork/go-cosmwasm/types" - v010wasmTypes "github.com/enigmampc/SecretNetwork/go-cosmwasm/types/v010" - "github.com/enigmampc/SecretNetwork/x/compute/internal/types" -) - -// MaskInitMsg is {} - -// MaskHandleMsg is used to encode handle messages -type MaskHandleMsg struct { - Reflect *reflectPayload `json:"reflect_msg,omitempty"` - Change *ownerPayload `json:"change_owner,omitempty"` -} - -type ownerPayload struct { - Owner sdk.Address `json:"owner"` -} - -type reflectPayload struct { - Msgs []v010wasmTypes.CosmosMsg `json:"msgs"` -} - -// MaskQueryMsg is used to encode query messages -type MaskQueryMsg struct { - Owner *struct{} `json:"owner,omitempty"` - ReflectCustom *Text `json:"reflect_custom,omitempty"` -} - -type Text struct { - Text string `json:"text"` -} - -type OwnerResponse struct { - Owner string `json:"owner,omitempty"` -} - -const MaskFeatures = "staking,mask" - -func TestMaskReflectContractSend(t *testing.T) { - ctx, keepers := CreateTestInput(t, false, MaskFeatures, reflectEncoders(MakeTestCodec()), nil) - accKeeper, keeper := keepers.AccountKeeper, keepers.WasmKeeper - - deposit := sdk.NewCoins(sdk.NewInt64Coin("denom", 100000)) - creator, privCreator := CreateFakeFundedAccount(ctx, accKeeper, keeper.bankKeeper, deposit) - _, _, bob := keyPubAddr() - - // upload mask code - maskCode, err := ioutil.ReadFile("./testdata/reflect.wasm") - require.NoError(t, err) - maskID, err := keeper.Create(ctx, creator, maskCode, "", "") - require.NoError(t, err) - require.Equal(t, uint64(1), maskID) - - // upload hackatom escrow code - escrowCode, err := ioutil.ReadFile("./testdata/contract.wasm") - require.NoError(t, err) - escrowID, err := keeper.Create(ctx, creator, escrowCode, "", "") - require.NoError(t, err) - require.Equal(t, uint64(2), escrowID) - - maskStart := sdk.NewCoins(sdk.NewInt64Coin("denom", 40000)) - - initMsgBz, err := testEncrypt(t, keeper, ctx, nil, maskID, []byte("{}")) - require.NoError(t, err) - - ctx = PrepareInitSignedTx(t, keeper, ctx, creator, privCreator, initMsgBz, maskID, maskStart) - - maskAddr, _, err := keeper.Instantiate(ctx, maskID, creator /* nil,*/, initMsgBz, "mask contract 2", maskStart, nil) - require.NoError(t, err) - require.NotEmpty(t, maskAddr) - - // now we set contract as verifier of an escrow - initMsg := InitMsg{ - Verifier: maskAddr, - Beneficiary: bob, - } - - initMsgBz, err = json.Marshal(initMsg) - require.NoError(t, err) - - initMsgBz, err = testEncrypt(t, keeper, ctx, nil, escrowID, initMsgBz) - require.NoError(t, err) - - escrowStart := sdk.NewCoins(sdk.NewInt64Coin("denom", 25000)) - - ctx = PrepareInitSignedTx(t, keeper, ctx, creator, privCreator, initMsgBz, escrowID, escrowStart) - - escrowAddr, _, err := keeper.Instantiate(ctx, escrowID, creator /* nil,*/, initMsgBz, "escrow contract 2", escrowStart, nil) - - require.NoError(t, err) - require.NotEmpty(t, escrowAddr) - - // let's make sure all balances make sense - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, creator, sdk.NewCoins(sdk.NewInt64Coin("denom", 35000))) // 100k - 40k - 25k - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, maskAddr, maskStart) - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, escrowAddr, escrowStart) - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, bob, nil) - - // now for the trick.... we reflect a message through the mask to call the escrow - // we also send an additional 14k tokens there. - // this should reduce the mask balance by 14k (to 26k) - // this 14k is added to the escrow, then the entire balance is sent to bob (total: 39k) - - contractCodeHash := hex.EncodeToString(keeper.GetContractHash(ctx, escrowAddr)) - // approveMsg := []byte(contractCodeHash + `{"release":{}}`) - msgs := []v010wasmTypes.CosmosMsg{{ - Wasm: &v010wasmTypes.WasmMsg{ - Execute: &v010wasmTypes.ExecuteMsg{ - ContractAddr: escrowAddr.String(), - CallbackCodeHash: contractCodeHash, - Msg: []byte(`{"release":{}}`), - Send: []wasmTypes.Coin{{ - Denom: "denom", - Amount: "14000", - }}, - }, - }, - }} - reflectSend := MaskHandleMsg{ - Reflect: &reflectPayload{ - Msgs: msgs, - }, - } - reflectSendBz, err := json.Marshal(reflectSend) - require.NoError(t, err) - - reflectSendBz, err = testEncrypt(t, keeper, ctx, maskAddr, 0, reflectSendBz) - require.NoError(t, err) - - ctx = PrepareExecSignedTx(t, keeper, ctx, creator, privCreator, reflectSendBz, maskAddr, nil) - - _, err = keeper.Execute(ctx, maskAddr, creator, reflectSendBz, nil, nil) - require.NoError(t, err) - - // did this work??? - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, creator, sdk.NewCoins(sdk.NewInt64Coin("denom", 35000))) // same as before - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, maskAddr, sdk.NewCoins(sdk.NewInt64Coin("denom", 26000))) // 40k - 14k (from send) - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, escrowAddr, sdk.Coins{}) // emptied reserved - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, bob, sdk.NewCoins(sdk.NewInt64Coin("denom", 39000))) // all escrow of 25k + 14k - -} - -func TestMaskReflectCustomMsg(t *testing.T) { - ctx, keepers := CreateTestInput(t, false, MaskFeatures, reflectEncoders(MakeTestCodec()), reflectPlugins()) - accKeeper, keeper := keepers.AccountKeeper, keepers.WasmKeeper - - deposit := sdk.NewCoins(sdk.NewInt64Coin("denom", 100000)) - creator, privCreator := CreateFakeFundedAccount(ctx, accKeeper, keeper.bankKeeper, deposit) - bob, privBob := CreateFakeFundedAccount(ctx, accKeeper, keeper.bankKeeper, deposit) - _, _, fred := keyPubAddr() - - // upload code - maskCode, err := ioutil.ReadFile("./testdata/reflect.wasm") - require.NoError(t, err) - codeID, err := keeper.Create(ctx, creator, maskCode, "", "") - require.NoError(t, err) - require.Equal(t, uint64(1), codeID) - - // creator instantiates a contract and gives it tokens - initMsgBz, err := testEncrypt(t, keeper, ctx, nil, codeID, []byte("{}")) - require.NoError(t, err) - contractStart := sdk.NewCoins(sdk.NewInt64Coin("denom", 40000)) - ctx = PrepareInitSignedTx(t, keeper, ctx, creator, privCreator, initMsgBz, codeID, contractStart) - contractAddr, _, err := keeper.Instantiate(ctx, codeID, creator /* nil,*/, initMsgBz, "mask contract 1", contractStart, nil) - require.NoError(t, err) - require.NotEmpty(t, contractAddr) - - // set owner to bob - transfer := MaskHandleMsg{ - Change: &ownerPayload{ - Owner: bob, - }, - } - transferBz, err := json.Marshal(transfer) - require.NoError(t, err) - transferBz, err = testEncrypt(t, keeper, ctx, contractAddr, 0, transferBz) - require.NoError(t, err) - ctx = PrepareExecSignedTx(t, keeper, ctx, creator, privCreator, transferBz, contractAddr, nil) - _, err = keeper.Execute(ctx, contractAddr, creator, transferBz, nil, nil) - require.NoError(t, err) - - // check some account values - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, contractAddr, contractStart) - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, bob, deposit) - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, fred, nil) - - // bob can send contract's tokens to fred (using SendMsg) - msgs := []v010wasmTypes.CosmosMsg{{ - Bank: &v010wasmTypes.BankMsg{ - Send: &v010wasmTypes.SendMsg{ - FromAddress: contractAddr.String(), - ToAddress: fred.String(), - Amount: []wasmTypes.Coin{{ - Denom: "denom", - Amount: "15000", - }}, - }, - }, - }} - reflectSend := MaskHandleMsg{ - Reflect: &reflectPayload{ - Msgs: msgs, - }, - } - reflectSendBz, err := json.Marshal(reflectSend) - require.NoError(t, err) - reflectSendBz, err = testEncrypt(t, keeper, ctx, contractAddr, 0, reflectSendBz) - require.NoError(t, err) - ctx = PrepareExecSignedTx(t, keeper, ctx, bob, privBob, reflectSendBz, contractAddr, nil) - _, err = keeper.Execute(ctx, contractAddr, bob, reflectSendBz, nil, nil) - require.NoError(t, err) - - // fred got coins - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, fred, sdk.NewCoins(sdk.NewInt64Coin("denom", 15000))) - // contract lost them - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, contractAddr, sdk.NewCoins(sdk.NewInt64Coin("denom", 25000))) - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, bob, deposit) - - // construct an opaque message - var sdkSendMsg sdk.Msg = &banktypes.MsgSend{ - FromAddress: contractAddr.String(), - ToAddress: fred.String(), - Amount: sdk.NewCoins(sdk.NewInt64Coin("denom", 23000)), - } - opaque, err := toReflectRawMsg(keeper.cdc, sdkSendMsg) - require.NoError(t, err) - reflectOpaque := MaskHandleMsg{ - Reflect: &reflectPayload{ - Msgs: []v010wasmTypes.CosmosMsg{opaque}, - }, - } - reflectOpaqueBz, err := json.Marshal(reflectOpaque) - require.NoError(t, err) - reflectOpaqueBz, err = testEncrypt(t, keeper, ctx, contractAddr, 0, reflectOpaqueBz) - require.NoError(t, err) - - ctx = PrepareExecSignedTx(t, keeper, ctx, bob, privBob, reflectOpaqueBz, contractAddr, nil) - _, err = keeper.Execute(ctx, contractAddr, bob, reflectOpaqueBz, nil, nil) - require.NoError(t, err) - - // fred got more coins - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, fred, sdk.NewCoins(sdk.NewInt64Coin("denom", 38000))) - // contract lost them - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, contractAddr, sdk.NewCoins(sdk.NewInt64Coin("denom", 2000))) - checkAccount(t, ctx, accKeeper, keeper.bankKeeper, bob, deposit) -} - -func TestMaskReflectCustomQuery(t *testing.T) { - ctx, keepers := CreateTestInput(t, false, MaskFeatures, reflectEncoders(MakeTestCodec()), reflectPlugins()) - accKeeper, keeper := keepers.AccountKeeper, keepers.WasmKeeper - - deposit := sdk.NewCoins(sdk.NewInt64Coin("denom", 100000)) - creator, privCreator := CreateFakeFundedAccount(ctx, accKeeper, keeper.bankKeeper, deposit) - - // upload code - maskCode, err := ioutil.ReadFile("./testdata/reflect.wasm") - require.NoError(t, err) - codeID, err := keeper.Create(ctx, creator, maskCode, "", "") - require.NoError(t, err) - require.Equal(t, uint64(1), codeID) - - // creator instantiates a contract and gives it tokens - initMsgBz, err := testEncrypt(t, keeper, ctx, nil, codeID, []byte("{}")) - require.NoError(t, err) - contractStart := sdk.NewCoins(sdk.NewInt64Coin("denom", 40000)) - ctx = PrepareInitSignedTx(t, keeper, ctx, creator, privCreator, initMsgBz, codeID, contractStart) - contractAddr, _, err := keeper.Instantiate(ctx, codeID, creator /* nil,*/, initMsgBz, "mask contract 1", contractStart, nil) - require.NoError(t, err) - require.NotEmpty(t, contractAddr) - - // let's perform a normal query of state - ownerQuery := MaskQueryMsg{ - Owner: &struct{}{}, - } - ownerQueryBz, err := json.Marshal(ownerQuery) - require.NoError(t, err) - - ownerRes, qErr := queryHelper(t, keeper, ctx, contractAddr, string(ownerQueryBz), true, false, defaultGasForTests) - require.Empty(t, qErr) - var res OwnerResponse - err = json.Unmarshal([]byte(ownerRes), &res) - require.NoError(t, err) - assert.Equal(t, res.Owner, creator.String()) - - // and now making use of the custom querier callbacks - customQuery := MaskQueryMsg{ - ReflectCustom: &Text{ - Text: "all Caps noW", - }, - } - customQueryBz, err := json.Marshal(customQuery) - require.NoError(t, err) - - custom, qErr := queryHelper(t, keeper, ctx, contractAddr, string(customQueryBz), true, false, defaultGasForTests) - require.Empty(t, qErr) - - var resp customQueryResponse - err = json.Unmarshal([]byte(custom), &resp) - require.NoError(t, err) - assert.Equal(t, resp.Msg, "ALL CAPS NOW") -} - -func checkAccount(t *testing.T, ctx sdk.Context, accKeeper authkeeper.AccountKeeper, bankKeeper bankkeeper.Keeper, addr sdk.AccAddress, expected sdk.Coins) { - acct := accKeeper.GetAccount(ctx, addr) - if expected == nil { - assert.Nil(t, acct) - } else { - assert.NotNil(t, acct) - coins := bankKeeper.GetAllBalances(ctx, acct.GetAddress()) - if expected.Empty() { - // there is confusion between nil and empty slice... let's just treat them the same - assert.True(t, coins.Empty()) - } else { - assert.Equal(t, coins, expected) - } - } -} - -/**** Code to support custom messages *****/ - -type reflectCustomMsg struct { - Debug string `json:"debug,omitempty"` - Raw []byte `json:"raw,omitempty"` -} - -// toReflectRawMsg encodes an sdk msg using any type with json encoding. -// Then wraps it as an opaque message -func toReflectRawMsg(cdc codec.BinaryCodec, msg sdk.Msg) (v010wasmTypes.CosmosMsg, error) { - any, err := codectypes.NewAnyWithValue(msg) - if err != nil { - return v010wasmTypes.CosmosMsg{}, err - } - rawBz, err := cdc.Marshal(any) - if err != nil { - return v010wasmTypes.CosmosMsg{}, sdkerrors.Wrap(sdkerrors.ErrJSONMarshal, err.Error()) - } - customMsg, err := json.Marshal(reflectCustomMsg{ - Raw: rawBz, - }) - res := v010wasmTypes.CosmosMsg{ - Custom: customMsg, - } - return res, nil -} - -// reflectEncoders needs to be registered in test setup to handle custom message callbacks -func reflectEncoders(cdc codec.Codec) *MessageEncoders { - return &MessageEncoders{ - Custom: fromReflectRawMsg(cdc), - } -} - -// fromReflectRawMsg decodes msg.Data to an sdk.Msg using proto Any and json encoding. -// this needs to be registered on the Encoders -func fromReflectRawMsg(cdc codec.Codec) CustomEncoder { - return func(_sender sdk.AccAddress, msg json.RawMessage) ([]sdk.Msg, error) { - var custom reflectCustomMsg - err := json.Unmarshal(msg, &custom) - if err != nil { - return nil, sdkerrors.Wrap(sdkerrors.ErrJSONUnmarshal, err.Error()) - } - if custom.Raw != nil { - var any codectypes.Any - if err := cdc.Unmarshal(custom.Raw, &any); err != nil { - return nil, sdkerrors.Wrap(sdkerrors.ErrJSONUnmarshal, err.Error()) - } - var msg sdk.Msg - if err := cdc.UnpackAny(&any, &msg); err != nil { - return nil, err - } - return []sdk.Msg{msg}, nil - } - if custom.Debug != "" { - return nil, sdkerrors.Wrapf(types.ErrInvalidMsg, "Custom Debug: %s", custom.Debug) - } - return nil, sdkerrors.Wrap(types.ErrInvalidMsg, "Unknown Custom message variant") - } -} - -type reflectCustomQuery struct { - Ping *struct{} `json:"ping,omitempty"` - Capital *Text `json:"capital,omitempty"` -} - -// this is from the go code back to the contract (capitalized or ping) -type customQueryResponse struct { - Msg string `json:"msg"` -} - -// these are the return values from contract -> go depending on type of query -type ownerResponse struct { - Owner string `json:"owner"` -} - -type capitalizedResponse struct { - Text string `json:"text"` -} - -type chainResponse struct { - Data []byte `json:"data"` -} - -// reflectPlugins needs to be registered in test setup to handle custom query callbacks -func reflectPlugins() *QueryPlugins { - return &QueryPlugins{ - Custom: performCustomQuery, - } -} - -func performCustomQuery(_ sdk.Context, request json.RawMessage) ([]byte, error) { - - var custom reflectCustomQuery - err := json.Unmarshal(request, &custom) - if err != nil { - return nil, sdkerrors.Wrap(sdkerrors.ErrJSONUnmarshal, err.Error()) - } - fmt.Println(fmt.Sprintf("0x%02x", request)) - if custom.Capital != nil { - msg := strings.ToUpper(custom.Capital.Text) - return json.Marshal(customQueryResponse{Msg: msg}) - } - if custom.Ping != nil { - return json.Marshal(customQueryResponse{Msg: "pong"}) - } - - return nil, sdkerrors.Wrap(types.ErrInvalidMsg, "Unknown Custom query variant") -} diff --git a/x/compute/internal/keeper/secret_contracts_test.go b/x/compute/internal/keeper/secret_contracts_test.go index b1b4e1265..6042056f4 100644 --- a/x/compute/internal/keeper/secret_contracts_test.go +++ b/x/compute/internal/keeper/secret_contracts_test.go @@ -3562,6 +3562,37 @@ func TestBankMsgBurn(t *testing.T) { }) } +func TestCosmosMsgCustom(t *testing.T) { + for _, contract := range testContracts { + t.Run(contract.CosmWasmVersion, func(t *testing.T) { + for _, callType := range []string{"init", "exec"} { + t.Run(callType, func(t *testing.T) { + ctx, keeper, codeID, _, walletA, privKeyA, _, _ := setupTest(t, contract.WasmFilePath, sdk.NewCoins()) + + var err cosmwasm.StdError + var contractAddress sdk.AccAddress + + if callType == "init" { + contractAddress, _, err = initHelperImpl(t, keeper, ctx, codeID, walletA, privKeyA, fmt.Sprintf(`{"cosmos_msg_custom":{}}`), false, contract.IsCosmWasmV1, defaultGasForTests, -1, sdk.NewCoins()) + } else { + contractAddress, _, err = initHelperImpl(t, keeper, ctx, codeID, walletA, privKeyA, `{"nop":{}}`, false, contract.IsCosmWasmV1, defaultGasForTests, -1, sdk.NewCoins()) + + _, _, _, err = execHelper(t, keeper, ctx, contractAddress, walletA, privKeyA, fmt.Sprintf(`{"cosmos_msg_custom":{}}`), false, contract.IsCosmWasmV1, math.MaxUint64, 0) + } + + require.NotEmpty(t, err) + // if contract.IsCosmWasmV1 { + require.Contains(t, err.Error(), "Custom variant not supported: invalid CosmosMsg from the contract") + // } else { + // require.Equal(t, err.Error(), "Custom variant not supported: invalid CosmosMsg from the contract") + + // } + }) + } + }) + } +} + func TestV1ReplyOnMultipleSubmessages(t *testing.T) { ctx, keeper, codeID, _, walletA, privKeyA, _, _ := setupTest(t, "./testdata/v1-sanity-contract/contract.wasm", sdk.NewCoins()) diff --git a/x/compute/internal/keeper/staking_test.go b/x/compute/internal/keeper/staking_test.go index 964770d65..fa0bf4361 100644 --- a/x/compute/internal/keeper/staking_test.go +++ b/x/compute/internal/keeper/staking_test.go @@ -48,6 +48,10 @@ type transferPayload struct { Amount string `json:"amount"` } +type ownerPayload struct { + Owner sdk.Address `json:"owner"` +} + type unbondPayload struct { // uint128 encoded as string Amount string `json:"amount"` @@ -243,6 +247,22 @@ func initializeStaking(t *testing.T) initInfo { } } +func checkAccount(t *testing.T, ctx sdk.Context, accKeeper authkeeper.AccountKeeper, bankKeeper bankkeeper.Keeper, addr sdk.AccAddress, expected sdk.Coins) { + acct := accKeeper.GetAccount(ctx, addr) + if expected == nil { + assert.Nil(t, acct) + } else { + assert.NotNil(t, acct) + coins := bankKeeper.GetAllBalances(ctx, acct.GetAddress()) + if expected.Empty() { + // there is confusion between nil and empty slice... let's just treat them the same + assert.True(t, coins.Empty()) + } else { + assert.Equal(t, coins, expected) + } + } +} + func TestBonding(t *testing.T) { initInfo := initializeStaking(t) defer initInfo.cleanup() diff --git a/x/compute/internal/keeper/testdata/test-contract/src/contract.rs b/x/compute/internal/keeper/testdata/test-contract/src/contract.rs index d88404da5..91f14f27c 100644 --- a/x/compute/internal/keeper/testdata/test-contract/src/contract.rs +++ b/x/compute/internal/keeper/testdata/test-contract/src/contract.rs @@ -1,7 +1,7 @@ use cosmwasm_storage::{PrefixedStorage, ReadonlySingleton, Singleton}; use cosmwasm_std::{ - log, to_binary, Api, BankMsg, Binary, Coin, CosmosMsg, Env, Extern, HandleResponse, + log, to_binary, Api, BankMsg, Binary, Coin, CosmosMsg, Empty, Env, Extern, HandleResponse, HandleResult, HumanAddr, InitResponse, InitResult, Querier, QueryRequest, QueryResult, ReadonlyStorage, StdError, StdResult, Storage, Uint128, WasmMsg, WasmQuery, }; @@ -78,6 +78,7 @@ pub enum InitMsg { to: HumanAddr, from: Option, }, + CosmosMsgCustom {}, } #[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)] @@ -265,6 +266,7 @@ pub enum HandleMsg { IncrementFromV1 { addition: u64, }, + CosmosMsgCustom {}, } #[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)] @@ -431,6 +433,10 @@ pub fn init( })], log: vec![], }), + InitMsg::CosmosMsgCustom {} => Ok(InitResponse { + messages: vec![CosmosMsg::Custom(Empty {})], + log: vec![], + }), } } @@ -653,6 +659,11 @@ pub fn handle( log: vec![], data: None, }), + HandleMsg::CosmosMsgCustom {} => Ok(HandleResponse { + messages: vec![CosmosMsg::Custom(Empty {})], + log: vec![], + data: None, + }), HandleMsg::SendFundsToInitCallback { amount, denom, diff --git a/x/compute/internal/keeper/testdata/v1-sanity-contract/src/contract.rs b/x/compute/internal/keeper/testdata/v1-sanity-contract/src/contract.rs index 4fa193380..f609b2035 100644 --- a/x/compute/internal/keeper/testdata/v1-sanity-contract/src/contract.rs +++ b/x/compute/internal/keeper/testdata/v1-sanity-contract/src/contract.rs @@ -3,7 +3,7 @@ use mem::MaybeUninit; use std::{mem, thread}; use cosmwasm_std::{ - attr, coins, entry_point, to_binary, BankMsg, Binary, CosmosMsg, Deps, DepsMut, Env, + attr, coins, entry_point, to_binary, BankMsg, Binary, CosmosMsg, Deps, DepsMut, Empty, Env, MessageInfo, QueryRequest, Reply, ReplyOn, Response, StdError, StdResult, Storage, SubMsg, SubMsgResult, WasmMsg, WasmQuery, }; @@ -153,6 +153,9 @@ pub fn instantiate( InstantiateMsg::BankMsgBurn { amount } => { Ok(Response::new().add_message(CosmosMsg::Bank(BankMsg::Burn { amount }))) } + InstantiateMsg::CosmosMsgCustom {} => { + Ok(Response::new().add_message(CosmosMsg::Custom(Empty {}))) + } } } @@ -552,6 +555,9 @@ pub fn execute(deps: DepsMut, env: Env, info: MessageInfo, msg: ExecuteMsg) -> S ExecuteMsg::BankMsgBurn { amount } => { Ok(Response::new().add_message(CosmosMsg::Bank(BankMsg::Burn { amount }))) } + ExecuteMsg::CosmosMsgCustom {} => { + Ok(Response::new().add_message(CosmosMsg::Custom(Empty {}))) + } } } diff --git a/x/compute/internal/keeper/testdata/v1-sanity-contract/src/msg.rs b/x/compute/internal/keeper/testdata/v1-sanity-contract/src/msg.rs index 5b84876d0..2e8fc7f76 100644 --- a/x/compute/internal/keeper/testdata/v1-sanity-contract/src/msg.rs +++ b/x/compute/internal/keeper/testdata/v1-sanity-contract/src/msg.rs @@ -66,6 +66,7 @@ pub enum InstantiateMsg { BankMsgBurn { amount: Vec, }, + CosmosMsgCustom {}, } #[derive(Serialize, Deserialize, Clone, Debug, PartialEq)] @@ -272,6 +273,7 @@ pub enum ExecuteMsg { BankMsgBurn { amount: Vec, }, + CosmosMsgCustom {}, } #[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]