Skip to content

Commit

Permalink
update cli tests
Browse files Browse the repository at this point in the history
  • Loading branch information
NagaTulasi committed Sep 25, 2024
1 parent 6aba59d commit 83b35fd
Show file tree
Hide file tree
Showing 2 changed files with 155 additions and 148 deletions.
46 changes: 24 additions & 22 deletions network/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -105,28 +105,30 @@ type Config struct {
LegacyAmino *codec.LegacyAmino // TODO: Remove!
InterfaceRegistry codectypes.InterfaceRegistry

TxConfig client.TxConfig
AccountRetriever client.AccountRetriever
AppConstructor AppConstructor // the ABCI application constructor
GenesisState map[string]json.RawMessage // custom genesis state to provide
TimeoutCommit time.Duration // the consensus commitment timeout
ChainID string // the network chain-id
NumValidators int // the total number of validators to create and bond
Mnemonics []string // custom user-provided validator operator mnemonics
BondDenom string // the staking bond denomination
MinGasPrices string // the minimum gas prices each validator will accept
AccountTokens sdkmath.Int // the amount of unique validator tokens (e.g. 1000node0)
StakingTokens sdkmath.Int // the amount of tokens each validator has available to stake
BondedTokens sdkmath.Int // the amount of tokens each validator stakes
PruningStrategy string // the pruning strategy each validator will have
EnableLogging bool // enable logging to STDOUT
CleanupDir bool // remove base temporary directory during cleanup
SigningAlgo string // signing algorithm for keys
KeyringOptions []keyring.Option // keyring configuration options
RPCAddress string // RPC listen address (including port)
APIAddress string // REST API listen address (including port)
GRPCAddress string // GRPC server listen address (including port)
PrintMnemonic bool // print the mnemonic of first validator as log output for testing
TxConfig client.TxConfig
AccountRetriever client.AccountRetriever
AppConstructor AppConstructor // the ABCI application constructor
GenesisState map[string]json.RawMessage // custom genesis state to provide
TimeoutCommit time.Duration // the consensus commitment timeout
ChainID string // the network chain-id
NumValidators int // the total number of validators to create and bond
Mnemonics []string // custom user-provided validator operator mnemonics
BondDenom string // the staking bond denomination
MinGasPrices string // the minimum gas prices each validator will accept
AccountTokens sdkmath.Int // the amount of unique validator tokens (e.g. 1000node0)
StakingTokens sdkmath.Int // the amount of tokens each validator has available to stake
BondedTokens sdkmath.Int // the amount of tokens each validator stakes
PruningStrategy string // the pruning strategy each validator will have
EnableLogging bool // enable logging to STDOUT
CleanupDir bool // remove base temporary directory during cleanup
SigningAlgo string // signing algorithm for keys
KeyringOptions []keyring.Option // keyring configuration options
RPCAddress string // RPC listen address (including port)
APIAddress string // REST API listen address (including port)
GRPCAddress string // GRPC server listen address (including port)
PrintMnemonic bool // print the mnemonic of first validator as log output for testing
LightClientURL string
PublishBlobInterval string
}

// DefaultConfig returns a sane default configuration suitable for nearly all
Expand Down
257 changes: 131 additions & 126 deletions x/cada/client/cli/cli_test.go
Original file line number Diff line number Diff line change
@@ -1,128 +1,133 @@
package cli_test

// import (
// "fmt"
// "testing"

// "github.com/cosmos/cosmos-sdk/client/flags"
// "github.com/cosmos/cosmos-sdk/crypto/hd"
// sdk "github.com/cosmos/cosmos-sdk/types"
// "github.com/stretchr/testify/suite"
// "github.com/vitwit/avail-da-module/client/cli"
// network "github.com/vitwit/avail-da-module/network"

// app "simapp/app"

// clitestutil "github.com/cosmos/cosmos-sdk/testutil/cli"
// )

// func TestIntegrationTestSuite(t *testing.T) {
// suite.Run(t, new(IntegrationTestSuite))
// }

// type IntegrationTestSuite struct {
// suite.Suite

// cfg network.Config
// network *network.Network
// addresses []string
// }

// const aliceMnemonic = "all soap kiwi cushion federal skirt tip shock exist tragic verify lunar shine rely torch please view future lizard garbage humble medal leisure mimic"

// func (s *IntegrationTestSuite) SetupSuite() {
// s.T().Log("setting up integration test suite")

// var err error

// // Setup network config
// cfg := network.DefaultConfig(app.NewTestNetworkFixture)
// cfg.NumValidators = 1
// s.cfg = cfg

// // Initialize the network
// s.network, err = network.New(s.T(), s.T().TempDir(), cfg)
// s.Require().NoError(err)

// kb := s.network.Validators[0].ClientCtx.Keyring
// path := sdk.GetConfig().GetFullBIP44Path()
// info, err := kb.NewAccount("alice", aliceMnemonic, "", path, hd.Secp256k1)
// s.Require().NoError(err)

// add, err := info.GetAddress()
// s.Require().NoError(err)
// s.addresses = append(s.addresses, add.String())

// _, err = s.network.WaitForHeight(1)
// s.Require().NoError(err)
// }

// func (s *IntegrationTestSuite) TearDownSuite() {
// s.T().Log("tearing down integration suite")
// s.network.Cleanup()
// }

// func (s *IntegrationTestSuite) TestNewUpdateBlobStatusCmd() {
// val := s.network.Validators[0]

// testCases := []struct {
// name string
// args []string
// expectErr bool
// }{
// {
// "update blob status - success",
// []string{
// "1",
// "10",
// "success",
// "120",
// fmt.Sprintf("--%s=%s", flags.FlagFrom, s.addresses[0]),
// fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
// fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
// },
// false,
// },
// {
// "update blob status - failure",
// []string{
// "1",
// "10",
// "failure",
// "120",
// fmt.Sprintf("--%s=%s", flags.FlagFrom, s.addresses[0]),
// fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
// fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
// },
// false,
// },
// {
// "update blob status - invalid status",
// []string{
// "1",
// "10",
// "invalid",
// "120",
// fmt.Sprintf("--%s=%s", flags.FlagFrom, s.addresses[0]),
// fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
// fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
// },
// false,
// },
// }

// for _, tc := range testCases {
// s.Run(tc.name, func() {
// cmd := cli.NewUpdateBlobStatusCmd()
// res, err := clitestutil.ExecTestCLICmd(val.ClientCtx, cmd, tc.args)
// if tc.expectErr {
// if err != nil {
// s.Require().Error(err)
// }
// }

// s.Require().NoError(nil)
// s.Require().NotNil(res)
// })
// }
// }
import (
"fmt"
"testing"

"github.com/cosmos/cosmos-sdk/client/flags"
"github.com/cosmos/cosmos-sdk/crypto/hd"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/stretchr/testify/suite"
network "github.com/vitwit/avail-da-module/network"
"github.com/vitwit/avail-da-module/x/cada/client/cli"

clitestutil "github.com/cosmos/cosmos-sdk/testutil/cli"
)

func TestIntegrationTestSuite(t *testing.T) {
suite.Run(t, new(IntegrationTestSuite))
}

type IntegrationTestSuite struct {
suite.Suite

cfg network.Config
network *network.Network
addresses []string
}

const aliceMnemonic = "all soap kiwi cushion federal skirt tip shock exist tragic verify lunar shine rely torch please view future lizard garbage humble medal leisure mimic"

func (s *IntegrationTestSuite) SetupSuite() {
s.T().Log("setting up integration test suite")

var err error

appConfig := network.MinimumAppConfig()

cfg, err := network.DefaultConfigWithAppConfig(appConfig)
s.Require().NoError(err)

s.cfg = cfg

cfg.NumValidators = 1
cfg.MinGasPrices = "0.000006stake"
cfg.PublishBlobInterval = "5"
cfg.LightClientURL = "http://127.0.0.1:8000"

// Initialize the network
s.network, err = network.New(s.T(), s.T().TempDir(), cfg)
s.Require().NoError(err)

kb := s.network.Validators[0].ClientCtx.Keyring
path := sdk.GetConfig().GetFullBIP44Path()
info, err := kb.NewAccount("alice", aliceMnemonic, "", path, hd.Secp256k1)
s.Require().NoError(err)

add, err := info.GetAddress()
s.Require().NoError(err)
s.addresses = append(s.addresses, add.String())

_, err = s.network.WaitForHeight(1)
s.Require().NoError(err)
}

func (s *IntegrationTestSuite) TearDownSuite() {
s.T().Log("tearing down integration suite")
s.network.Cleanup()
}

func (s *IntegrationTestSuite) TestNewUpdateBlobStatusCmd() {
val := s.network.Validators[0]

testCases := []struct {
name string
args []string
expectErr bool
}{
{
"update blob status - success",
[]string{
"1",
"10",
"success",
"120",
fmt.Sprintf("--%s=%s", flags.FlagFrom, s.addresses[0]),
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
},
false,
},
{
"update blob status - failure",
[]string{
"1",
"10",
"failure",
"120",
fmt.Sprintf("--%s=%s", flags.FlagFrom, s.addresses[0]),
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
},
false,
},
{
"update blob status - invalid status",
[]string{
"1",
"10",
"invalid",
"120",
fmt.Sprintf("--%s=%s", flags.FlagFrom, s.addresses[0]),
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
},
false,
},
}

for _, tc := range testCases {
s.Run(tc.name, func() {
cmd := cli.NewUpdateBlobStatusCmd()
res, err := clitestutil.ExecTestCLICmd(val.ClientCtx, cmd, tc.args)
if tc.expectErr {
if err != nil {
s.Require().Error(err)
}
}

s.Require().NoError(nil)
s.Require().NotNil(res)
})
}
}

0 comments on commit 83b35fd

Please sign in to comment.