mirror of
https://github.com/planetmint/planetmint-go.git
synced 2025-06-06 06:06:43 +00:00

* ignite scaffold map redeem-claim amount issued:bool --module dao --index beneficiary,liquid-tx-hash * revert: remove autogenerated delete redeem claim logic * fix: replace deprecated autogenerated sdkerrors with errorsmod * refactor: rename issued to confirmed on redeem claim * feat: add claim address param * test: add test for restricted msg UpdateRedeemClaim * refactor: update redeem claim key creation and messages * feat: add SendUpdateRedeemCLaim to util * feat: add RedeemClaimDecorator for ante package * ignite scaffold message confirm-redeem-claim id:uint beneficiary:string --module dao * feat: add handleConfirmRedeemClaim to ante handler * feat: add handleUpdateRedeemClaim to ante handler * feat: implement ConfirmRedeemClaim msg handler * test: add redeem claim test and adjust e2e test suite * fix: make use of uint to rddl string util in CreateRedeemClaim * fix: linter and staticcheck errors * ignite scaffold query redeem-claim-by-liquid-tx-hash liquid-tx-hash --response redeem-claim:RedeemClaim --module dao * feat: add RedeemClaimByLiquidTXHash store capabilities * test: add QueryRedeemClaimByLiquidTxHash to e2e test suite * feat: add RedeemClaimDecorator to ante handler chain * fix: remove redundant planetmint-go from service path * fix: linter and staticcheck errors * fix: go vet errors * fix: remove unused autogenerated simulation * fix: broken simulation * fix: openapi.yml * revert: remove autogenerated redundant test file that causes data race on pipeline * feat: burn claim on CreateRedeemClaim * fix: linter error * test: fix mock bankkeeper for msg server test * fix: reissuance test if statement * chore: removed TODO comment * fix: typo in redeem claim error msg * revert: remove autogenerated genesis state * fix: dao module simulation * revert: remove unused function * fix: linter errors * fix: linter error --------- Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com>
131 lines
3.5 KiB
Go
131 lines
3.5 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
"strconv"
|
|
"testing"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/types/query"
|
|
"github.com/stretchr/testify/require"
|
|
"google.golang.org/grpc/codes"
|
|
"google.golang.org/grpc/status"
|
|
|
|
keepertest "github.com/planetmint/planetmint-go/testutil/keeper"
|
|
"github.com/planetmint/planetmint-go/testutil/nullify"
|
|
"github.com/planetmint/planetmint-go/x/dao/types"
|
|
)
|
|
|
|
// Prevent strconv unused error
|
|
var _ = strconv.IntSize
|
|
|
|
func TestRedeemClaimQuerySingle(t *testing.T) {
|
|
keeper, ctx := keepertest.DaoKeeper(t)
|
|
wctx := sdk.WrapSDKContext(ctx)
|
|
msgs := createNRedeemClaim(keeper, ctx, 2)
|
|
tests := []struct {
|
|
desc string
|
|
request *types.QueryGetRedeemClaimRequest
|
|
response *types.QueryGetRedeemClaimResponse
|
|
err error
|
|
}{
|
|
{
|
|
desc: "First",
|
|
request: &types.QueryGetRedeemClaimRequest{
|
|
Beneficiary: msgs[0].Beneficiary,
|
|
Id: msgs[0].Id,
|
|
},
|
|
response: &types.QueryGetRedeemClaimResponse{RedeemClaim: msgs[0]},
|
|
},
|
|
{
|
|
desc: "Second",
|
|
request: &types.QueryGetRedeemClaimRequest{
|
|
Beneficiary: msgs[1].Beneficiary,
|
|
Id: msgs[1].Id,
|
|
},
|
|
response: &types.QueryGetRedeemClaimResponse{RedeemClaim: msgs[1]},
|
|
},
|
|
{
|
|
desc: "KeyNotFound",
|
|
request: &types.QueryGetRedeemClaimRequest{
|
|
Beneficiary: strconv.Itoa(100000),
|
|
Id: uint64(100000),
|
|
},
|
|
err: status.Error(codes.NotFound, "not found"),
|
|
},
|
|
{
|
|
desc: "InvalidRequest",
|
|
err: status.Error(codes.InvalidArgument, "invalid request"),
|
|
},
|
|
}
|
|
for _, tc := range tests {
|
|
t.Run(tc.desc, func(t *testing.T) {
|
|
response, err := keeper.RedeemClaim(wctx, tc.request)
|
|
if tc.err != nil {
|
|
require.ErrorIs(t, err, tc.err)
|
|
} else {
|
|
require.NoError(t, err)
|
|
require.Equal(t,
|
|
nullify.Fill(tc.response),
|
|
nullify.Fill(response),
|
|
)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestRedeemClaimQueryPaginated(t *testing.T) {
|
|
keeper, ctx := keepertest.DaoKeeper(t)
|
|
wctx := sdk.WrapSDKContext(ctx)
|
|
msgs := createNRedeemClaim(keeper, ctx, 5)
|
|
|
|
request := func(next []byte, offset, limit uint64, total bool) *types.QueryAllRedeemClaimRequest {
|
|
return &types.QueryAllRedeemClaimRequest{
|
|
Pagination: &query.PageRequest{
|
|
Key: next,
|
|
Offset: offset,
|
|
Limit: limit,
|
|
CountTotal: total,
|
|
},
|
|
}
|
|
}
|
|
t.Run("ByOffset", func(t *testing.T) {
|
|
step := 2
|
|
for i := 0; i < len(msgs); i += step {
|
|
resp, err := keeper.RedeemClaimAll(wctx, request(nil, uint64(i), uint64(step), false))
|
|
require.NoError(t, err)
|
|
require.LessOrEqual(t, len(resp.RedeemClaim), step)
|
|
require.Subset(t,
|
|
nullify.Fill(msgs),
|
|
nullify.Fill(resp.RedeemClaim),
|
|
)
|
|
}
|
|
})
|
|
t.Run("ByKey", func(t *testing.T) {
|
|
step := 2
|
|
var next []byte
|
|
for i := 0; i < len(msgs); i += step {
|
|
resp, err := keeper.RedeemClaimAll(wctx, request(next, 0, uint64(step), false))
|
|
require.NoError(t, err)
|
|
require.LessOrEqual(t, len(resp.RedeemClaim), step)
|
|
require.Subset(t,
|
|
nullify.Fill(msgs),
|
|
nullify.Fill(resp.RedeemClaim),
|
|
)
|
|
next = resp.Pagination.NextKey
|
|
}
|
|
})
|
|
t.Run("Total", func(t *testing.T) {
|
|
resp, err := keeper.RedeemClaimAll(wctx, request(nil, 0, 0, true))
|
|
require.NoError(t, err)
|
|
require.Equal(t, len(msgs), int(resp.Pagination.Total))
|
|
require.ElementsMatch(t,
|
|
nullify.Fill(msgs),
|
|
nullify.Fill(resp.RedeemClaim),
|
|
)
|
|
})
|
|
t.Run("InvalidRequest", func(t *testing.T) {
|
|
_, err := keeper.RedeemClaimAll(wctx, nil)
|
|
require.ErrorIs(t, err, status.Error(codes.InvalidArgument, "invalid request"))
|
|
})
|
|
}
|