Some checks failed
CodeQL / Analyze (push) Waiting to run
golangci-lint / lint (push) Waiting to run
Tests / Code Coverage / build (amd64) (push) Waiting to run
Tests / Code Coverage / build (arm64) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[additional-args:-tags="test_e2e" name:e2e path:./e2e]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:08-wasm path:./modules/light-clients/08-wasm]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:ibc-go path:.]) (push) Waiting to run
Docker Build & Push Simapp (main) / docker-build (push) Has been cancelled
174 lines
6.4 KiB
Go
174 lines
6.4 KiB
Go
//go:build !test_e2e
|
|
|
|
package transfer
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
test "github.com/cosmos/interchaintest/v10/testutil"
|
|
testifysuite "github.com/stretchr/testify/suite"
|
|
|
|
"github.com/cosmos/ibc-go/e2e/testsuite"
|
|
"github.com/cosmos/ibc-go/e2e/testsuite/query"
|
|
"github.com/cosmos/ibc-go/e2e/testvalues"
|
|
transfertypes "git.cw.tr/mukan-network/mukan-ibc/modules/apps/transfer/types"
|
|
clienttypes "git.cw.tr/mukan-network/mukan-ibc/modules/core/02-client/types"
|
|
channeltypes "git.cw.tr/mukan-network/mukan-ibc/modules/core/04-channel/types"
|
|
"git.cw.tr/mukan-network/mukan-ibc/modules/core/exported"
|
|
localhost "git.cw.tr/mukan-network/mukan-ibc/modules/light-clients/09-localhost"
|
|
ibctesting "git.cw.tr/mukan-network/mukan-ibc/testing"
|
|
)
|
|
|
|
// compatibility:from_version: v7.10.0
|
|
func TestTransferLocalhostTestSuite(t *testing.T) {
|
|
testifysuite.Run(t, new(LocalhostTransferTestSuite))
|
|
}
|
|
|
|
type LocalhostTransferTestSuite struct {
|
|
testsuite.E2ETestSuite
|
|
}
|
|
|
|
// SetupSuite sets up chains for the current test suite
|
|
func (s *LocalhostTransferTestSuite) SetupSuite() {
|
|
s.SetupChains(context.TODO(), 1, nil)
|
|
}
|
|
|
|
// TestMsgTransfer_Localhost creates two wallets on a single chain and performs MsgTransfers back and forth
|
|
// to ensure ibc functions as expected on localhost. This test is largely the same as TestMsgTransfer_Succeeds_Nonincentivized
|
|
// except that chain B is replaced with an additional wallet on chainA.
|
|
func (s *LocalhostTransferTestSuite) TestMsgTransfer_Localhost() {
|
|
t := s.T()
|
|
ctx := context.TODO()
|
|
|
|
chains := s.GetAllChains()
|
|
chainA := chains[0]
|
|
|
|
channelVersion := transfertypes.V1
|
|
|
|
chainADenom := chainA.Config().Denom
|
|
|
|
rlyWallet := s.CreateUserOnChainA(ctx, testvalues.StartingTokenAmount)
|
|
userAWallet := s.CreateUserOnChainA(ctx, testvalues.StartingTokenAmount)
|
|
userBWallet := s.CreateUserOnChainA(ctx, testvalues.StartingTokenAmount)
|
|
|
|
var (
|
|
msgChanOpenInitRes channeltypes.MsgChannelOpenInitResponse
|
|
msgChanOpenTryRes channeltypes.MsgChannelOpenTryResponse
|
|
ack []byte
|
|
packet channeltypes.Packet
|
|
)
|
|
|
|
s.Require().NoError(test.WaitForBlocks(ctx, 1, chainA), "failed to wait for blocks")
|
|
|
|
t.Run("channel open init localhost", func(t *testing.T) {
|
|
msgChanOpenInit := channeltypes.NewMsgChannelOpenInit(
|
|
transfertypes.PortID, channelVersion,
|
|
channeltypes.UNORDERED, []string{exported.LocalhostConnectionID},
|
|
transfertypes.PortID, rlyWallet.FormattedAddress(),
|
|
)
|
|
|
|
s.Require().NoError(msgChanOpenInit.ValidateBasic())
|
|
|
|
txResp := s.BroadcastMessages(ctx, chainA, rlyWallet, msgChanOpenInit)
|
|
s.AssertTxSuccess(txResp)
|
|
|
|
s.Require().NoError(testsuite.UnmarshalMsgResponses(txResp, &msgChanOpenInitRes))
|
|
})
|
|
|
|
t.Run("channel open try localhost", func(t *testing.T) {
|
|
msgChanOpenTry := channeltypes.NewMsgChannelOpenTry(
|
|
transfertypes.PortID, channelVersion,
|
|
channeltypes.UNORDERED, []string{exported.LocalhostConnectionID},
|
|
transfertypes.PortID, msgChanOpenInitRes.ChannelId,
|
|
channelVersion, localhost.SentinelProof, clienttypes.ZeroHeight(), rlyWallet.FormattedAddress(),
|
|
)
|
|
|
|
txResp := s.BroadcastMessages(ctx, chainA, rlyWallet, msgChanOpenTry)
|
|
s.AssertTxSuccess(txResp)
|
|
|
|
s.Require().NoError(testsuite.UnmarshalMsgResponses(txResp, &msgChanOpenTryRes))
|
|
})
|
|
|
|
t.Run("channel open ack localhost", func(t *testing.T) {
|
|
msgChanOpenAck := channeltypes.NewMsgChannelOpenAck(
|
|
transfertypes.PortID, msgChanOpenInitRes.ChannelId,
|
|
msgChanOpenTryRes.ChannelId, channelVersion,
|
|
localhost.SentinelProof, clienttypes.ZeroHeight(), rlyWallet.FormattedAddress(),
|
|
)
|
|
|
|
txResp := s.BroadcastMessages(ctx, chainA, rlyWallet, msgChanOpenAck)
|
|
s.AssertTxSuccess(txResp)
|
|
})
|
|
|
|
t.Run("channel open confirm localhost", func(t *testing.T) {
|
|
msgChanOpenConfirm := channeltypes.NewMsgChannelOpenConfirm(
|
|
transfertypes.PortID, msgChanOpenTryRes.ChannelId,
|
|
localhost.SentinelProof, clienttypes.ZeroHeight(), rlyWallet.FormattedAddress(),
|
|
)
|
|
|
|
txResp := s.BroadcastMessages(ctx, chainA, rlyWallet, msgChanOpenConfirm)
|
|
s.AssertTxSuccess(txResp)
|
|
})
|
|
|
|
t.Run("query localhost transfer channel ends", func(t *testing.T) {
|
|
channelEndA, err := query.Channel(ctx, chainA, transfertypes.PortID, msgChanOpenInitRes.ChannelId)
|
|
s.Require().NoError(err)
|
|
s.Require().NotNil(channelEndA)
|
|
|
|
channelEndB, err := query.Channel(ctx, chainA, transfertypes.PortID, msgChanOpenTryRes.ChannelId)
|
|
s.Require().NoError(err)
|
|
s.Require().NotNil(channelEndB)
|
|
|
|
s.Require().Equal(channelEndA.ConnectionHops, channelEndB.ConnectionHops)
|
|
})
|
|
|
|
t.Run("send packet localhost ibc transfer", func(t *testing.T) {
|
|
var err error
|
|
txResp := s.Transfer(ctx, chainA, userAWallet, transfertypes.PortID, msgChanOpenInitRes.ChannelId, testvalues.DefaultTransferAmount(chainADenom), userAWallet.FormattedAddress(), userBWallet.FormattedAddress(), clienttypes.NewHeight(1, 500), 0, "")
|
|
s.AssertTxSuccess(txResp)
|
|
|
|
packet, err = ibctesting.ParseV1PacketFromEvents(txResp.Events)
|
|
s.Require().NoError(err)
|
|
s.Require().NotNil(packet)
|
|
})
|
|
|
|
t.Run("tokens are escrowed", func(t *testing.T) {
|
|
actualBalance, err := s.GetChainANativeBalance(ctx, userAWallet)
|
|
s.Require().NoError(err)
|
|
|
|
expected := testvalues.StartingTokenAmount - testvalues.IBCTransferAmount
|
|
s.Require().Equal(expected, actualBalance)
|
|
})
|
|
|
|
t.Run("recv packet localhost ibc transfer", func(t *testing.T) {
|
|
var err error
|
|
msgRecvPacket := channeltypes.NewMsgRecvPacket(packet, localhost.SentinelProof, clienttypes.ZeroHeight(), rlyWallet.FormattedAddress())
|
|
|
|
txResp := s.BroadcastMessages(ctx, chainA, rlyWallet, msgRecvPacket)
|
|
s.AssertTxSuccess(txResp)
|
|
|
|
ack, err = ibctesting.ParseAckFromEvents(txResp.Events)
|
|
s.Require().NoError(err)
|
|
s.Require().NotNil(ack)
|
|
})
|
|
|
|
t.Run("acknowledge packet localhost ibc transfer", func(t *testing.T) {
|
|
msgAcknowledgement := channeltypes.NewMsgAcknowledgement(packet, ack, localhost.SentinelProof, clienttypes.ZeroHeight(), rlyWallet.FormattedAddress())
|
|
|
|
txResp := s.BroadcastMessages(ctx, chainA, rlyWallet, msgAcknowledgement)
|
|
s.AssertTxSuccess(txResp)
|
|
})
|
|
|
|
t.Run("verify tokens transferred", func(t *testing.T) {
|
|
s.AssertPacketRelayed(ctx, chainA, transfertypes.PortID, msgChanOpenInitRes.ChannelId, 1)
|
|
|
|
ibcToken := testsuite.GetIBCToken(chainADenom, transfertypes.PortID, msgChanOpenTryRes.ChannelId)
|
|
actualBalance, err := query.Balance(ctx, chainA, userBWallet.FormattedAddress(), ibcToken.IBCDenom())
|
|
|
|
s.Require().NoError(err)
|
|
|
|
expected := testvalues.IBCTransferAmount
|
|
s.Require().Equal(expected, actualBalance.Int64())
|
|
})
|
|
}
|