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

IBC + Stargate + wasmd 0.28 #1101

Merged
merged 109 commits into from
Aug 31, 2022
Merged
Changes from 1 commit
Commits
Show all changes
109 commits
Select commit Hold shift + click to select a range
b7c439a
WIP: Start to implement IBC receive hooks
assafmo Jul 14, 2022
f769b83
CosmWasm v1 IBC OnOpenChannel
assafmo Jul 19, 2022
26413fd
Parse IBC results in go-cosmwasm
assafmo Jul 25, 2022
d3cda94
Refactor IBC contract calls, lots of shared code
assafmo Jul 25, 2022
bd46776
IBC keeper
assafmo Jul 25, 2022
1277f83
Keeper OnRecvPacket
assafmo Jul 26, 2022
1d80153
WIP: IBC on the enclave side
assafmo Jul 26, 2022
0e412a9
Remove old CosmWasm remnants
assafmo Jul 27, 2022
a60a2cb
secret-contract-optimizer v1.0.8
assafmo Aug 2, 2022
a4a2b1c
Some IBC progress
assafmo Aug 2, 2022
88827c0
WIP: Start to implement IBC receive hooks
assafmo Jul 14, 2022
eb9f617
CosmWasm v1 IBC OnOpenChannel
assafmo Jul 19, 2022
a3e703a
Parse IBC results in go-cosmwasm
assafmo Jul 25, 2022
7929c34
Refactor IBC contract calls, lots of shared code
assafmo Jul 25, 2022
4604b60
IBC keeper
assafmo Jul 25, 2022
73b3e3a
Keeper OnRecvPacket
assafmo Jul 26, 2022
e4ffb9c
WIP: IBC on the enclave side
assafmo Jul 26, 2022
5bee32a
Remove old CosmWasm remnants
assafmo Jul 27, 2022
ee0a8e0
secret-contract-optimizer v1.0.8
assafmo Aug 2, 2022
a921247
Some IBC progress
assafmo Aug 2, 2022
2e60c05
Merge branch 'cw-1-ibc-receive-hooks' of github.com:scrtlabs/SecretNe…
assafmo Aug 11, 2022
d7ee442
Revert a stupid change
assafmo Aug 11, 2022
5c22a98
Decrypt only data from IBC
Aug 11, 2022
752c337
Fix compilation
Aug 11, 2022
05bad14
Parse every IBC submessage
Aug 14, 2022
92772fe
Make IBC handling nicer
Aug 15, 2022
084849d
Encrypt IBC outputs for encrypted inputs
Aug 16, 2022
ede75fa
Finalize output in a function
Aug 16, 2022
86501b0
Finalize plaintext messages
Aug 16, 2022
cc236c7
Support plaintext execute messages
Aug 17, 2022
190a6df
Merge branch 'cosmwasm-v1' into cw-1-ibc-receive-hooks
Aug 17, 2022
28a412a
Correct errors for replies
Aug 17, 2022
214101a
Wire up StargateQuery
assafmo Aug 17, 2022
94b816a
parse the message correctly
Aug 18, 2022
18abe47
Create IBC tests suite
Aug 19, 2022
2152373
Fix compilation
Aug 20, 2022
a359a8e
Fix debugger for go-tests
assafmo Aug 22, 2022
6061640
Add integration tests, enable stargate feature
assafmo Aug 22, 2022
84174bf
Add integration tests to the CI
assafmo Aug 22, 2022
8755a43
Make StargateMsg work (with tests)
assafmo Aug 22, 2022
40c02fe
Implement all missing v1 QueryPlugins
assafmo Aug 22, 2022
9f55427
Continue fixing the v1 querier
assafmo Aug 22, 2022
8b5ff3d
Fix StargateQuery paths
assafmo Aug 22, 2022
f512b1c
Fix possible null dref in tests
Aug 22, 2022
68b8a00
Fix second optional null dref
Aug 22, 2022
2adda1d
Remove unused code
assafmo Aug 23, 2022
dad0b26
LocalSecret: expose LOG_LEVEL as env var
assafmo Aug 23, 2022
ff4250a
StargateQuery test
assafmo Aug 23, 2022
be350cc
Implement all queries for v1 integration tests contract
assafmo Aug 23, 2022
4873d34
Refactored v010/v1 env parsing in the enclave to make it a little mor…
Cashmaney Aug 23, 2022
32afa88
Merge pull request #1083 from scrtlabs/lior-fix-null-dref2
assafmo Aug 23, 2022
0725def
Integration tests: finish implementing v1 contract query
assafmo Aug 23, 2022
3849efb
Verify EIP191 inside the enclave
assafmo Aug 23, 2022
9f333d3
Increase `make go-tests` timeout 20m->40m
assafmo Aug 23, 2022
38c225a
Fix go tests for StargateMsg (Add compute MsgServer)
assafmo Aug 23, 2022
6585e96
Fix Integration-Tests CI
assafmo Aug 23, 2022
bd1f396
Clippy
assafmo Aug 23, 2022
a58ecae
Clippy
assafmo Aug 23, 2022
aa542b2
Fix CI Integration-Tests?
assafmo Aug 23, 2022
0ec3497
Parse protos on reply to extract reply params
assafmo Aug 24, 2022
10dd4e8
More refactoring
Cashmaney Aug 24, 2022
38d7c51
Compute MsgServer refactor
assafmo Aug 24, 2022
c87d153
Fix the majority of linting problems
Aug 24, 2022
c23c6dc
Clippy must be made happy
Cashmaney Aug 24, 2022
c77d2c5
Merge pull request #1093 from scrtlabs/lior-fix-warnings
assafmo Aug 24, 2022
c397862
Use v0.10 MsgRouter for MsgExec & MsgInit
assafmo Aug 24, 2022
eae764e
Try debugging Integration-Tests CI
assafmo Aug 24, 2022
2dbedca
Try debugging Integration-Tests CI
assafmo Aug 24, 2022
9157ddf
CI Go-Tests increase timeout 20m->40m
assafmo Aug 24, 2022
1973545
Merge branch 'cosmwasm-v1' into stargate-query
assafmo Aug 24, 2022
898e375
Fix bug from previous merge
assafmo Aug 24, 2022
229bc81
v1 sanity contract: make ExecuteMsg::GasMeter more efficient because …
assafmo Aug 24, 2022
76b2562
rustfmt v1 sanity contract
assafmo Aug 24, 2022
bb335e0
Fix TestCallbackSanity for wasmd v0.28
assafmo Aug 24, 2022
5185c9a
Fix all go-test that relied on events being ordered
assafmo Aug 24, 2022
0d91925
Fix relay
Aug 28, 2022
33ddf38
Merge branch 'stargate-query' into eshel-ibc
Aug 28, 2022
e83075d
Merge branch 'env-parsing-refactor' into eshel-ibc
Cashmaney Aug 28, 2022
66e3ed2
Merged env refactor changes to latest IBC branch
Cashmaney Aug 28, 2022
22a04de
New contract for ibc tests
Aug 28, 2022
16455f0
New ibc test
Aug 28, 2022
488cf00
Fix ibc
Aug 28, 2022
171e769
Now channel open works
Aug 28, 2022
3648c61
Merge pull request #1095 from scrtlabs/eshel-ibc-env-refactor
Cashmaney Aug 28, 2022
9f70972
IBC Channel Connect WIP
Aug 28, 2022
817d878
Merge branch 'cw-1-ibc-receive-hooks' into eshel-ibc
Aug 28, 2022
5833c68
Fix compilation
Aug 28, 2022
c29e8a6
fixing compilation errors on contract_operations and io.rs
eshelB Aug 28, 2022
4c43604
Channel connect is now workins (Including submessages)
Aug 28, 2022
4058c9e
Channel close tests
Aug 28, 2022
c32ba0b
Merge remote-tracking branch 'origin/cw-1-ibc-receive-hooks' into esh…
Aug 29, 2022
a0b0bba
adding util file that lets me see a transaction more cleanly: convert…
eshelB Aug 29, 2022
b49d664
IBC packet receive tests and bag fixes
Aug 29, 2022
498d961
Merge pull request #1096 from scrtlabs/lior-ibc-tests
liorbond Aug 29, 2022
7d0f85a
IBC ack and timeout should be encrypted
Aug 29, 2022
b058d3c
IBC ack tests
Aug 29, 2022
5b97e6f
Encrypt the output of every reply (Should be changed)
Aug 30, 2022
8152de2
adding util file that lets me see a transaction more cleanly: convert…
eshelB Aug 29, 2022
7d65399
Encrypt plaintext replies only if the original message was encrypted
Aug 30, 2022
b7ab07f
Merge pull request #1097 from scrtlabs/lior-ibc-tests
liorbond Aug 30, 2022
dfd161b
Merge branch 'eshel-ibc' of github.com:scrtlabs/SecretNetwork into es…
eshelB Aug 30, 2022
add2302
Fix gtests
Aug 30, 2022
50551f0
Merge pull request #1098 from scrtlabs/lior-ibc-tests
liorbond Aug 30, 2022
5dfee90
added the v010 integratoin-test for bankMsgSend
eshelB Aug 30, 2022
819352f
Merge branch 'eshel-ibc' of github.com:scrtlabs/SecretNetwork into es…
eshelB Aug 30, 2022
07d51f4
Commented code
Aug 30, 2022
2888b8a
Fix test setup
Cashmaney Aug 30, 2022
b9312c1
Log with "code_id" when storing contract
Aug 30, 2022
30a4318
Merge pull request #1099 from scrtlabs/lior-ibc-tests
liorbond Aug 30, 2022
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
Prev Previous commit
Next Next commit
Fix second optional null dref
Lior Bondarevski committed Aug 22, 2022
commit 68b8a00cf0b0f630c0048ab9064d4c90b109153c
12 changes: 9 additions & 3 deletions x/compute/internal/keeper/ibc_test.go
Original file line number Diff line number Diff line change
@@ -180,7 +180,9 @@ func ibcPacketReceiveHelper(
internalPacket := packet

if shouldEncryptMsg {
hashStr := hex.EncodeToString(keeper.GetContractHash(ctx, contractAddr))
contractHash, err := keeper.GetContractHash(ctx, contractAddr)
require.NoError(t, err)
hashStr := hex.EncodeToString(contractHash)

msg := types.SecretMsg{
CodeHash: []byte(hashStr),
@@ -232,7 +234,9 @@ func ibcPacketAckHelper(
var nonce []byte

if shouldEncryptMsg {
hashStr := hex.EncodeToString(keeper.GetContractHash(ctx, contractAddr))
contractHash, err := keeper.GetContractHash(ctx, contractAddr)
require.NoError(t, err)
hashStr := hex.EncodeToString(contractHash)

msg := types.SecretMsg{
CodeHash: []byte(hashStr),
@@ -287,7 +291,9 @@ func ibcPacketTimeoutHelper(
var nonce []byte

if shouldEncryptMsg {
hashStr := hex.EncodeToString(keeper.GetContractHash(ctx, contractAddr))
contractHash, err := keeper.GetContractHash(ctx, contractAddr)
require.NoError(t, err)
hashStr := hex.EncodeToString(contractHash)

msg := types.SecretMsg{
CodeHash: []byte(hashStr),
15 changes: 9 additions & 6 deletions x/compute/internal/keeper/keeper.go
Original file line number Diff line number Diff line change
@@ -716,14 +716,17 @@ func (k Keeper) GetContractHash(ctx sdk.Context, contractAddress sdk.AccAddress)
contractInfo := k.GetContractInfo(ctx, contractAddress)

if contractInfo == nil {
return nil, fmt.Errorf("failed to contract info for the following address: %s", contractAddress.String())
return nil, fmt.Errorf("failed to get contract info for the following address: %s", contractAddress.String())
}

codeId := contractInfo.CodeID

hash := k.GetCodeInfo(ctx, codeId).CodeHash
codeInfo, err := k.GetCodeInfo(ctx, codeId)
if err != nil {
return nil, err
}

return hash, nil
return codeInfo.CodeHash, nil
}

func (k Keeper) GetContractInfo(ctx sdk.Context, contractAddress sdk.AccAddress) *types.ContractInfo {
@@ -825,15 +828,15 @@ func (k Keeper) fixContractState(ctx sdk.Context, contractAddress sdk.AccAddress
return nil
}

func (k Keeper) GetCodeInfo(ctx sdk.Context, codeID uint64) *types.CodeInfo {
func (k Keeper) GetCodeInfo(ctx sdk.Context, codeID uint64) (types.CodeInfo, error) {
store := ctx.KVStore(k.storeKey)
var codeInfo types.CodeInfo
codeInfoBz := store.Get(types.GetCodeKey(codeID))
if codeInfoBz == nil {
return nil
return types.CodeInfo{}, fmt.Errorf("failed to get code info for code id %d", codeID)
}
k.cdc.MustUnmarshal(codeInfoBz, &codeInfo)
return &codeInfo
return codeInfo, nil
}

func (k Keeper) containsCodeInfo(ctx sdk.Context, codeID uint64) bool {
119 changes: 14 additions & 105 deletions x/compute/internal/keeper/keeper_test.go
Original file line number Diff line number Diff line change
@@ -89,104 +89,6 @@ func TestCreate(t *testing.T) {
require.Equal(t, wasmCode, storedCode)
}

/*
func TestCreateStoresInstantiatePermission(t *testing.T) {
wasmCode, err := ioutil.ReadFile("./testdata/contract.wasm")
require.NoError(t, err)
var (
deposit = sdk.NewCoins(sdk.NewInt64Coin("denom", 100000))
myAddr = bytes.Repeat([]byte{1}, sdk.AddrLen)
)

specs := map[string]struct {
srcPermission types.AccessType
expInstConf types.AccessConfig
}{
"default": {
srcPermission: types.DefaultParams().DefaultInstantiatePermission,
expInstConf: types.AllowEverybody,
},
"everybody": {
srcPermission: types.Everybody,
expInstConf: types.AllowEverybody,
},
"nobody": {
srcPermission: types.Nobody,
expInstConf: types.AllowNobody,
},
"onlyAddress with matching address": {
srcPermission: types.OnlyAddress,
expInstConf: types.AccessConfig{Type: types.OnlyAddress, Address: myAddr},
},
}
for msg, spec := range specs {
t.Run(msg, func(t *testing.T) {
tempDir, err := ioutil.TempDir("", "wasm")
require.NoError(t, err)
defer os.RemoveAll(tempDir)

ctx, keepers := CreateTestInput(t, false, tempDir, SupportedFeatures, nil, nil)
accKeeper, keeper := keepers.AccountKeeper, keepers.WasmKeeper
fundAccounts(ctx, accKeeper, myAddr, deposit)

codeID, err := keeper.Create(ctx, myAddr, wasmCode, "https://github.com/CosmWasm/wasmd/blob/master/x/wasm/testdata/escrow.wasm", "any/builder:tag")
require.NoError(t, err)

codeInfo := keeper.GetCodeInfo(ctx, codeID)
require.NotNil(t, codeInfo)
assert.True(t, spec.expInstConf.Equals(codeInfo.InstantiateConfig), "got %#v", codeInfo.InstantiateConfig)
})
}
}

func TestCreateWithParamPermissions(t *testing.T) {
tempDir, err := ioutil.TempDir("", "wasm")
require.NoError(t, err)
defer os.RemoveAll(tempDir)
ctx, keepers := CreateTestInput(t, false, tempDir, SupportedFeatures, nil, nil)
accKeeper, keeper := keepers.AccountKeeper, keepers.WasmKeeper

deposit := sdk.NewCoins(sdk.NewInt64Coin("denom", 100000))
creator := CreateFakeFundedAccount(ctx, accKeeper, deposit)
otherAddr := CreateFakeFundedAccount(ctx, accKeeper, deposit)

wasmCode, err := ioutil.ReadFile("./testdata/contract.wasm")
require.NoError(t, err)

specs := map[string]struct {
srcPermission types.AccessConfig
expError *sdkerrors.Error
}{
"default": {
srcPermission: types.DefaultUploadAccess,
},
"everybody": {
srcPermission: types.AllowEverybody,
},
"nobody": {
srcPermission: types.AllowNobody,
expError: sdkerrors.ErrUnauthorized,
},
"onlyAddress with matching address": {
srcPermission: types.OnlyAddress.With(creator),
},
"onlyAddress with non matching address": {
srcPermission: types.OnlyAddress.With(otherAddr),
expError: sdkerrors.ErrUnauthorized,
},
}
for msg, spec := range specs {
t.Run(msg, func(t *testing.T) {
_, err := keeper.Create(ctx, creator, wasmCode, "https://github.com/CosmWasm/wasmd/blob/master/x/wasm/testdata/escrow.wasm", "any/builder:tag")
require.True(t, spec.expError.Is(err), err)
if spec.expError != nil {
return
}
})
}
}
*/

func TestCreateDuplicate(t *testing.T) {
encodingConfig := MakeEncodingConfig()
var transferPortSource types.ICS20TransferPortSource
@@ -340,7 +242,10 @@ func TestInstantiate(t *testing.T) {
initMsgBz, err := json.Marshal(initMsg)
require.NoError(t, err)

key := keeper.GetCodeInfo(ctx, contractID).CodeHash
codeInfo, err := keeper.GetCodeInfo(ctx, contractID)
require.NoError(t, err)

key := codeInfo.CodeHash

msg := types.SecretMsg{
CodeHash: []byte(hex.EncodeToString(key)),
@@ -595,8 +500,10 @@ func TestExecute(t *testing.T) {
}
initMsgBz, err := json.Marshal(initMsg)

key := keeper.GetCodeInfo(ctx, contractID).CodeHash
// keyStr := hex.EncodeToString(key)
codeInfo, err := keeper.GetCodeInfo(ctx, contractID)
require.NoError(t, err)

key := codeInfo.CodeHash

msg := types.SecretMsg{
CodeHash: []byte(hex.EncodeToString(key)),
@@ -651,8 +558,7 @@ func TestExecute(t *testing.T) {

initMsgBz = []byte(`{"release":{}}`)

key = keeper.GetCodeInfo(ctx, contractID).CodeHash
// keyStr := hex.EncodeToString(key)
require.NoError(t, err)

msg = types.SecretMsg{
CodeHash: []byte(hex.EncodeToString(key)),
@@ -880,7 +786,10 @@ func TestExecuteWithCpuLoop(t *testing.T) {
initMsgBz, err := json.Marshal(initMsg)
require.NoError(t, err)

hash := keeper.GetCodeInfo(ctx, contractID).CodeHash
codeInfo, err := keeper.GetCodeInfo(ctx, contractID)
require.NoError(t, err)

hash := codeInfo.CodeHash

msg := types.SecretMsg{
CodeHash: []byte(hex.EncodeToString(hash)),
@@ -918,7 +827,7 @@ func TestExecuteWithCpuLoop(t *testing.T) {

codeHash, err := keeper.GetContractHash(ctx, addr)
require.NoError(t, err)

codeHashStr := hex.EncodeToString(codeHash)

msg2 := types.SecretMsg{
46 changes: 14 additions & 32 deletions x/compute/internal/keeper/querier.go
Original file line number Diff line number Diff line change
@@ -233,17 +233,18 @@ func queryCode(ctx sdk.Context, codeID uint64, keeper Keeper) (*types.QueryCodeR
if codeID == 0 {
return nil, nil
}
res := keeper.GetCodeInfo(ctx, codeID)
if res == nil {
// nil, nil leads to 404 in rest handler

codeInfo, err := keeper.GetCodeInfo(ctx, codeID)
if err != nil {
return nil, nil
}

info := types.CodeInfoResponse{
CodeID: codeID,
Creator: res.Creator,
DataHash: res.CodeHash,
Source: res.Source,
Builder: res.Builder,
Creator: codeInfo.Creator,
DataHash: codeInfo.CodeHash,
Source: codeInfo.Source,
Builder: codeInfo.Builder,
}

code, err := keeper.GetByteCode(ctx, codeID)
@@ -269,30 +270,6 @@ func queryCodeList(ctx sdk.Context, keeper Keeper) ([]types.CodeInfoResponse, er
return info, nil
}

/*
func queryContractHistory(ctx sdk.Context, bech string, keeper Keeper) ([]byte, error) {
contractAddr, err := sdk.AccAddressFromBech32(bech)
if err != nil {
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, err.Error())
}
entries := keeper.GetContractHistory(ctx, contractAddr)
if entries == nil {
// nil, nil leads to 404 in rest handler
return nil, nil
}
// redact response
for i := range entries {
entries[i].Updated = nil
}

bz, err := json.MarshalIndent(entries, "", " ")
if err != nil {
return nil, sdkerrors.Wrap(sdkerrors.ErrJSONMarshal, err.Error())
}
return bz, nil
}
*/

func queryContractAddress(ctx sdk.Context, label string, keeper Keeper) (sdk.AccAddress, error) {
res := keeper.GetContractAddress(ctx, label)
if res == nil {
@@ -317,5 +294,10 @@ func queryContractHash(ctx sdk.Context, address sdk.AccAddress, keeper Keeper) (
return nil, nil
}

return keeper.GetCodeInfo(ctx, res.CodeID).CodeHash, nil
codeInfo, err := keeper.GetCodeInfo(ctx, res.CodeID)
if err != nil {
return nil, nil
}

return codeInfo.CodeHash, nil
}
15 changes: 12 additions & 3 deletions x/compute/internal/keeper/querier_test.go
Original file line number Diff line number Diff line change
@@ -48,7 +48,10 @@ func TestQueryContractLabel(t *testing.T) {
initMsgBz, err := json.Marshal(initMsg)
require.NoError(t, err)

hash := keeper.GetCodeInfo(ctx, contractID).CodeHash
codeInfo, err := keeper.GetCodeInfo(ctx, contractID)
require.NoError(t, err)

hash := codeInfo.CodeHash

msg := types.SecretMsg{
CodeHash: []byte(hex.EncodeToString(hash)),
@@ -149,7 +152,10 @@ func TestQueryContractState(t *testing.T) {
initMsgBz, err := json.Marshal(initMsg)
require.NoError(t, err)

key := keeper.GetCodeInfo(ctx, contractID).CodeHash
codeInfo, err := keeper.GetCodeInfo(ctx, contractID)
require.NoError(t, err)

key := codeInfo.CodeHash
keyStr := hex.EncodeToString(key)

msg := types.SecretMsg{
@@ -290,7 +296,10 @@ func TestListContractByCodeOrdering(t *testing.T) {
initMsgBz, err := json.Marshal(initMsg)
require.NoError(t, err)

key := keeper.GetCodeInfo(ctx, codeID).CodeHash
codeInfo, err := keeper.GetCodeInfo(ctx, codeID)
require.NoError(t, err)

key := codeInfo.CodeHash
keyStr := hex.EncodeToString(key)

msg := types.SecretMsg{
68 changes: 51 additions & 17 deletions x/compute/internal/keeper/secret_contracts_test.go
Original file line number Diff line number Diff line change
@@ -56,7 +56,10 @@ func testEncrypt(t *testing.T, keeper Keeper, ctx sdk.Context, contractAddress s
var err error

if codeId != 0 {
hash = keeper.GetCodeInfo(ctx, codeId).CodeHash
codeInfo, err := keeper.GetCodeInfo(ctx, codeId)
require.NoError(t, err)

hash = codeInfo.CodeHash
} else {
hash, err = keeper.GetContractHash(ctx, contractAddress)
require.NoError(t, err)
@@ -85,7 +88,10 @@ func uploadCode(ctx sdk.Context, t *testing.T, keeper Keeper, wasmPath string, w
codeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

codeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, codeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, codeID)
require.NoError(t, err)

codeHash := hex.EncodeToString(codeInfo.CodeHash)

return codeID, codeHash
}
@@ -547,7 +553,10 @@ func initHelperImpl(
codeID uint64, creator sdk.AccAddress, creatorPrivKey crypto.PrivKey, initMsg string,
isErrorEncrypted bool, isV1Contract bool, gas uint64, wasmCallCount int64, sentFunds sdk.Coins, shouldSkipAttributes ...bool,
) ([]byte, sdk.Context, sdk.AccAddress, []ContractEvent, cosmwasm.StdError) {
hashStr := hex.EncodeToString(keeper.GetCodeInfo(ctx, codeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, codeID)
require.NoError(t, err)

hashStr := hex.EncodeToString(codeInfo.CodeHash)

msg := types.SecretMsg{
CodeHash: []byte(hashStr),
@@ -3700,7 +3709,6 @@ func TestSendFunds(t *testing.T) {
originType, destinationType := callTypes[0], callTypes[1]

t.Run(originType+"->"+destinationType, func(t *testing.T) {

alreadyTested := make(map[string]bool)
alreadyTested["useruser->useruser"] = true // we are only testing contracts here
for _, currentSubjects := range multisetsFrom(testContracts, 2) {
@@ -3945,7 +3953,9 @@ func TestWasmMsgStructure(t *testing.T) {
require.NoError(t, err)

toCodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
toCodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, toCodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, toCodeID)
require.NoError(t, err)
toCodeHash := hex.EncodeToString(codeInfo.CodeHash)
require.NoError(t, err)

toAddress := sdk.AccAddress{}
@@ -4114,7 +4124,9 @@ func TestV1InitV010ContractWithReply(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, _ := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"counter":{"counter":10, "expires":100}}`, true, true, defaultGasForTests)
msg := fmt.Sprintf(`{"init_v10":{"counter":80, "code_id":%d, "code_hash":"%s"}}`, v010CodeID, v010CodeHash)
@@ -4143,7 +4155,9 @@ func TestV1ExecuteV010ContractWithReply(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, err := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"nop":{}}`, true, true, defaultGasForTests)
require.Empty(t, err)
@@ -4167,7 +4181,9 @@ func TestV1InitV010ContractNoReply(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, _ := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"counter":{"counter":10, "expires":100}}`, true, true, defaultGasForTests)
msg := fmt.Sprintf(`{"init_v10_no_reply":{"counter":180, "code_id":%d, "code_hash":"%s"}}`, v010CodeID, v010CodeHash)
@@ -4196,7 +4212,9 @@ func TestV1ExecuteV010ContractNoReply(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, err := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"nop":{}}`, true, true, defaultGasForTests)
require.Empty(t, err)
@@ -4225,7 +4243,9 @@ func TestV1QueryV010Contract(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, err := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"nop":{}}`, true, true, defaultGasForTests)
require.Empty(t, err)
@@ -4249,7 +4269,9 @@ func TestV1InitV010ContractWithReplyWithError(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, _ := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"counter":{"counter":10, "expires":100}}`, true, true, defaultGasForTests)
msg := fmt.Sprintf(`{"init_v10_with_error":{"code_id":%d, "code_hash":"%s"}}`, v010CodeID, v010CodeHash)
@@ -4268,7 +4290,9 @@ func TestV1ExecuteV010ContractWithReplyWithError(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, err := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"nop":{}}`, true, true, defaultGasForTests)
require.Empty(t, err)
@@ -4291,7 +4315,9 @@ func TestV1InitV010ContractNoReplyWithError(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, _ := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"counter":{"counter":10, "expires":100}}`, true, true, defaultGasForTests)
msg := fmt.Sprintf(`{"init_v10_no_reply_with_error":{"code_id":%d, "code_hash":"%s"}}`, v010CodeID, v010CodeHash)
@@ -4311,7 +4337,9 @@ func TestV1ExecuteV010ContractNoReplyWithError(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, err := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"nop":{}}`, true, true, defaultGasForTests)
require.Empty(t, err)
@@ -4335,7 +4363,9 @@ func TestV1QueryV010ContractWithError(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, contractAddress, _, err := initHelper(t, keeper, ctx, codeID, walletA, privKeyA, `{"nop":{}}`, true, true, defaultGasForTests)
require.Empty(t, err)
@@ -5873,7 +5903,9 @@ func TestV1SendsLogsMixedWithV010WithoutReply(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, v010ContractAddress, _, err := initHelper(t, keeper, ctx, v010CodeID, walletA, privKeyA, `{"nop":{}}`, true, false, defaultGasForTests)
require.Empty(t, err)
@@ -5933,7 +5965,9 @@ func TestV1SendsLogsMixedWithV010WithReply(t *testing.T) {
v010CodeID, err := keeper.Create(ctx, walletA, wasmCode, "", "")
require.NoError(t, err)

v010CodeHash := hex.EncodeToString(keeper.GetCodeInfo(ctx, v010CodeID).CodeHash)
codeInfo, err := keeper.GetCodeInfo(ctx, v010CodeID)
require.NoError(t, err)
v010CodeHash := hex.EncodeToString(codeInfo.CodeHash)

_, _, v010ContractAddress, _, err := initHelper(t, keeper, ctx, v010CodeID, walletA, privKeyA, `{"nop":{}}`, true, false, defaultGasForTests)
require.Empty(t, err)