Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Linting #180

Closed
wants to merge 8 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/CODEOWNERS
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,5 @@

# review whenever someone opens a pull request.

* @ceyonur @darioush @aaronbuchwald
* @ceyonur @darioush

25 changes: 14 additions & 11 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@ on:
- 'v[0-9]+.[0-9]+.[0-9]+'
pull_request:

env:
tmpnet_data_path: ~/.tmpnet/networks/1000

jobs:
lint_test:
name: Lint
Expand Down Expand Up @@ -88,7 +91,7 @@ jobs:
uses: actions/upload-artifact@v4
with:
name: subnet-evm-e2e-logs-precompile
path: /tmp/network-runner-root-data*/
path: /tmp/e2e-test/precompile-data
retention-days: 5
e2e_warp:
name: e2e warp tests
Expand Down Expand Up @@ -124,14 +127,14 @@ jobs:
run: ./scripts/build.sh /tmp/e2e-test/avalanchego/plugins/srEXiWaHuhNyGwPUi444Tu47ZEDwxTWrbQiuD7FmgSAQ6X7Dy
- name: Run Warp E2E Tests
shell: bash
run: AVALANCHEGO_BUILD_PATH=/tmp/e2e-test/avalanchego DATA_DIR=/tmp/e2e-test/warp-data ./scripts/run_ginkgo_warp.sh
- name: Upload Artifact
run: AVALANCHEGO_BUILD_PATH=/tmp/e2e-test/avalanchego ./scripts/run_ginkgo_warp.sh
- name: Upload tmpnet network dir for warp testing
if: always()
uses: actions/upload-artifact@v4
with:
name: subnet-evm-e2e-logs-warp
path: /tmp/network-runner-root-data*/
retention-days: 5
name: warp-tmpnet-data
path: ${{ env.tmpnet_data_path }}
if-no-files-found: error
e2e_load:
name: e2e load tests
runs-on: ubuntu-latest
Expand All @@ -153,14 +156,14 @@ jobs:
run: ./scripts/build.sh /tmp/e2e-test/avalanchego/plugins/srEXiWaHuhNyGwPUi444Tu47ZEDwxTWrbQiuD7FmgSAQ6X7Dy
- name: Run E2E Load Tests
shell: bash
run: AVALANCHEGO_BUILD_PATH=/tmp/e2e-test/avalanchego DATA_DIR=/tmp/e2e-test/load-data ./scripts/run_ginkgo_load.sh
- name: Upload Artifact
run: AVALANCHEGO_BUILD_PATH=/tmp/e2e-test/avalanchego ./scripts/run_ginkgo_load.sh
- name: Upload tmpnet network dir for load testing
if: always()
uses: actions/upload-artifact@v4
with:
name: subnet-evm-e2e-logs-load
path: /tmp/network-runner-root-data*/
retention-days: 5
name: load-tmpnet-data
path: ${{ env.tmpnet_data_path }}
if-no-files-found: error

build_image:
name: Build Docker Image
Expand Down
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ The Subnet EVM runs in a separate process from the main AvalancheGo process and
[v0.5.11] [email protected] (Protocol Version: 31)
[v0.6.0] [email protected] (Protocol Version: 33)
[v0.6.1] [email protected] (Protocol Version: 33)
[v0.6.2] [email protected] (Protocol Version: 34)
```

## API
Expand Down
3 changes: 3 additions & 0 deletions accounts/abi/bind/precompilebind/precompile_bind.go
Original file line number Diff line number Diff line change
Expand Up @@ -155,6 +155,9 @@ func createPrecompileHook(abifilename string, template string) bind.BindHook {
for key := range allowlist.AllowListABI.Methods {
delete(funcs, key)
}
for events := range allowlist.AllowListABI.Events {
delete(contract.Events, events)
}
}

precompileContract := &tmplPrecompileContract{
Expand Down
10 changes: 5 additions & 5 deletions accounts/abi/bind/precompilebind/precompile_bind_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -536,7 +536,7 @@ var bindTests = []struct {
require.NoError(t, err)
require.Equal(t, testBytes, unpacked.BytesTest)
gasCost := GetTestEventGasCost(testEventData)
require.Equal(t, contract.LogGas + 2 * contract.LogTopicGas + contract.LogDataGas, gasCost)
require.Equal(t, contract.LogGas + 3 * contract.LogTopicGas + contract.LogDataGas, gasCost)

topics, data, err = PackEmptyEvent()
require.NoError(t, err)
Expand All @@ -553,7 +553,7 @@ var bindTests = []struct {
require.Equal(t, eventID, topics[0])
require.Equal(t, testAddr.Hash(), topics[1])
require.Equal(t, 0, len(data))
require.Equal(t, contract.LogGas + 2 * contract.LogTopicGas, GetIndexedEventGasCost())
require.Equal(t, contract.LogGas + 3 * contract.LogTopicGas, GetIndexedEventGasCost())

testMixedData := MixedEventData{
Num: testInt,
Expand All @@ -567,7 +567,7 @@ var bindTests = []struct {
unpackedMixedData, err := UnpackMixedEventData(data)
require.NoError(t, err)
require.Equal(t, testMixedData, unpackedMixedData)
require.Equal(t, contract.LogGas + contract.LogTopicGas + contract.LogDataGas, GetMixedEventGasCost(testMixedData))
require.Equal(t, contract.LogGas + 2 * contract.LogTopicGas + contract.LogDataGas, GetMixedEventGasCost(testMixedData))

testDynamicData := DynamicEventData{
Str: "test",
Expand All @@ -581,15 +581,15 @@ var bindTests = []struct {
unpackedDynamicData, err := UnpackDynamicEventData(data)
require.NoError(t, err)
require.Equal(t, testDynamicData, unpackedDynamicData)
require.Equal(t, contract.LogGas + 2 * contract.LogTopicGas + 2 * contract.LogDataGas, GetDynamicEventGasCost(testDynamicData))
require.Equal(t, contract.LogGas + 3 * contract.LogTopicGas + 2 * contract.LogDataGas, GetDynamicEventGasCost(testDynamicData))

topics, data, err = PackUnnamedEvent(testUint, testUint)
require.NoError(t, err)
eventID = IEventerABI.Events["unnamed"].ID
require.Len(t, topics, 3)
require.Equal(t, eventID, topics[0])
require.Equal(t, 0, len(data))
require.Equal(t, contract.LogGas + 2 * contract.LogTopicGas, GetUnnamedEventGasCost())
require.Equal(t, contract.LogGas + 3 * contract.LogTopicGas, GetUnnamedEventGasCost())
`,
"",
false,
Expand Down
5 changes: 3 additions & 2 deletions accounts/abi/bind/precompilebind/precompile_event_template.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ accessibleState.GetStateDB().AddLog(
{{range .Contract.Events}}
{{$event := .}}
{{$createdDataStruct := false}}
{{$topicCount := 0}}
{{$topicCount := 1}}
{{- range .Normalized.Inputs}}
{{- if .Indexed}}
{{$topicCount = add $topicCount 1}}
Expand All @@ -81,8 +81,9 @@ accessibleState.GetStateDB().AddLog(
// The gas cost of the non-indexed data depends on the data type and the data size.
func Get{{.Normalized.Name}}EventGasCost({{if $createdDataStruct}} data {{.Normalized.Name}}EventData{{end}}) uint64 {
gas := contract.LogGas // base gas cost
{{if $topicCount | lt 0}}
{{if $topicCount | lt 1}}
// Add topics gas cost ({{$topicCount}} topics)
// Topics always include the signature hash of the event. The rest are the indexed event arguments.
gas += contract.LogTopicGas * {{$topicCount}}
{{end}}

Expand Down
14 changes: 11 additions & 3 deletions chain.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,20 @@
"tx-regossip-max-size": 32,
"priority-regossip-max-txs": 500,
"priority-regossip-txs-per-address": 200,
"priority-regossip-addresses": ["0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", "0x70997970C51812dc3A010C7d01b50e0d17dc79C8", "0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC", "0x8db97C7cEcE249c2b98bDC0226Cc4C2A57BF52FC"],
"priority-regossip-addresses": [
"0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266",
"0x70997970C51812dc3A010C7d01b50e0d17dc79C8",
"0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC",
"0x8db97C7cEcE249c2b98bDC0226Cc4C2A57BF52FC"
],
"validator-private-key-file": "/tmp/validator.pk",
"is-validator": true,
"trading-api-enabled": true,
"testing-api-enabled": true,
"load-from-snapshot-enabled": true,
"snapshot-file-path": "/tmp/snapshot",
"makerbook-database-path": "/tmp/makerbook"
}
"makerbook-database-path": "/tmp/makerbook",
"order-gossip-num-validators": 10,
"order-gossip-num-non-validators": 5,
"order-gossip-num-peers": 15
}
24 changes: 13 additions & 11 deletions cmd/precompilegen/template-readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,21 @@ For testing take a look at other precompile tests in contract_test.go and config
See the tutorial in <https://docs.avax.network/subnets/hello-world-precompile-tutorial> for more information about precompile development.

General guidelines for precompile development:

1- Set a suitable config key in generated module.go. E.g: "yourPrecompileConfig"
2- Read the comment and set a suitable contract address in generated module.go. E.g:
ContractAddress = common.HexToAddress("ASUITABLEHEXADDRESS")
3- It is recommended to only modify code in the highlighted areas marked with "CUSTOM CODE STARTS HERE". Typically, custom codes are required in only those areas.
Modifying code outside of these areas should be done with caution and with a deep understanding of how these changes may impact the EVM.
4- Set gas costs in generated contract.go
5- Force import your precompile package in precompile/registry/registry.go
6- Add your config unit tests under generated package config_test.go
7- Add your contract unit tests under generated package contract_test.go
8- Additionally you can add a full-fledged VM test for your precompile under plugin/vm/vm_test.go. See existing precompile tests for examples.
9- Add your solidity interface and test contract to contracts/contracts
10- Write solidity contract tests for your precompile in contracts/contracts/test
11- Write TypeScript DS-Test counterparts for your solidity tests in contracts/test
12- Create your genesis with your precompile enabled in tests/precompile/genesis/
13- Create e2e test for your solidity test in tests/precompile/solidity/suites.go
14- Run your e2e precompile Solidity tests with './scripts/run_ginkgo.sh`
4- If you have any event defined in your precompile, review the generated event.go file and set your event gas costs. You should also emit your event in your function in the contract.go file.
5- Set gas costs in generated contract.go
6- Force import your precompile package in precompile/registry/registry.go
7- Add your config unit tests under generated package config_test.go
8- Add your contract unit tests under generated package contract_test.go
9- Additionally you can add a full-fledged VM test for your precompile under plugin/vm/vm_test.go. See existing precompile tests for examples.
10- Add your solidity interface and test contract to contracts/contracts
11- Write solidity contract tests for your precompile in contracts/contracts/test
12- Write TypeScript DS-Test counterparts for your solidity tests in contracts/test
13- Create your genesis with your precompile enabled in tests/precompile/genesis/
14- Create e2e test for your solidity test in tests/precompile/solidity/suites.go
15- Run your e2e precompile Solidity tests with './scripts/run_ginkgo.sh`
1 change: 1 addition & 0 deletions compatibility.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
{
"rpcChainVMProtocolVersion": {
"v0.6.2": 34,
"v0.6.1": 33,
"v0.6.0": 33,
"v0.5.11": 31,
Expand Down
8 changes: 5 additions & 3 deletions core/txpool/txpool.go
Original file line number Diff line number Diff line change
Expand Up @@ -202,7 +202,9 @@ type Config struct {
// DefaultConfig contains the default configurations for the transaction
// pool.
var DefaultConfig = Config{
Journal: "transactions.rlp",
// If we re-enable txpool journaling, we should also add the saved local
// transactions to the p2p gossip on startup.
Journal: "",
Rejournal: time.Hour,

PriceLimit: 1,
Expand All @@ -213,7 +215,7 @@ var DefaultConfig = Config{
AccountQueue: 64,
GlobalQueue: 1024,

Lifetime: 3 * time.Hour,
Lifetime: 10 * time.Minute,
}

// sanitize checks the provided user configurations and changes anything that's
Expand Down Expand Up @@ -1128,7 +1130,7 @@ func (pool *TxPool) PurgeOrderBookTxs() {
pool.mu.Lock()
defer pool.mu.Unlock()

for from, _ := range pool.orderBookTxs.txs {
for from := range pool.orderBookTxs.txs {
delete(pool.orderBookTxs.txs, from)
}

Expand Down
35 changes: 15 additions & 20 deletions core/txpool/txpool_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ import (
var (
// testTxPoolConfig is a transaction pool configuration without stateful disk
// sideeffects used during testing.
testTxPoolConfig Config
testTxPoolConfig = DefaultConfig

// eip1559Config is a chain config with EIP-1559 enabled at block 0.
eip1559Config *params.ChainConfig
Expand All @@ -77,9 +77,6 @@ var (
)

func init() {
testTxPoolConfig = DefaultConfig
testTxPoolConfig.Journal = ""

cpy := *params.TestChainConfig
eip1559Config = &cpy
eip1559Config.SubnetEVMTimestamp = utils.NewUint64(0)
Expand Down Expand Up @@ -2641,7 +2638,7 @@ func BenchmarkMultiAccountBatchInsert(b *testing.B) {

func TestAddOrderBookTx(t *testing.T) {
t.Run("when adding only one tx to orderbook queue", func(t *testing.T) {
pool, _ := setupTxPool()
pool, _ := setupPool()
defer pool.Stop()

key, _ := crypto.GenerateKey()
Expand All @@ -2650,13 +2647,12 @@ func TestAddOrderBookTx(t *testing.T) {
tx := transaction(uint64(0), 100000, key)

pool.AddOrderBookTx(tx)
actualTxs := pool.OrderBookTxMap[account].Flatten()
actualTxs := pool.orderBookTxs.txs[account].Flatten()
assert.Equal(t, 1, actualTxs.Len())
assert.Equal(t, tx, actualTxs[0])

})
t.Run("when adding more than one tx to orderbook queue", func(t *testing.T) {
pool, _ := setupTxPool()
pool, _ := setupPool()
defer pool.Stop()

key, _ := crypto.GenerateKey()
Expand All @@ -2665,15 +2661,15 @@ func TestAddOrderBookTx(t *testing.T) {
pool.AddOrderBookTx(tx1)
tx2 := transaction(uint64(1), 100000, key)
pool.AddOrderBookTx(tx2)
actualTxs := pool.OrderBookTxMap[account].Flatten()
actualTxs := pool.orderBookTxs.txs[account].Flatten()
assert.Equal(t, 2, actualTxs.Len())
assert.Equal(t, tx1, actualTxs[0])
assert.Equal(t, tx2, actualTxs[1])
})
}

func TestGetOrderBookTxNonce(t *testing.T) {
pool, _ := setupTxPool()
pool, _ := setupPool()
defer pool.Stop()
key, _ := crypto.GenerateKey()
account := crypto.PubkeyToAddress(key.PublicKey)
Expand All @@ -2690,45 +2686,44 @@ func TestGetOrderBookTxNonce(t *testing.T) {
}

func TestGetOrderBookTxs(t *testing.T) {
pool, _ := setupTxPool()
pool, _ := setupPool()
defer pool.Stop()
key, _ := crypto.GenerateKey()
account := crypto.PubkeyToAddress(key.PublicKey)

t.Run("when there are no tx in orderBookTxMap", func(t *testing.T) {
actualTxList := pool.OrderBookTxMap[account]
actualTxList := pool.orderBookTxs.txs[account]
assert.Equal(t, nil, actualTxList)
})
t.Run("when there are txs in orderBookTxMap", func(t *testing.T) {
tx1 := transaction(uint64(0), 100000, key)
pool.AddOrderBookTx(tx1)
tx2 := transaction(uint64(1), 100000, key)
pool.AddOrderBookTx(tx2)
actualTxs := pool.OrderBookTxMap[account].Flatten()
actualTxs := pool.orderBookTxs.txs[account].Flatten()
assert.Equal(t, types.Transactions{tx1, tx2}, actualTxs)
})
}

func TestPurgeOrderBookTxs(t *testing.T) {
pool, _ := setupTxPool()
pool, _ := setupPool()
defer pool.Stop()
key, _ := crypto.GenerateKey()
account := crypto.PubkeyToAddress(key.PublicKey)

t.Run("when there is no tx for an account in orderBookTxMap", func(t *testing.T) {
txList := pool.OrderBookTxMap[account]
t.Run("when there is no tx for an account in orderBookTx", func(t *testing.T) {
txList := pool.orderBookTxs.txs[account]
assert.Nil(t, txList)
})
t.Run("when there is tx for an account in orderBookTxMap", func(t *testing.T) {
t.Run("when there is tx for an account in orderBookTxs", func(t *testing.T) {
tx1 := transaction(uint64(0), 100000, key)
pool.AddOrderBookTx(tx1)
actualTxs := pool.OrderBookTxMap[account].Flatten()
actualTxs := pool.orderBookTxs.txs[account].Flatten()
assert.Equal(t, types.Transactions{tx1}, actualTxs)

pool.PurgeOrderBookTxs()

txList := pool.OrderBookTxMap[account]
txList := pool.orderBookTxs.txs[account]
assert.Nil(t, txList)
})

}
1 change: 0 additions & 1 deletion eth/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,6 @@ func (api *EthereumAPI) GetTransactionStatus(ctx context.Context, hash common.Ha
return map[string]interface{}{
"status": "NOT_FOUND",
}, nil

}

for _, tx := range currentBlock.Transactions() {
Expand Down
9 changes: 8 additions & 1 deletion eth/api_backend.go
Original file line number Diff line number Diff line change
Expand Up @@ -340,7 +340,14 @@ func (b *EthAPIBackend) SendTx(ctx context.Context, signedTx *types.Transaction)
if err := ctx.Err(); err != nil {
return err
}
return b.eth.txPool.AddLocal(signedTx)
if err := b.eth.txPool.AddLocal(signedTx); err != nil {
return err
}

// We only enqueue transactions for push gossip if they were submitted over the RPC and
// added to the mempool.
b.eth.gossiper.Add(signedTx)
return nil
}

func (b *EthAPIBackend) GetPoolTransactions() (types.Transactions, error) {
Expand Down
Loading
Loading