Skip to content

Commit

Permalink
Reorder tx results into absolute order (sei-protocol#1018)
Browse files Browse the repository at this point in the history
* Reorder tx results into absolute order

* remove TODO
  • Loading branch information
udpatil authored Aug 7, 2023
1 parent 6265551 commit 6a7ba94
Show file tree
Hide file tree
Showing 2 changed files with 75 additions and 17 deletions.
25 changes: 15 additions & 10 deletions app/app.go
Original file line number Diff line number Diff line change
Expand Up @@ -1246,8 +1246,8 @@ func (app *App) ProcessTxs(
return txResults, ctx
}

func (app *App) PartitionPrioritizedTxs(ctx sdk.Context, txs [][]byte) (prioritizedTxs, otherTxs [][]byte) {
for _, tx := range txs {
func (app *App) PartitionPrioritizedTxs(ctx sdk.Context, txs [][]byte) (prioritizedTxs, otherTxs [][]byte, prioritizedIndices, otherIndices []int) {
for idx, tx := range txs {
decodedTx, err := app.txDecoder(tx)
if err != nil {
ctx.Logger().Error(fmt.Sprintf("Error decoding tx for partitioning: %v", err))
Expand All @@ -1256,7 +1256,7 @@ func (app *App) PartitionPrioritizedTxs(ctx sdk.Context, txs [][]byte) (prioriti
continue
}
prioritized := false
// if theres a prioritized msg, we want to add to prioritizedTxs
// if all messages are prioritized, we want to add to prioritizedTxs
msgLoop:
for _, msg := range decodedTx.GetMsgs() {
switch msg.(type) {
Expand All @@ -1275,12 +1275,14 @@ func (app *App) PartitionPrioritizedTxs(ctx sdk.Context, txs [][]byte) (prioriti
}
if prioritized {
prioritizedTxs = append(prioritizedTxs, tx)
prioritizedIndices = append(prioritizedIndices, idx)
} else {
otherTxs = append(otherTxs, tx)
otherIndices = append(otherIndices, idx)
}

}
return prioritizedTxs, otherTxs
return prioritizedTxs, otherTxs, prioritizedIndices, otherIndices
}

func (app *App) BuildDependenciesAndRunTxs(ctx sdk.Context, txs [][]byte) ([]*abci.ExecTxResult, sdk.Context) {
Expand Down Expand Up @@ -1334,13 +1336,14 @@ func (app *App) ProcessBlock(ctx sdk.Context, txs [][]byte, req BlockProcessRequ
beginBlockResp := app.BeginBlock(ctx, beginBlockReq)
events = append(events, beginBlockResp.Events...)

var txResults []*abci.ExecTxResult

prioritizedTxs, txs := app.PartitionPrioritizedTxs(ctx, txs)
txResults := make([]*abci.ExecTxResult, len(txs))
prioritizedTxs, otherTxs, prioritizedIndices, otherIndices := app.PartitionPrioritizedTxs(ctx, txs)

// run the prioritized txs
prioritizedResults, ctx := app.BuildDependenciesAndRunTxs(ctx, prioritizedTxs)
txResults = append(txResults, prioritizedResults...)
for relativePrioritizedIndex, originalIndex := range prioritizedIndices {
txResults[originalIndex] = prioritizedResults[relativePrioritizedIndex]
}

// Finalize all Bank Module Transfers here so that events are included for prioritiezd txs
deferredWriteEvents := app.BankKeeper.WriteDeferredBalances(ctx)
Expand All @@ -1349,8 +1352,10 @@ func (app *App) ProcessBlock(ctx sdk.Context, txs [][]byte, req BlockProcessRequ
midBlockEvents := app.MidBlock(ctx, req.GetHeight())
events = append(events, midBlockEvents...)

otherResults, ctx := app.BuildDependenciesAndRunTxs(ctx, txs)
txResults = append(txResults, otherResults...)
otherResults, ctx := app.BuildDependenciesAndRunTxs(ctx, otherTxs)
for relativeOtherIndex, originalIndex := range otherIndices {
txResults[originalIndex] = otherResults[relativeOtherIndex]
}

// Finalize all Bank Module Transfers here so that events are included
lazyWriteEvents := app.BankKeeper.WriteDeferredBalances(ctx)
Expand Down
67 changes: 60 additions & 7 deletions app/app_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,15 @@ package app_test

import (
"context"
"fmt"
"testing"
"time"

"github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
sdk "github.com/cosmos/cosmos-sdk/types"
sdkacltypes "github.com/cosmos/cosmos-sdk/types/accesscontrol"
acltypes "github.com/cosmos/cosmos-sdk/x/accesscontrol/types"
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types"
"github.com/k0kubun/pp/v3"
"github.com/sei-protocol/sei-chain/app"
Expand Down Expand Up @@ -191,18 +193,37 @@ func TestPartitionPrioritizedTxs(t *testing.T) {
mixedTx,
}

prioritizedTxs, otherTxs := testWrapper.App.PartitionPrioritizedTxs(testWrapper.Ctx, txs)
require.Equal(t, prioritizedTxs, [][]byte{oracleTx, contractRegisterTx, contractUnregisterTx, contractSuspendTx})
require.Equal(t, otherTxs, [][]byte{otherTx, mixedTx})
prioritizedTxs, otherTxs, prioIdxs, otherIdxs := testWrapper.App.PartitionPrioritizedTxs(testWrapper.Ctx, txs)
require.Equal(t, [][]byte{oracleTx, contractRegisterTx, contractUnregisterTx, contractSuspendTx}, prioritizedTxs)
require.Equal(t, [][]byte{otherTx, mixedTx}, otherTxs)
require.Equal(t, []int{0, 1, 2, 3}, prioIdxs)
require.Equal(t, []int{4, 5}, otherIdxs)

diffOrderTxs := [][]byte{
oracleTx,
otherTx,
contractRegisterTx,
contractUnregisterTx,
mixedTx,
contractSuspendTx,
}

prioritizedTxs, otherTxs, prioIdxs, otherIdxs = testWrapper.App.PartitionPrioritizedTxs(testWrapper.Ctx, diffOrderTxs)
require.Equal(t, [][]byte{oracleTx, contractRegisterTx, contractUnregisterTx, contractSuspendTx}, prioritizedTxs)
require.Equal(t, [][]byte{otherTx, mixedTx}, otherTxs)
require.Equal(t, []int{0, 2, 3, 5}, prioIdxs)
require.Equal(t, []int{1, 4}, otherIdxs)
}

func TestProcessOracleAndOtherTxsSuccess(t *testing.T) {
tm := time.Now().UTC()
valPub := secp256k1.GenPrivKey().PubKey()
secondAcc := secp256k1.GenPrivKey().PubKey()

testWrapper := app.NewTestWrapper(t, tm, valPub)

account := sdk.AccAddress(valPub.Address()).String()
account2 := sdk.AccAddress(secondAcc.Address()).String()
validator := sdk.ValAddress(valPub.Address()).String()

oracleMsg := &oracletypes.MsgAggregateExchangeRateVote{
Expand All @@ -211,10 +232,10 @@ func TestProcessOracleAndOtherTxsSuccess(t *testing.T) {
Validator: validator,
}

otherMsg := &stakingtypes.MsgDelegate{
DelegatorAddress: account,
ValidatorAddress: validator,
Amount: sdk.NewCoin("usei", sdk.NewInt(1)),
otherMsg := &banktypes.MsgSend{
FromAddress: account,
ToAddress: account2,
Amount: sdk.NewCoins(sdk.NewInt64Coin("usei", 2)),
}

oracleTxBuilder := app.MakeEncodingConfig().TxConfig.NewTxBuilder()
Expand All @@ -223,11 +244,15 @@ func TestProcessOracleAndOtherTxsSuccess(t *testing.T) {

err := oracleTxBuilder.SetMsgs(oracleMsg)
require.NoError(t, err)
oracleTxBuilder.SetGasLimit(200000)
oracleTxBuilder.SetFeeAmount(sdk.NewCoins(sdk.NewInt64Coin("usei", 20000)))
oracleTx, err := txEncoder(oracleTxBuilder.GetTx())
require.NoError(t, err)

err = otherTxBuilder.SetMsgs(otherMsg)
require.NoError(t, err)
otherTxBuilder.SetGasLimit(100000)
otherTxBuilder.SetFeeAmount(sdk.NewCoins(sdk.NewInt64Coin("usei", 10000)))
otherTx, err := txEncoder(otherTxBuilder.GetTx())
require.NoError(t, err)

Expand All @@ -249,8 +274,36 @@ func TestProcessOracleAndOtherTxsSuccess(t *testing.T) {
req,
req.DecidedLastCommit,
)
fmt.Println("txResults1", txResults)

require.Equal(t, 2, len(txResults))
require.Equal(t, uint32(3), txResults[0].Code)
require.Equal(t, uint32(5), txResults[1].Code)

diffOrderTxs := [][]byte{
otherTx,
oracleTx,
}

req = &abci.RequestFinalizeBlock{
Height: 1,
}
_, txResults2, _, _ := testWrapper.App.ProcessBlock(
testWrapper.Ctx.WithBlockHeight(
1,
).WithBlockGasMeter(
sdk.NewInfiniteGasMeter(),
),
diffOrderTxs,
req,
req.DecidedLastCommit,
)
fmt.Println("txResults2", txResults2)

require.Equal(t, 2, len(txResults2))
// opposite ordering due to true index ordering
require.Equal(t, uint32(5), txResults2[0].Code)
require.Equal(t, uint32(3), txResults2[1].Code)
}

func TestInvalidProposalWithExcessiveGasWanted(t *testing.T) {
Expand Down

0 comments on commit 6a7ba94

Please sign in to comment.