Some checks are pending
Build SimApp / build (amd64) (push) Waiting to run
Build SimApp / build (arm64) (push) Waiting to run
CodeQL / Analyze (push) Waiting to run
Build & Push / build (push) Waiting to run
Run Gosec / Gosec (push) Waiting to run
Lint / golangci-lint (push) Waiting to run
Checks dependencies and mocks generation / Check go mod tidy (push) Waiting to run
Checks dependencies and mocks generation / Check up to date mocks (push) Waiting to run
System Tests / setup (push) Waiting to run
System Tests / test-system (push) Blocked by required conditions
System Tests / test-system-legacy (push) Blocked by required conditions
Tests / Code Coverage / split-test-files (push) Waiting to run
Tests / Code Coverage / tests (00) (push) Blocked by required conditions
Tests / Code Coverage / tests (01) (push) Blocked by required conditions
Tests / Code Coverage / tests (02) (push) Blocked by required conditions
Tests / Code Coverage / tests (03) (push) Blocked by required conditions
Tests / Code Coverage / test-integration (push) Waiting to run
Tests / Code Coverage / test-e2e (push) Waiting to run
Tests / Code Coverage / repo-analysis (push) Blocked by required conditions
Tests / Code Coverage / test-sim-nondeterminism (push) Waiting to run
Tests / Code Coverage / test-clientv2 (push) Waiting to run
Tests / Code Coverage / test-core (push) Waiting to run
Tests / Code Coverage / test-depinject (push) Waiting to run
Tests / Code Coverage / test-errors (push) Waiting to run
Tests / Code Coverage / test-math (push) Waiting to run
Tests / Code Coverage / test-schema (push) Waiting to run
Tests / Code Coverage / test-collections (push) Waiting to run
Tests / Code Coverage / test-cosmovisor (push) Waiting to run
Tests / Code Coverage / test-confix (push) Waiting to run
Tests / Code Coverage / test-store (push) Waiting to run
Tests / Code Coverage / test-log (push) Waiting to run
Tests / Code Coverage / test-x-tx (push) Waiting to run
Tests / Code Coverage / test-x-nft (push) Waiting to run
Tests / Code Coverage / test-x-circuit (push) Waiting to run
Tests / Code Coverage / test-x-feegrant (push) Waiting to run
Tests / Code Coverage / test-x-evidence (push) Waiting to run
Tests / Code Coverage / test-x-upgrade (push) Waiting to run
Tests / Code Coverage / test-tools-benchmark (push) Waiting to run
93 lines
2.6 KiB
Go
93 lines
2.6 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
"time"
|
|
|
|
"cosmossdk.io/math"
|
|
|
|
"git.cw.tr/mukan-network/mukan-sdk/x/protocolpool/types"
|
|
)
|
|
|
|
func (suite *KeeperTestSuite) TestInitExportGenesis() {
|
|
suite.bankKeeper.EXPECT().BlockedAddr(recipientAddr).Return(false).Times(1)
|
|
|
|
gs := types.NewGenesisState(
|
|
[]types.ContinuousFund{
|
|
{
|
|
Recipient: recipientAddr.String(),
|
|
Percentage: math.LegacyMustNewDecFromStr("0.1"),
|
|
Expiry: nil,
|
|
},
|
|
},
|
|
)
|
|
|
|
err := suite.poolKeeper.InitGenesis(suite.ctx, gs)
|
|
suite.Require().NoError(err)
|
|
|
|
// Export
|
|
exportedGenState, err := suite.poolKeeper.ExportGenesis(suite.ctx)
|
|
suite.Require().NoError(err)
|
|
suite.Require().Equal(gs.ContinuousFunds, exportedGenState.ContinuousFunds)
|
|
}
|
|
|
|
func (suite *KeeperTestSuite) TestInitExportGenesis_BlockedAddress() {
|
|
suite.bankKeeper.EXPECT().BlockedAddr(recipientAddr).Return(true).Times(1)
|
|
|
|
gs := types.NewGenesisState(
|
|
[]types.ContinuousFund{
|
|
{
|
|
Recipient: recipientAddr.String(),
|
|
Percentage: math.LegacyMustNewDecFromStr("0.1"),
|
|
Expiry: nil,
|
|
},
|
|
},
|
|
)
|
|
|
|
err := suite.poolKeeper.InitGenesis(suite.ctx, gs)
|
|
suite.Require().Error(err)
|
|
}
|
|
|
|
func (suite *KeeperTestSuite) TestInitGenesis_InvalidRecipient() {
|
|
gs := types.NewGenesisState([]types.ContinuousFund{
|
|
{
|
|
Recipient: "invalid_address", // This should fail the address decoding.
|
|
Percentage: math.LegacyMustNewDecFromStr("0.1"),
|
|
Expiry: nil,
|
|
},
|
|
})
|
|
|
|
err := suite.poolKeeper.InitGenesis(suite.ctx, gs)
|
|
suite.Require().Error(err)
|
|
}
|
|
|
|
func (suite *KeeperTestSuite) TestInitGenesis_SkipsExpiredFunds() {
|
|
suite.bankKeeper.EXPECT().BlockedAddr(recipientAddr).Return(false).Times(1)
|
|
suite.bankKeeper.EXPECT().BlockedAddr(recipientAddr2).Return(false).Times(1)
|
|
|
|
// Set up block time for the test
|
|
currentTime := suite.ctx.BlockTime()
|
|
expiredTime := currentTime.Add(-time.Hour)
|
|
futureTime := currentTime.Add(time.Hour)
|
|
|
|
gs := types.NewGenesisState([]types.ContinuousFund{
|
|
{
|
|
Recipient: recipientAddr.String(),
|
|
Percentage: math.LegacyMustNewDecFromStr("0.1"),
|
|
Expiry: &expiredTime, // This fund should be ignored.
|
|
},
|
|
{
|
|
Recipient: recipientAddr2.String(),
|
|
Percentage: math.LegacyMustNewDecFromStr("0.2"),
|
|
Expiry: &futureTime, // This fund should be accepted.
|
|
},
|
|
})
|
|
|
|
err := suite.poolKeeper.InitGenesis(suite.ctx, gs)
|
|
suite.Require().NoError(err)
|
|
|
|
// Export and verify only the valid continuous fund is present.
|
|
exportedGenState, err := suite.poolKeeper.ExportGenesis(suite.ctx)
|
|
suite.Require().NoError(err)
|
|
suite.Require().Len(exportedGenState.ContinuousFunds, 1)
|
|
suite.Require().Equal(recipientAddr2.String(), exportedGenState.ContinuousFunds[0].Recipient)
|
|
}
|