Skip to content

Commit

Permalink
rename native amount and host zone unbonding status (#1071)
Browse files Browse the repository at this point in the history
  • Loading branch information
sampocs authored Jan 11, 2024
1 parent 4b4b19a commit 9914611
Show file tree
Hide file tree
Showing 26 changed files with 146 additions and 151 deletions.
2 changes: 1 addition & 1 deletion app/upgrades/v17/upgrades.go
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,7 @@ func MigrateUnbondingRecords(ctx sdk.Context, k stakeibckeeper.Keeper) error {
continue
}

userRedemptionRecord.StTokenAmount = estimatedStTokenConversionRate.Mul(sdk.NewDecFromInt(userRedemptionRecord.Amount)).RoundInt()
userRedemptionRecord.StTokenAmount = estimatedStTokenConversionRate.Mul(sdk.NewDecFromInt(userRedemptionRecord.NativeTokenAmount)).RoundInt()
k.RecordsKeeper.SetUserRedemptionRecord(ctx, userRedemptionRecord)
}
}
Expand Down
4 changes: 2 additions & 2 deletions app/upgrades/v17/upgrades_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -220,8 +220,8 @@ func (s *UpgradeTestSuite) SetupMigrateUnbondingRecords() func() {
for i := 1; i <= 6; i++ {
mockURRId := strconv.Itoa(i)
mockURR := recordtypes.UserRedemptionRecord{
Id: mockURRId,
Amount: sdkmath.NewInt(URRAmount),
Id: mockURRId,
NativeTokenAmount: sdkmath.NewInt(URRAmount),
}
s.App.RecordsKeeper.SetUserRedemptionRecord(s.Ctx, mockURR)
}
Expand Down
2 changes: 1 addition & 1 deletion app/upgrades/v5/upgrades_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -329,7 +329,7 @@ func (s *UpgradeTestSuite) SetupOldRecordStore(codec codec.Codec) func() {
userRedemptionRecord, found := s.App.RecordsKeeper.GetUserRedemptionRecord(s.Ctx, userRedemptionRecordId)
s.Require().True(found, "redemption record found")
s.Require().Equal(userRedemptionRecord.Id, userRedemptionRecordId, "redemption record id")
s.Require().Equal(userRedemptionRecord.Amount, sdkmath.NewInt(1000000), "redemption record amount")
s.Require().Equal(userRedemptionRecord.NativeTokenAmount, sdkmath.NewInt(1000000), "redemption record amount")

epochUnbondingRecord, found := s.App.RecordsKeeper.GetEpochUnbondingRecord(s.Ctx, epochNumber)
s.Require().True(found, "epoch unbonding record found")
Expand Down
14 changes: 5 additions & 9 deletions dockernet/tests/integration_tests.bats
Original file line number Diff line number Diff line change
Expand Up @@ -371,8 +371,8 @@ setup_file() {
WAIT_FOR_BLOCK $STRIDE_LOGS 5

# check that a user redemption record was created
redemption_record_amount=$($STRIDE_MAIN_CMD q records list-user-redemption-record | grep -Fiw 'amount' | head -n 1 | grep -o -E '[0-9]+')
amount_positive=$(($redemption_record_amount > 0))
redemption_record_native_amount=$($STRIDE_MAIN_CMD q records list-user-redemption-record | grep -Fiw 'native_token_amount' | head -n 1 | grep -o -E '[0-9]+')
amount_positive=$(($redemption_record_native_amount > 0))
assert_equal "$amount_positive" "1"

# attempt to redeem with an invalid receiver address to invoke a failure
Expand All @@ -397,16 +397,12 @@ setup_file() {

# Check that the redemption record created from the autopilot redeem above was incremented
# and that there is still only one record
num_records=$($STRIDE_MAIN_CMD q records list-user-redemption-record | grep -c "amount")
num_records=$($STRIDE_MAIN_CMD q records list-user-redemption-record | grep -c "native_token_amount")
assert_equal "$num_records" "1"

# The amount in the redemption record is denominated in native tokens, but amount in the
# redeem message is denominated in stTokens (and the redemption rate may be greater than 1)
# So when checking the amount, we make sure the amount in the record is greater than or
# equal to 2 * REDEEM_AMOUNT (since there were two redemptions - one from autopilot, one here)
redemption_record_amount=$($STRIDE_MAIN_CMD q records list-user-redemption-record | grep -Fiw 'amount' | head -n 1 | grep -o -E '[0-9]+')
redemption_record_st_amount=$($STRIDE_MAIN_CMD q records list-user-redemption-record | grep -Fiw 'st_token_amount' | head -n 1 | grep -o -E '[0-9]+')
expected_record_minimum=$(echo "$REDEEM_AMOUNT * 2" | bc)
assert_equal "$(($redemption_record_amount >= $expected_record_minimum))" "1"
assert_equal "$redemption_record_st_amount" "$expected_record_minimum"

WAIT_FOR_STRING $STRIDE_LOGS "\[REDEMPTION] completed on $HOST_CHAIN_ID"
WAIT_FOR_BLOCK $STRIDE_LOGS 2
Expand Down
2 changes: 1 addition & 1 deletion proto/stride/records/records.proto
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ option go_package = "github.com/Stride-Labs/stride/v17/x/records/types";
message UserRedemptionRecord {
string id = 1; // {chain_id}.{epoch}.{receiver}
string receiver = 3;
string amount = 4 [
string native_token_amount = 4 [
(gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Int",
(gogoproto.nullable) = false
];
Expand Down
2 changes: 1 addition & 1 deletion readme-docs/md/records_README.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ Epoch Unbonding Records
- `GetAllPreviousEpochUnbondingRecords()`
- `GetHostZoneUnbondingByChainId()`
- `AddHostZoneToEpochUnbondingRecord()`
- `SetHostZoneUnbondings()`
- `SetHostZoneUnbondingStatus()`

User Redemption Records
- `SetUserRedemptionRecord()`
Expand Down
2 changes: 1 addition & 1 deletion x/records/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ Epoch Unbonding Records
- `GetAllPreviousEpochUnbondingRecords()`
- `GetHostZoneUnbondingByChainId()`
- `AddHostZoneToEpochUnbondingRecord()`
- `SetHostZoneUnbondings()`
- `SetHostZoneUnbondingStatus()`

User Redemption Records

Expand Down
6 changes: 3 additions & 3 deletions x/records/client/cli/query_user_redemption_record_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,9 +29,9 @@ func networkWithUserRedemptionRecordObjects(t *testing.T, n int) (*network.Netwo

for i := 0; i < n; i++ {
userRedemptionRecord := types.UserRedemptionRecord{
Id: strconv.Itoa(i),
Amount: sdkmath.NewInt(int64(i)),
StTokenAmount: sdkmath.NewInt(int64(i)),
Id: strconv.Itoa(i),
NativeTokenAmount: sdkmath.NewInt(int64(i)),
StTokenAmount: sdkmath.NewInt(int64(i)),
}
nullify.Fill(&userRedemptionRecord)
state.UserRedemptionRecordList = append(state.UserRedemptionRecordList, userRedemptionRecord)
Expand Down
3 changes: 1 addition & 2 deletions x/records/keeper/epoch_unbonding_record.go
Original file line number Diff line number Diff line change
Expand Up @@ -133,8 +133,7 @@ func (k Keeper) SetHostZoneUnbondingRecord(ctx sdk.Context, epochNumber uint64,
}

// Updates the status for a given host zone across relevant epoch unbonding record IDs
// TODO [cleanup]: Rename to SetHostZoneUnbondingStatus
func (k Keeper) SetHostZoneUnbondings(ctx sdk.Context, chainId string, epochUnbondingRecordIds []uint64, status types.HostZoneUnbonding_Status) error {
func (k Keeper) SetHostZoneUnbondingStatus(ctx sdk.Context, chainId string, epochUnbondingRecordIds []uint64, status types.HostZoneUnbonding_Status) error {
for _, epochUnbondingRecordId := range epochUnbondingRecordIds {
k.Logger(ctx).Info(fmt.Sprintf("Updating host zone unbondings on EpochUnbondingRecord %d to status %s", epochUnbondingRecordId, status.String()))
// fetch the host zone unbonding
Expand Down
4 changes: 2 additions & 2 deletions x/records/keeper/epoch_unbonding_record_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,7 @@ func TestAddHostZoneToEpochUnbondingRecord(t *testing.T) {
)
}

func TestSetHostZoneUnbondings(t *testing.T) {
func TestSetHostZoneUnbondingStatus(t *testing.T) {
keeper, ctx := keepertest.RecordsKeeper(t)

initialEpochUnbondingRecords, _ := createNEpochUnbondingRecord(keeper, ctx, 4)
Expand All @@ -161,7 +161,7 @@ func TestSetHostZoneUnbondings(t *testing.T) {
}
}

err := keeper.SetHostZoneUnbondings(ctx, hostIdToUpdate, epochsToUpdate, newStatus)
err := keeper.SetHostZoneUnbondingStatus(ctx, hostIdToUpdate, epochsToUpdate, newStatus)
require.Nil(t, err)

actualEpochUnbondingRecord := keeper.GetAllEpochUnbondingRecord(ctx)
Expand Down
2 changes: 1 addition & 1 deletion x/records/keeper/user_redemption_record_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ func createNUserRedemptionRecord(keeper *keeper.Keeper, ctx sdk.Context, n int)
items := make([]types.UserRedemptionRecord, n)
for i := range items {
items[i].Id = strconv.Itoa(i)
items[i].Amount = sdkmath.NewInt(int64(i))
items[i].NativeTokenAmount = sdkmath.NewInt(int64(i))
items[i].StTokenAmount = sdkmath.NewInt(int64(i))
keeper.SetUserRedemptionRecord(ctx, items[i])
}
Expand Down
12 changes: 6 additions & 6 deletions x/records/migrations/v2/convert.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,11 +44,11 @@ func convertToNewUserRedemptionRecord(oldRedemptionRecord oldrecordstypes.UserRe
return recordstypes.UserRedemptionRecord{
Id: oldRedemptionRecord.Id,
// Sender: oldRedemptionRecord.Sender,
Receiver: oldRedemptionRecord.Receiver,
Amount: sdkmath.NewIntFromUint64(oldRedemptionRecord.Amount),
Denom: oldRedemptionRecord.Denom,
HostZoneId: oldRedemptionRecord.HostZoneId,
EpochNumber: oldRedemptionRecord.EpochNumber,
ClaimIsPending: oldRedemptionRecord.ClaimIsPending,
Receiver: oldRedemptionRecord.Receiver,
NativeTokenAmount: sdkmath.NewIntFromUint64(oldRedemptionRecord.Amount),
Denom: oldRedemptionRecord.Denom,
HostZoneId: oldRedemptionRecord.HostZoneId,
EpochNumber: oldRedemptionRecord.EpochNumber,
ClaimIsPending: oldRedemptionRecord.ClaimIsPending,
}
}
10 changes: 5 additions & 5 deletions x/records/migrations/v2/convert_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -123,11 +123,11 @@ func TestConvertUserRedemptionRecord(t *testing.T) {
Id: id,
Receiver: receiver,
// Sender: sender,
Amount: sdkmath.NewInt(1),
Denom: denom,
HostZoneId: hostZoneId,
EpochNumber: epochNumber,
ClaimIsPending: claimIsPending,
NativeTokenAmount: sdkmath.NewInt(1),
Denom: denom,
HostZoneId: hostZoneId,
EpochNumber: epochNumber,
ClaimIsPending: claimIsPending,
}

actualNewUserRedemptionRecord := convertToNewUserRedemptionRecord(oldUserRedemptionRecord)
Expand Down
Loading

0 comments on commit 9914611

Please sign in to comment.