Skip to content

Commit

Permalink
fix linter issues
Browse files Browse the repository at this point in the history
  • Loading branch information
jmank88 committed Nov 18, 2024
1 parent f08e800 commit 2352b69
Show file tree
Hide file tree
Showing 25 changed files with 150 additions and 83 deletions.
2 changes: 0 additions & 2 deletions deployment/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@ module github.com/smartcontractkit/chainlink/deployment

go 1.23

toolchain go1.23.0

// Make sure we're working with the latest chainlink libs
replace github.com/smartcontractkit/chainlink/v2 => ../

Expand Down
26 changes: 16 additions & 10 deletions integration-tests/actions/actions.go
Original file line number Diff line number Diff line change
Expand Up @@ -350,27 +350,33 @@ func SendFunds(logger zerolog.Logger, client *seth.Client, payload FundsToSendPa
return nil, err
}

var gasLimit int64
var gasLimit uint64
gasLimitRaw, err := client.EstimateGasLimitForFundTransfer(fromAddress, payload.ToAddress, payload.Amount)
if err != nil {
gasLimit = client.Cfg.Network.TransferGasFee
if client.Cfg.Network.TransferGasFee < 0 {
return nil, fmt.Errorf("negative transfer gas fee: %d", client.Cfg.Network.TransferGasFee)
}
gasLimit = uint64(client.Cfg.Network.TransferGasFee)
} else {
gasLimit = int64(gasLimitRaw)
gasLimit = gasLimitRaw
}

gasPrice := big.NewInt(0)
gasFeeCap := big.NewInt(0)
gasTipCap := big.NewInt(0)

if payload.GasLimit != nil {
gasLimit = *payload.GasLimit
if *payload.GasLimit < 0 {
return nil, fmt.Errorf("negative gas limit: %d", *payload.GasLimit)
}
gasLimit = uint64(*payload.GasLimit)
}

if client.Cfg.Network.EIP1559DynamicFees {
// if any of the dynamic fees are not set, we need to either estimate them or read them from config
if payload.GasFeeCap == nil || payload.GasTipCap == nil {
// estimation or config reading happens here
txOptions := client.NewTXOpts(seth.WithGasLimit(uint64(gasLimit)))
txOptions := client.NewTXOpts(seth.WithGasLimit(gasLimit))
gasFeeCap = txOptions.GasFeeCap
gasTipCap = txOptions.GasTipCap
}
Expand All @@ -385,7 +391,7 @@ func SendFunds(logger zerolog.Logger, client *seth.Client, payload FundsToSendPa
}
} else {
if payload.GasPrice == nil {
txOptions := client.NewTXOpts(seth.WithGasLimit(uint64(gasLimit)))
txOptions := client.NewTXOpts(seth.WithGasLimit(gasLimit))
gasPrice = txOptions.GasPrice
} else {
gasPrice = payload.GasPrice
Expand All @@ -399,7 +405,7 @@ func SendFunds(logger zerolog.Logger, client *seth.Client, payload FundsToSendPa
Nonce: nonce,
To: &payload.ToAddress,
Value: payload.Amount,
Gas: uint64(gasLimit),
Gas: gasLimit,
GasFeeCap: gasFeeCap,
GasTipCap: gasTipCap,
}
Expand All @@ -408,7 +414,7 @@ func SendFunds(logger zerolog.Logger, client *seth.Client, payload FundsToSendPa
Nonce: nonce,
To: &payload.ToAddress,
Value: payload.Amount,
Gas: uint64(gasLimit),
Gas: gasLimit,
GasPrice: gasPrice,
}
}
Expand All @@ -429,7 +435,7 @@ func SendFunds(logger zerolog.Logger, client *seth.Client, payload FundsToSendPa
Str("To", payload.ToAddress.Hex()).
Str("Amount (wei/ether)", fmt.Sprintf("%s/%s", payload.Amount, conversions.WeiToEther(payload.Amount).Text('f', -1))).
Uint64("Nonce", nonce).
Int64("Gas Limit", gasLimit).
Uint64("Gas Limit", gasLimit).
Str("Gas Price", gasPrice.String()).
Str("Gas Fee Cap", gasFeeCap.String()).
Str("Gas Tip Cap", gasTipCap.String()).
Expand All @@ -449,7 +455,7 @@ func SendFunds(logger zerolog.Logger, client *seth.Client, payload FundsToSendPa
Str("TxHash", signedTx.Hash().String()).
Str("Amount (wei/ether)", fmt.Sprintf("%s/%s", payload.Amount, conversions.WeiToEther(payload.Amount).Text('f', -1))).
Uint64("Nonce", nonce).
Int64("Gas Limit", gasLimit).
Uint64("Gas Limit", gasLimit).
Str("Gas Price", gasPrice.String()).
Str("Gas Fee Cap", gasFeeCap.String()).
Str("Gas Tip Cap", gasTipCap.String()).
Expand Down
5 changes: 5 additions & 0 deletions integration-tests/actions/automationv2/actions.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (
"encoding/json"
"errors"
"fmt"
"math"
"math/big"
"strings"
"testing"
Expand Down Expand Up @@ -642,6 +643,10 @@ func calculateOCR2ConfigArgs(a *AutomationTest, S []int, oracleIdentities []conf
MaxUpkeepBatchSize: a.PluginConfig.MaxUpkeepBatchSize,
})

if a.PublicConfig.RMax > math.MaxUint8 {
panic(fmt.Errorf("rmax overflows uint8: %d", a.PublicConfig.RMax))
}

return ocr2.ContractSetConfigArgsForTests(
a.PublicConfig.DeltaProgress, a.PublicConfig.DeltaResend,
a.PublicConfig.DeltaRound, a.PublicConfig.DeltaGrace,
Expand Down
15 changes: 7 additions & 8 deletions integration-tests/actions/keeper_helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -670,15 +670,14 @@ Distribute your funds across multiple private keys and update your configuration
func GetAndAssertCorrectConcurrency(client *seth.Client, minConcurrency int) (int, error) {
concurrency := client.Cfg.GetMaxConcurrency()

var msg string
if client.Cfg.IsSimulatedNetwork() {
msg = fmt.Sprintf(INSUFFICIENT_EPHEMERAL_KEYS, concurrency)
} else {
msg = fmt.Sprintf(INSUFFICIENT_STATIC_KEYS, concurrency)
}

if concurrency < minConcurrency {
return 0, fmt.Errorf(msg)
var err error
if client.Cfg.IsSimulatedNetwork() {
err = fmt.Errorf(INSUFFICIENT_EPHEMERAL_KEYS, concurrency)
} else {
err = fmt.Errorf(INSUFFICIENT_STATIC_KEYS, concurrency)
}
return 0, err
}

return concurrency, nil
Expand Down
2 changes: 1 addition & 1 deletion integration-tests/ccip-tests/actions/ccip_helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -4157,7 +4157,7 @@ func (c *CCIPTestEnv) SetUpNodeKeysAndFund(
nodeFund *big.Float,
chains []blockchain.EVMClient,
) error {
if c.CLNodes == nil || len(c.CLNodes) == 0 {
if len(c.CLNodes) == 0 {
return fmt.Errorf("no chainlink nodes to setup")
}
var chainlinkNodes []*nodeclient.ChainlinkClient
Expand Down
6 changes: 3 additions & 3 deletions integration-tests/ccip-tests/actions/reorg_helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,16 +27,16 @@ type ReorgConfig struct {
// DstGethHTTPURL dest chain Geth HTTP URL
DstGethHTTPURL string
// SrcFinalityDepth source chain finality depth
SrcFinalityDepth uint64
SrcFinalityDepth int
// DstGethHTTPURL dest chain finality depth
DstFinalityDepth uint64
DstFinalityDepth int
// FinalityDelta blocks to rewind below or above finality
FinalityDelta int
}

// Validate validates ReorgConfig params
func (rc *ReorgConfig) Validate() error {
if rc.FinalityDelta >= int(rc.SrcFinalityDepth) || rc.FinalityDelta >= int(rc.DstFinalityDepth) {
if rc.FinalityDelta >= rc.SrcFinalityDepth || rc.FinalityDelta >= rc.DstFinalityDepth {
return fmt.Errorf(
"finality delta can't be higher than source or dest chain finality, delta: %d, src: %d, dst: %d",
rc.FinalityDelta, rc.SrcFinalityDepth, rc.DstFinalityDepth,
Expand Down
6 changes: 5 additions & 1 deletion integration-tests/ccip-tests/contracts/contract_models.go
Original file line number Diff line number Diff line change
Expand Up @@ -2241,7 +2241,11 @@ func (a *MockAggregator) UpdateRoundData(answer *big.Int, minP, maxP *int) error

// if answer is nil, we calculate the answer with random percentage (within the provided range) of latest answer
if answer == nil {
rand.Seed(uint64(time.Now().UnixNano()))
now := time.Now().UnixNano()
if now < 0 {
return fmt.Errorf("negative timestamp: %d", now)
}
rand.Seed(uint64(now))
randomNumber := rand.Intn(pointer.GetInt(maxP)-pointer.GetInt(minP)+1) + pointer.GetInt(minP)
// answer = previous round answer + (previous round answer * random percentage)
answer = new(big.Int).Add(a.Answer, new(big.Int).Div(new(big.Int).Mul(a.Answer, big.NewInt(int64(randomNumber))), big.NewInt(100)))
Expand Down
23 changes: 15 additions & 8 deletions integration-tests/ccip-tests/smoke/ccip_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package smoke

import (
"fmt"
"math"
"math/big"
"testing"
"time"
Expand Down Expand Up @@ -874,8 +875,8 @@ func TestSmokeCCIPReorgBelowFinality(t *testing.T) {
require.NoError(t, err, "Send requests failed")
rs := SetupReorgSuite(t, &log, setUpOutput)
// run below finality reorg in both source and destination chain
blocksBackSrc := int(rs.Cfg.SrcFinalityDepth) - rs.Cfg.FinalityDelta
blocksBackDst := int(rs.Cfg.DstFinalityDepth) - rs.Cfg.FinalityDelta
blocksBackSrc := rs.Cfg.SrcFinalityDepth - rs.Cfg.FinalityDelta
blocksBackDst := rs.Cfg.DstFinalityDepth - rs.Cfg.FinalityDelta
rs.RunReorg(rs.DstClient, blocksBackSrc, "Source", 2*time.Second)
rs.RunReorg(rs.DstClient, blocksBackDst, "Destination", 2*time.Second)
time.Sleep(1 * time.Minute)
Expand Down Expand Up @@ -930,10 +931,10 @@ func performAboveFinalityReorgAndValidate(t *testing.T, network string) {
logPollerName := ""
if network == "Destination" {
logPollerName = fmt.Sprintf("EVM.%d.LogPoller", lane.DestChain.GetChainID())
rs.RunReorg(rs.DstClient, int(rs.Cfg.DstFinalityDepth)+rs.Cfg.FinalityDelta, network, 2*time.Second)
rs.RunReorg(rs.DstClient, rs.Cfg.DstFinalityDepth+rs.Cfg.FinalityDelta, network, 2*time.Second)
} else {
logPollerName = fmt.Sprintf("EVM.%d.LogPoller", lane.SourceChain.GetChainID())
rs.RunReorg(rs.SrcClient, int(rs.Cfg.SrcFinalityDepth)+rs.Cfg.FinalityDelta, network, 2*time.Second)
rs.RunReorg(rs.SrcClient, rs.Cfg.SrcFinalityDepth+rs.Cfg.FinalityDelta, network, 2*time.Second)
}
clNodes := setUpOutput.Env.CLNodes
// assert every node is detecting the reorg (LogPollInterval is set as 1s for faster detection)
Expand Down Expand Up @@ -1123,17 +1124,23 @@ func testOffRampRateLimits(t *testing.T, rateLimiterConfig contracts.RateLimiter

// SetupReorgSuite defines the setup required to perform re-org step
func SetupReorgSuite(t *testing.T, lggr *zerolog.Logger, setupOutput *testsetups.CCIPTestSetUpOutputs) *actions.ReorgSuite {
var finalitySrc uint64
var finalityDst uint64
var finalitySrc int
var finalityDst int
if setupOutput.Cfg.SelectedNetworks[0].FinalityTag {
finalitySrc = 10
} else {
finalitySrc = setupOutput.Cfg.SelectedNetworks[0].FinalityDepth
if setupOutput.Cfg.SelectedNetworks[0].FinalityDepth > math.MaxInt {
t.Fatalf("source finality depth overflows int: %d", setupOutput.Cfg.SelectedNetworks[0].FinalityDepth)
}
finalitySrc = int(setupOutput.Cfg.SelectedNetworks[0].FinalityDepth)
}
if setupOutput.Cfg.SelectedNetworks[1].FinalityTag {
finalityDst = 10
} else {
finalityDst = setupOutput.Cfg.SelectedNetworks[1].FinalityDepth
if setupOutput.Cfg.SelectedNetworks[1].FinalityDepth > math.MaxInt {
t.Fatalf("destination finality depth overflows int: %d", setupOutput.Cfg.SelectedNetworks[1].FinalityDepth)
}
finalityDst = int(setupOutput.Cfg.SelectedNetworks[1].FinalityDepth)
}
var srcGethHTTPURL, dstGethHTTPURL string
if setupOutput.Env.LocalCluster != nil {
Expand Down
2 changes: 1 addition & 1 deletion integration-tests/ccip-tests/testconfig/global.go
Original file line number Diff line number Diff line change
Expand Up @@ -584,7 +584,7 @@ func (c *ChainlinkDeployment) Validate() error {
if c.NoOfNodes == nil {
return errors.New("chainlink config is invalid, NoOfNodes should be specified")
}
if c.Nodes != nil && len(c.Nodes) > 0 {
if len(c.Nodes) > 0 {
noOfNodes := pointer.GetInt(c.NoOfNodes)
if noOfNodes != len(c.Nodes) {
return errors.New("chainlink config is invalid, NoOfNodes and Nodes length mismatch")
Expand Down
2 changes: 1 addition & 1 deletion integration-tests/ccip-tests/testsetups/ccip.go
Original file line number Diff line number Diff line change
Expand Up @@ -300,7 +300,7 @@ func (c *CCIPTestConfig) SetNetworkPairs(lggr zerolog.Logger) error {
var newNetworkPairs []NetworkPair
denselyConnectedNetworks := make(map[string]struct{})
// if densely connected networks are provided, choose all the network pairs containing the networks mentioned in the list for DenselyConnectedNetworkChainIds
if c.TestGroupInput.DenselyConnectedNetworkChainIds != nil && len(c.TestGroupInput.DenselyConnectedNetworkChainIds) > 0 {
if len(c.TestGroupInput.DenselyConnectedNetworkChainIds) > 0 {
for _, n := range c.TestGroupInput.DenselyConnectedNetworkChainIds {
denselyConnectedNetworks[n] = struct{}{}
}
Expand Down
4 changes: 4 additions & 0 deletions integration-tests/ccip-tests/types/config/node/core.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package node
import (
"bytes"
"fmt"
"math"
"math/big"

"github.com/smartcontractkit/chainlink-testing-framework/lib/blockchain"
Expand Down Expand Up @@ -54,6 +55,9 @@ func WithPrivateEVMs(networks []blockchain.EVMNetwork, commonChainConfig *evmcfg
}
}
if evmConfig.Chain.FinalityDepth == nil && network.FinalityDepth > 0 {
if network.FinalityDepth > math.MaxUint32 {
panic(fmt.Errorf("finality depth overflows uint32: %d", network.FinalityDepth))
}
evmConfig.Chain.FinalityDepth = ptr.Ptr(uint32(network.FinalityDepth))
}
if evmConfig.Chain.FinalityTagEnabled == nil && network.FinalityTag {
Expand Down
12 changes: 6 additions & 6 deletions integration-tests/contracts/ethereum_contracts_automation.go
Original file line number Diff line number Diff line change
Expand Up @@ -2809,14 +2809,14 @@ type AutomationConsumerBenchmarkUpkeepObserver struct {

firstBlockNum uint64 // Records the number of the first block that came in
lastBlockNum uint64 // Records the number of the last block that came in
blockRange int64 // How many blocks to watch upkeeps for
blockRange uint64 // How many blocks to watch upkeeps for
upkeepSLA int64 // SLA after which an upkeep is counted as 'missed'
metricsReporter *testreporters.KeeperBenchmarkTestReporter // Testreporter to track results
upkeepIndex int64
firstEligibleBuffer int64

// State variables, changes as we get blocks
blocksSinceSubscription int64 // How many blocks have passed since subscribing
blocksSinceSubscription uint64 // How many blocks have passed since subscribing
blocksSinceEligible int64 // How many blocks have come in since upkeep has been eligible for check
countEligible int64 // Number of times the upkeep became eligible
countMissed int64 // Number of times we missed SLA for performing upkeep
Expand All @@ -2832,7 +2832,7 @@ func NewAutomationConsumerBenchmarkUpkeepObserver(
contract AutomationConsumerBenchmark,
registry KeeperRegistry,
upkeepID *big.Int,
blockRange int64,
blockRange uint64,
upkeepSLA int64,
metricsReporter *testreporters.KeeperBenchmarkTestReporter,
upkeepIndex int64,
Expand Down Expand Up @@ -2906,7 +2906,7 @@ func (o *AutomationConsumerBenchmarkUpkeepObserver) ReceiveHeader(receivedHeader
o.blocksSinceEligible = 0
}

isEligible, err := o.instance.CheckEligible(context.Background(), big.NewInt(o.upkeepIndex), big.NewInt(o.blockRange), big.NewInt(o.firstEligibleBuffer))
isEligible, err := o.instance.CheckEligible(context.Background(), big.NewInt(o.upkeepIndex), new(big.Int).SetUint64(o.blockRange), big.NewInt(o.firstEligibleBuffer))
if err != nil {
return false, err
}
Expand All @@ -2924,7 +2924,7 @@ func (o *AutomationConsumerBenchmarkUpkeepObserver) ReceiveHeader(receivedHeader
o.blocksSinceEligible++
}

if o.blocksSinceSubscription >= o.blockRange || int64(o.lastBlockNum-o.firstBlockNum) >= o.blockRange {
if o.blocksSinceSubscription >= o.blockRange || o.lastBlockNum-o.firstBlockNum >= o.blockRange {
if o.blocksSinceEligible > 0 {
if o.blocksSinceEligible > o.upkeepSLA {
o.l.Warn().
Expand Down Expand Up @@ -2953,7 +2953,7 @@ func (o *AutomationConsumerBenchmarkUpkeepObserver) ReceiveHeader(receivedHeader
Str("Upkeep_ID", o.upkeepID.String()).
Str("Contract_Address", o.instance.Address()).
Int64("Upkeeps_Performed", upkeepCount.Int64()).
Int64("Total_Blocks_Watched", o.blocksSinceSubscription).
Uint64("Total_Blocks_Watched", o.blocksSinceSubscription).
Str("Registry_Address", o.registry.Address()).
Msg("Finished Watching for Upkeeps")

Expand Down
9 changes: 8 additions & 1 deletion integration-tests/docker/test_env/test_env_builder.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package test_env

import (
"fmt"
"math"
"os"
"path/filepath"
"slices"
Expand Down Expand Up @@ -279,10 +280,16 @@ func (b *CLTestEnvBuilder) Build() (*CLClusterTestEnv, error) {

processFn := func(log logstream.LogContent, count *int) error {
countSoFar := count
if *countSoFar < 0 {
return fmt.Errorf("negative count: %d", *countSoFar)
}
newCount, err := testreporters.ScanLogLine(b.l, string(log.Content), b.chainlinkNodeLogScannerSettings.FailingLogLevel, uint(*countSoFar), b.chainlinkNodeLogScannerSettings.Threshold, b.chainlinkNodeLogScannerSettings.AllowedMessages)
if err != nil {
return err
}
if newCount > math.MaxInt {
return fmt.Errorf("new count overflows int: %d", newCount)
}
*count = int(newCount)
return nil
}
Expand Down Expand Up @@ -494,7 +501,7 @@ func (b *CLTestEnvBuilder) Build() (*CLClusterTestEnv, error) {
b.te.EVMNetworks = append(b.te.EVMNetworks, &networkConfig)

if b.isEVM {
if b.evmNetworkOption != nil && len(b.evmNetworkOption) > 0 {
if len(b.evmNetworkOption) > 0 {
for _, fn := range b.evmNetworkOption {
fn(&networkConfig)
}
Expand Down
Loading

0 comments on commit 2352b69

Please sign in to comment.