-
Notifications
You must be signed in to change notification settings - Fork 56
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Custom log index for sei chain (#1592)
Patch with minor adjustments from the chainlink repo [PR](smartcontractkit/chainlink#15858). Adjustments were caused by differences between repos. It's easier to do&review them than to apply all the changes made to chainlink repo that included MultiNode abstraction with 5k lines changed.
- Loading branch information
1 parent
a95f09e
commit 9947770
Showing
13 changed files
with
394 additions
and
41 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
"chainlink": patch | ||
--- | ||
|
||
#added Sei config and error mapping |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
ChainID = '1328' | ||
ChainType = 'sei' | ||
# finality_depth: instant | ||
FinalityDepth = 10 | ||
# block_time: ~0.4s, adding 1 second buffer | ||
LogPollInterval = '2s' | ||
# finality_depth * block_time / 60 secs = ~0.8 min (finality time) | ||
NoNewFinalizedHeadsThreshold = '5m' | ||
# "RPC node returned multiple missing blocks on query for block numbers [31592085 31592084] even though the WS subscription already sent us these blocks. It might help to increase EVM.RPCBlockQueryDelay (currently 1)" | ||
RPCBlockQueryDelay = 5 | ||
|
||
[GasEstimator] | ||
EIP1559DynamicFees = false | ||
Mode = 'BlockHistory' | ||
PriceMax = '3000 gwei' # recommended by ds&a | ||
|
||
[GasEstimator.BlockHistory] | ||
BlockHistorySize = 200 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
//go:build !amd64 && !arm64 | ||
package build | ||
"non-64-bits architectures are not supported" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -144,6 +144,7 @@ func Test_Eth_Errors(t *testing.T) { | |
{"client error transaction already in mempool", true, "tomlConfig"}, | ||
{"alreadyknown", true, "Gnosis"}, | ||
{"failed to forward tx to sequencer, please try again. Error message: 'already known'", true, "Mantle"}, | ||
{"tx already exists in cache", true, "Sei"}, | ||
} | ||
for _, test := range tests { | ||
err = evmclient.NewSendErrorS(test.message) | ||
|
@@ -420,6 +421,11 @@ func Test_Eth_Errors_Fatal(t *testing.T) { | |
{"client error fatal", true, "tomlConfig"}, | ||
{"[Request ID: d9711488-4c1e-4af2-bc1f-7969913d7b60] Error invoking RPC: transaction [email protected] failed precheck with status INVALID_SIGNATURE", true, "hedera"}, | ||
{"invalid chain id for signer", true, "Treasure"}, | ||
|
||
{": out of gas", true, "Sei"}, | ||
{"Tx too large. Max size is 2048576, but got 2097431", true, "Sei"}, | ||
{": insufficient funds", true, "Sei"}, | ||
{"insufficient fee", true, "Sei"}, | ||
} | ||
|
||
for _, test := range tests { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
package client | ||
|
||
import ( | ||
"errors" | ||
"math" | ||
"testing" | ||
|
||
ethtypes "github.com/ethereum/go-ethereum/core/types" | ||
"github.com/stretchr/testify/require" | ||
|
||
commonclient "github.com/smartcontractkit/chainlink/v2/common/client" | ||
"github.com/smartcontractkit/chainlink/v2/core/chains/evm/config/chaintype" | ||
"github.com/smartcontractkit/chainlink/v2/core/logger" | ||
) | ||
|
||
func TestRPCClient_MakeLogsValid(t *testing.T) { | ||
testCases := []struct { | ||
Name string | ||
TxIndex uint | ||
LogIndex uint | ||
ExpectedLogIndex uint | ||
ExpectedError error | ||
}{ | ||
{ | ||
Name: "TxIndex = 0 LogIndex = 0", | ||
TxIndex: 0, | ||
LogIndex: 0, | ||
ExpectedLogIndex: 0, | ||
ExpectedError: nil, | ||
}, | ||
{ | ||
Name: "TxIndex = 0 LogIndex = 1", | ||
TxIndex: 0, | ||
LogIndex: 1, | ||
ExpectedLogIndex: 1, | ||
ExpectedError: nil, | ||
}, | ||
{ | ||
Name: "TxIndex = 0 LogIndex = MaxUint32", | ||
TxIndex: 0, | ||
LogIndex: math.MaxUint32, | ||
ExpectedLogIndex: math.MaxUint32, | ||
ExpectedError: nil, | ||
}, | ||
{ | ||
Name: "LogIndex = MaxUint32 + 1 => returns an error", | ||
TxIndex: 0, | ||
LogIndex: math.MaxUint32 + 1, | ||
ExpectedLogIndex: 0, | ||
ExpectedError: errors.New("log's index 4294967296 of tx 0x0000000000000000000000000000000000000000000000000000000000000000 exceeds max supported value of 4294967295"), | ||
}, | ||
{ | ||
Name: "TxIndex = 1 LogIndex = 0", | ||
TxIndex: 1, | ||
LogIndex: 0, | ||
ExpectedLogIndex: math.MaxUint32 + 1, | ||
ExpectedError: nil, | ||
}, | ||
{ | ||
Name: "TxIndex = MaxUint32 LogIndex = MaxUint32", | ||
TxIndex: math.MaxUint32, | ||
LogIndex: math.MaxUint32, | ||
ExpectedLogIndex: math.MaxUint64, | ||
ExpectedError: nil, | ||
}, | ||
{ | ||
Name: "TxIndex = MaxUint32 + 1 => returns an error", | ||
TxIndex: math.MaxUint32 + 1, | ||
LogIndex: 0, | ||
ExpectedLogIndex: 0, | ||
ExpectedError: errors.New("TxIndex of tx 0x0000000000000000000000000000000000000000000000000000000000000000 exceeds max supported value of 4294967295"), | ||
}, | ||
} | ||
for _, tc := range testCases { | ||
t.Run(tc.Name, func(t *testing.T) { | ||
rpc := newRPCClient(logger.TestLogger(t), nil, nil, "eth-primary-rpc-0", 0, nil, commonclient.Primary, 0, 0, commonclient.QueryTimeout, commonclient.QueryTimeout, "") | ||
log, err := rpc.makeLogValid(ethtypes.Log{TxIndex: tc.TxIndex, Index: tc.LogIndex}) | ||
// non sei should return as is | ||
require.NoError(t, err) | ||
require.Equal(t, tc.TxIndex, log.TxIndex) | ||
require.Equal(t, tc.LogIndex, log.Index) | ||
seiRPC := newRPCClient(logger.TestLogger(t), nil, nil, "eth-primary-rpc-0", 0, nil, commonclient.Primary, 0, 0, commonclient.QueryTimeout, commonclient.QueryTimeout, chaintype.ChainSei) | ||
log, err = seiRPC.makeLogValid(ethtypes.Log{TxIndex: tc.TxIndex, Index: tc.LogIndex}) | ||
if tc.ExpectedError != nil { | ||
require.EqualError(t, err, tc.ExpectedError.Error()) | ||
return | ||
} | ||
|
||
require.Equal(t, tc.ExpectedLogIndex, log.Index) | ||
require.Equal(t, tc.TxIndex, log.TxIndex) | ||
}) | ||
} | ||
} |
Oops, something went wrong.