Skip to content

Commit

Permalink
Merge pull request #296 from arkeonetwork/fix_thor_mainnet
Browse files Browse the repository at this point in the history
fix: thor mainnet error
  • Loading branch information
shreyasbhat0 authored Oct 17, 2024
2 parents b9658d5 + 002ddc3 commit deb1b73
Showing 13 changed files with 88 additions and 11 deletions.
2 changes: 1 addition & 1 deletion .goreleaser-cross.yaml
Original file line number Diff line number Diff line change
@@ -134,7 +134,7 @@ archives:
- none*

checksum:
name_template: '{{ .ProjectName }}d_v{{ .Version }}_{{ if eq .Env.BUILD_TAG "testnet" }}_testnet{{ end }}_cross_checksums.txt'
name_template: '{{ .ProjectName }}d_v{{ .Version }}_{{ if eq .Env.BUILD_TAG "testnet" }}testnet{{ end }}_cross_checksums.txt'

dockers:
- use: buildx
2 changes: 1 addition & 1 deletion .goreleaser.yaml
Original file line number Diff line number Diff line change
@@ -60,7 +60,7 @@ archives:
files:
- none*
checksum:
name_template: '{{ .ProjectName }}d_v{{ .Version }}_{{ if eq .Env.BUILD_TAG "testnet" }}_testnet{{ end }}_checksums.txt'
name_template: '{{ .ProjectName }}d_v{{ .Version }}_{{ if eq .Env.BUILD_TAG "testnet" }}testnet{{ end }}_checksums.txt'
dockers:
- use: buildx
goos: linux
11 changes: 11 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -28,6 +28,16 @@ Contains bug fixes.
Contains all the PRs that improved the code without changing the behaviors.
-->

# v1.0.2-Prerelease

## Added

## Changed
- Updated thorchain claim server address handling

## Fixed
- Fixed Regression Test Version Issues

# v1.0.1-Prerelease

## Added
@@ -61,6 +71,7 @@ Contains all the PRs that improved the code without changing the behaviors.
- Updated Tests on arkeo module keeper
- version issue on begin blocker
- Fixed Genesis Url
- Fixed thorchain claim server address mainnet

# v1.0.0-Prerelease

1 change: 1 addition & 0 deletions test/regression/cmd/export.go
Original file line number Diff line number Diff line change
@@ -44,6 +44,7 @@ func export(path string) error {
appState, _ := export["app_state"].(map[string]any)
claimArkeo, _ := appState["claimarkeo"].(map[string]any)
params, _ := claimArkeo["params"].(map[string]any)
delete(export, "app_version")
delete(params, "airdrop_start_time")
staking, _ := appState["staking"].(map[string]any)
validators, _ := staking["validators"].([]any)
Original file line number Diff line number Diff line change
@@ -690,7 +690,6 @@
"upgrade": {},
"vesting": {}
},
"app_version": "v1.0.0-prerelease",
"chain_id": "arkeo",
"consensus": {
"params": {
Original file line number Diff line number Diff line change
@@ -708,7 +708,6 @@
"upgrade": {},
"vesting": {}
},
"app_version": "v1.0.0-prerelease",
"chain_id": "arkeo",
"consensus": {
"params": {
1 change: 0 additions & 1 deletion test/regression/mnt/exports/suites_core_send.json
Original file line number Diff line number Diff line change
@@ -583,7 +583,6 @@
"upgrade": {},
"vesting": {}
},
"app_version": "v1.0.0-prerelease",
"chain_id": "arkeo",
"consensus": {
"params": {
1 change: 0 additions & 1 deletion test/regression/mnt/exports/suites_initialize.json
Original file line number Diff line number Diff line change
@@ -580,7 +580,6 @@
"upgrade": {},
"vesting": {}
},
"app_version": "v1.0.0-prerelease",
"chain_id": "arkeo",
"consensus": {
"params": {
Original file line number Diff line number Diff line change
@@ -594,7 +594,6 @@
"upgrade": {},
"vesting": {}
},
"app_version": "v1.0.0-prerelease",
"chain_id": "arkeo",
"consensus": {
"params": {
Original file line number Diff line number Diff line change
@@ -667,7 +667,6 @@
"upgrade": {},
"vesting": {}
},
"app_version": "v1.0.0-prerelease",
"chain_id": "arkeo",
"consensus": {
"params": {
1 change: 0 additions & 1 deletion test/regression/mnt/exports/suites_sentinel_sentinel.json
Original file line number Diff line number Diff line change
@@ -560,7 +560,6 @@
"upgrade": {},
"vesting": {}
},
"app_version": "v1.0.0-prerelease",
"chain_id": "arkeo",
"consensus": {
"params": {
2 changes: 1 addition & 1 deletion x/claim/keeper/msg_server_claim_thorchain.go
Original file line number Diff line number Diff line change
@@ -15,7 +15,7 @@ func (k msgServer) ClaimThorchain(goCtx context.Context, msg *types.MsgClaimThor
k.Logger(ctx).Info(msg.Creator)

// only allow thorchain claim server address to call this function
if msg.Creator != "tarkeo1z02ke8639m47g9dfrheegr2u9zecegt5qvtj00" || msg.Creator == "arkeo1z02ke8639m47g9dfrheegr2u9zecegt50fjg7v" {
if msg.Creator != "tarkeo1z02ke8639m47g9dfrheegr2u9zecegt5qvtj00" && msg.Creator != "arkeo1z02ke8639m47g9dfrheegr2u9zecegt50fjg7v" {
return nil, errors.Wrapf(types.ErrInvalidCreator, "Invalid Creator %s", msg.Creator)
}

74 changes: 73 additions & 1 deletion x/claim/keeper/msg_server_claim_thorchain_test.go
Original file line number Diff line number Diff line change
@@ -10,7 +10,7 @@ import (
"github.com/arkeonetwork/arkeo/x/claim/types"
)

func TestClaimThorchain(t *testing.T) {
func TestClaimThorchainTestnetAddress(t *testing.T) {
msgServer, keepers, ctx := setupMsgServer(t)
sdkCtx := sdk.UnwrapSDKContext(ctx)

@@ -81,3 +81,75 @@ func TestClaimThorchain(t *testing.T) {
_, err = msgServer.ClaimThorchain(ctx, &claimMessage)
require.ErrorIs(t, err, types.ErrNoClaimableAmount)
}

func TestClaimThorchainMainnetAddress(t *testing.T) {
msgServer, keepers, ctx := setupMsgServer(t)
sdkCtx := sdk.UnwrapSDKContext(ctx)

config := sdk.GetConfig()
config.SetBech32PrefixForAccount("arkeo", "arkeopub")

arkeoServerAddress, err := sdk.AccAddressFromBech32("arkeo1z02ke8639m47g9dfrheegr2u9zecegt50fjg7v")
require.NoError(t, err)

fromAddr := utils.GetRandomArkeoAddress()
toAddr := utils.GetRandomArkeoAddress()

claimRecordFrom := types.ClaimRecord{
Chain: types.ARKEO,
Address: fromAddr.String(),
AmountClaim: sdk.NewInt64Coin(types.DefaultClaimDenom, 100),
AmountVote: sdk.NewInt64Coin(types.DefaultClaimDenom, 100),
AmountDelegate: sdk.NewInt64Coin(types.DefaultClaimDenom, 100),
}
claimRecordTo := types.ClaimRecord{
Chain: types.ARKEO,
Address: toAddr.String(),
AmountClaim: sdk.NewInt64Coin(types.DefaultClaimDenom, 100),
AmountVote: sdk.NewInt64Coin(types.DefaultClaimDenom, 100),
AmountDelegate: sdk.NewInt64Coin(types.DefaultClaimDenom, 100),
}
err = keepers.ClaimKeeper.SetClaimRecord(sdkCtx, claimRecordFrom)
require.NoError(t, err)
err = keepers.ClaimKeeper.SetClaimRecord(sdkCtx, claimRecordTo)
require.NoError(t, err)

// mint coins to module account
err = keepers.BankKeeper.MintCoins(sdkCtx, types.ModuleName, sdk.NewCoins(sdk.NewInt64Coin(types.DefaultClaimDenom, 10000)))
require.NoError(t, err)

invalidClaimMessage := types.MsgClaimThorchain{
Creator: fromAddr.String(),
FromAddress: fromAddr.String(),
ToAddress: toAddr.String(),
}
_, err = msgServer.ClaimThorchain(ctx, &invalidClaimMessage)
require.ErrorIs(t, types.ErrInvalidCreator, err)

claimMessage := types.MsgClaimThorchain{
Creator: arkeoServerAddress.String(),
FromAddress: fromAddr.String(),
ToAddress: toAddr.String(),
}
_, err = msgServer.ClaimThorchain(ctx, &claimMessage)
require.NoError(t, err)

// check if claimrecord is updated
claimRecordFrom, err = keepers.ClaimKeeper.GetClaimRecord(sdkCtx, fromAddr.String(), types.ARKEO)
require.NoError(t, err)
require.True(t, claimRecordFrom.IsEmpty())

claimRecordTo, err = keepers.ClaimKeeper.GetClaimRecord(sdkCtx, toAddr.String(), types.ARKEO)
require.NoError(t, err)
require.True(t, !claimRecordTo.IsEmpty())

require.Equal(t, claimRecordTo.Address, toAddr.String())
require.Equal(t, claimRecordTo.Chain, types.ARKEO)
require.Equal(t, claimRecordTo.AmountClaim, sdk.NewInt64Coin(types.DefaultClaimDenom, 200))
require.Equal(t, claimRecordTo.AmountVote, sdk.NewInt64Coin(types.DefaultClaimDenom, 200))
require.Equal(t, claimRecordTo.AmountDelegate, sdk.NewInt64Coin(types.DefaultClaimDenom, 200))

// attempt to claim again to ensure it fails.
_, err = msgServer.ClaimThorchain(ctx, &claimMessage)
require.ErrorIs(t, err, types.ErrNoClaimableAmount)
}

0 comments on commit deb1b73

Please sign in to comment.