Skip to content

Commit 7e2be02

Browse files
cfflsgballets1naholimansysvm
authored
Merge upstream_merge branch to develop (ethereum#1229)
* cmd, core, trie: verkle-capable `geth init` (ethereum#28270) This change allows the creation of a genesis block for verkle testnets. This makes for a chunk of code that is easier to review and still touches many discussion points. * eth/tracers/js: fix isPush for push0 (ethereum#28520) Fixes so that `push0` opcode is correctly reported as `true` by the `IsPush` function --------- Co-authored-by: Martin Holst Swende <[email protected]> * trie: spelling - fix comments in hasher (ethereum#28507) Co-authored-by: VM <[email protected]> * tests/fuzzers: move fuzzers into native packages (ethereum#28467) This PR moves our fuzzers from tests/fuzzers into whatever their respective 'native' package is. The historical reason why they were placed in an external location, is that when they were based on go-fuzz, they could not be "hidden" via the _test.go prefix. So in order to shove them away from the go-ethereum "production code", they were put aside. But now we've rewritten them to be based on golang testing, and thus can be brought back. I've left (in tests/) the ones that are not production (bls128381), require non-standard imports (secp requires btcec, bn256 requires gnark/google/cloudflare deps). This PR also adds a fuzzer for precompiled contracts, because why not. This PR utilizes a newly rewritten replacement for go-118-fuzz-build, namely gofuzz-shim, which utilises the inputs from the fuzzing engine better. * tests: skip tests on windows 32bit CI (ethereum#28521) tests: skip half the blockchain- and state-tests on windows 32bit CI-tests * cmd/geth: more special cases logging tests (ethereum#28527) adds logging tests for errors and custom fmt.Stringer-types which output strings that needs to be quoted/escaped. * accounts,cmd,console,les,metrics: refactor some errors checked by (ST1005) go-staticcheck (ethereum#28532) fix: fix some (ST1005)go-staticcheck * miner: run tests in parallel (ethereum#28506) Changes many of the tests in the miner package to run in parallel * internal/jsre/deps: fix typo in jsdoc (ethereum#28511) minor typo fix * accounts/abi: improve readability of method-to-string conversion (ethereum#28530) refactor: improve readability of NewMethod print * all: replace some cases of strings.SplitN with strings.Cut (ethereum#28446) * ethdb/memorydb, trie: reduced allocations (ethereum#28473) * trie: use pooling of iterator states in iterator The node iterator burns through a lot of memory while iterating a trie, and a lot of that can be avoided by using a fairly small pool (max 40 items). name old time/op new time/op delta Iterator-8 6.22ms ± 3% 5.40ms ± 6% -13.18% (p=0.008 n=5+5) name old alloc/op new alloc/op delta Iterator-8 2.36MB ± 0% 1.67MB ± 0% -29.23% (p=0.008 n=5+5) name old allocs/op new allocs/op delta Iterator-8 37.0k ± 0% 29.8k ± 0% ~ (p=0.079 n=4+5) * ethdb/memorydb: avoid one copying of key By making the transformation from []byte to string at an earlier point, we save an allocation which otherwise happens later on. name old time/op new time/op delta BatchAllocs-8 412µs ± 6% 382µs ± 2% -7.18% (p=0.016 n=5+4) name old alloc/op new alloc/op delta BatchAllocs-8 480kB ± 0% 490kB ± 0% +1.93% (p=0.008 n=5+5) name old allocs/op new allocs/op delta BatchAllocs-8 3.03k ± 0% 2.03k ± 0% -32.98% (p=0.008 n=5+5) * Dockerfile: update Go to 1.21 (ethereum#28538) * cmd/evm: validate blockchain tests poststate account storage (ethereum#28443) This PR verifies the accounts' storage as specified in a blockchain test's postState field The expect-section, it does really only check that the test works. It's meant for the test-author to verify that "If the test does what it's supposed to, then the nonce of X should be 2, and the slot Y at Z should be 0x123. This expect-section is not exhaustive (not full post-state) It is also not auto-generated, but put there manually by the author. We can still check it, as a test-sanity-check, in geth * signer: run tests in parallel (ethereum#28536) marks tests as parallel-safe in package signer * accounts, cmd: fix typos (ethereum#28526) * core/txpool/legacypool: respect nolocals-setting (ethereum#28435) This change adds a check to ensure that transactions added to the legacy pool are not treated as 'locals' if the global locals-management has been disabled. This change makes the pool enforce the --txpool.pricelimit setting. * cmd: run tests in parallel (ethereum#28546) * core/state/snapshot: print correct error from trie iterator (ethereum#28560) * cmd/evm: capitalize evm commands (ethereum#28569) * standard:fix for a unified standard * standard:fix more as a complements --------- Co-authored-by: haotian <[email protected]> * accounts/abi: context info on unpack-errors (ethereum#28529) adds contextual information to errors returned by unpack * core, trie, rpc: speed up tests (ethereum#28461) * rpc: make subscription test faster reduces time for TestClientSubscriptionChannelClose from 25 sec to < 1 sec. * trie: cache trie nodes for faster sanity check This reduces the time spent on TestIncompleteSyncHash from ~25s to ~16s. * core/forkid: speed up validation test This takes the validation test from > 5s to sub 1 sec * core/state: improve snapshot test run brings the time for TestSnapshotRandom from 13s down to 6s * accounts/keystore: improve keyfile test This removes some unnecessary waits and reduces the runtime of TestUpdatedKeyfileContents from 5 to 3 seconds * trie: remove resolver * trie: only check ~5% of all trie nodes * ethdb/pebble: don't double-close iterator inside pebbleIterator (ethereum#28566) Adds 'released' flag to pebbleIterator to avoid double closing cockroachdb/pebble.Iterator as it is an invalid operation. Fixes ethereum#28565 * eth/filters: reuse error msg for invalid block range (ethereum#28479) * core/types: make 'v' optional for DynamicFeeTx and BlobTx (ethereum#28564) This fixes an issue where transactions would not be accepted when they have only 'yParity' and not 'v'. * rpc: improve performance of subscription notification encoding (ethereum#28328) It turns out that encoding json.RawMessage is slow because package json basically parses the message again to ensure it is valid. We can avoid the slowdown by encoding the entire RPC notification once, which yields a 30% speedup. * cmd/utils: validate pre-existing genesis in --dev mode (ethereum#28468) geth --dev can be used with an existing data directory and genesis block. Since dev mode only works with PoS, we need to verify that the merge has happened. Co-authored-by: Felix Lange <[email protected]> * cmd/geth: add support for --dev flag in dumpgenesis (ethereum#28463) Co-authored-by: Felix Lange <[email protected]> Co-authored-by: lightclient <[email protected]> * les/vflux: run tests in parallel (ethereum#28524) * cmd/{geth,utils}: add cmd to export preimages in snap enumeration order (ethereum#28256) Adds a subcommand: `geth snapshot export-preimages`, to export preimages of every hash found during a snapshot enumeration: that is, it exports _only the active state_, and not _all_ preimages that have been used but are no longer part of the state. This tool is needed for the verkle transition, in order to distribute the preimages needed for the conversion. Since only the 'active' preimages are exported, the output is shrunk from ~70GB to ~4GB. The order of the output is the order used by the snapshot enumeration, which avoids database thrashing. However, it also means that storage-slot preimages are not deduplicated. * cmd/geth: fix build error (ethereum#28585) * cmd/devp2p/internal/ethtest: undo debug-hack (ethereum#28588) cmd/devp2p/internal/ethtest: remove a debug-hack flaw which prevented certain tests from running * params: update discV5 bootnodes (ethereum#28562) update discV5 bootnodes from https://github.com/eth-clients/eth2-networks/blob/master/shared/mainnet/bootstrap_nodes.txt * cmd, les, tests: remove light client code (ethereum#28586) * cmd, les, tests: remove light client code This commit removes the light client (LES) code. Since the merge the light client has been broken and it is hard to maintain it alongside the normal client. We decided it would be best to remove it for now and maybe rework and reintroduce it in the future. * cmd, eth: remove some more mentions of light mode * cmd: re-add flags and mark as deprecated * cmd: warn the user about deprecated flags * eth: better error message * eth, internal/ethapi: drop some weird indirection (ethereum#28597) * trie: fix random test generator early terminate (ethereum#28590) This change fixes a minor bug in the `randTest.Generate` function, which caused the `quick.Check` to be a no-op. * eth/gasestimator, internal/ethapi: move gas estimator out of rpc (ethereum#28600) * go.mod: update uint256 to v1.2.4 (ethereum#28612) * eth/catalyst, eth/downloader: expose more sync information (ethereum#28584) This change exposes more information from sync module internally * light: remove package light(ethereum#28614) This changes removes the package 'light', which is currently unused. * cmd/evm, core/state: fix post-exec dump of state (statetests, blockchaintests) (ethereum#28504) There were several problems related to dumping state. - If a preimage was missing, even if we had set the `OnlyWithAddresses` to `false`, to export them anyway, the way the mapping was constructed (using `common.Address` as key) made the entries get lost anyway. Concerns both state- and blockchain tests. - Blockchain test execution was not configured to store preimages. This changes makes it so that the block test executor takes a callback, just like the state test executor already does. This callback can be used to examine the post-execution state, e.g. to aid debugging of test failures. * ethereum: remove TODO comment about subscription (ethereum#28609) * eth/tracers/js: fix type inconsistencies (ethereum#28488) This change fixes two type-inconsistencies in the JS tracer: - In most places we return byte arrays as a `Uint8Array` to the tracer. However it seems we missed doing the conversion for `ctx` fields which are passed to the tracer during `result`. They are passed as simple arrays. I think Uint8Arrays are more suitable and we should change this inconsistency. Note: this will be a breaking-change. But I believe the effect is small. If we look at our tracers we see that these fields (`ctx.from`, `ctx.to`, etc.) are used in 2 ways. Passed to `toHex` which takes both array or buffer. Or the length was measured which is the same for both types. - The `slice` taking in `int, int` params versus `memory.slice` taking `int64, int64` params. I suggest changing `slice` types to `int64`. This should have no effect almost in any case. * crypto/secp256k1: fix 32-bit tests when CGO_ENABLED=0 (ethereum#28602) * consensus: verify the nonexistence of shanghai- and cancun-specific header fields (ethereum#28605) * eth/gasestimator: allow slight estimation error in favor of less iterations (ethereum#28618) * eth/gasestimator: early exit for plain transfer and error allowance * core, eth/gasestimator: hard guess at a possible required gas * internal/ethapi: update estimation tests with the error ratio * eth/gasestimator: I hate you linter * graphql: fix gas estimation test --------- Co-authored-by: Oren <[email protected]> * all: replace log15 with slog (ethereum#28187) This PR replaces Geth's logger package (a fork of [log15](https://github.com/inconshreveable/log15)) with an implementation using slog, a logging library included as part of the Go standard library as of Go1.21. Main changes are as follows: * removes any log handlers that were unused in the Geth codebase. * Json, logfmt, and terminal formatters are now slog handlers. * Verbosity level constants are changed to match slog constant values. Internal translation is done to make this opaque to the user and backwards compatible with existing `--verbosity` and `--vmodule` options. * `--log.backtraceat` and `--log.debug` are removed. The external-facing API is largely the same as the existing Geth logger. Logger method signatures remain unchanged. A small semantic difference is that a `Handler` can only be set once per `Logger` and not changed dynamically. This just means that a new logger must be instantiated every time the handler of the root logger is changed. ---- For users of the `go-ethereum/log` module. If you were using this module for your own project, you will need to change the initialization. If you previously did ```golang log.Root().SetHandler(log.LvlFilterHandler(log.LvlInfo, log.StreamHandler(os.Stderr, log.TerminalFormat(true)))) ``` You now instead need to do ```golang log.SetDefault(log.NewLogger(log.NewTerminalHandlerWithLevel(os.Stderr, log.LevelInfo, true))) ``` See more about reasoning here: ethereum#28558 (comment) * core/state: make stateobject.create selfcontain (ethereum#28459) * trie/triedb/hashdb: take lock around access to dirties cache (ethereum#28542) Add read locking of db lock around access to dirties cache in hashdb.Database to prevent data race versus hashdb.Database.dereference which can modify the dirities map by deleting an item. Fixes ethereum#28541 --------- Co-authored-by: Gary Rong <[email protected]> * accounts/abi/bind: fix typo (ethereum#28630) * slog: faster and less memory-consumption (ethereum#28621) These changes improves the performance of the non-coloured terminal formatting, _quite a lot_. ``` name old time/op new time/op delta TerminalHandler-8 10.2µs ±15% 5.4µs ± 9% -47.02% (p=0.008 n=5+5) name old alloc/op new alloc/op delta TerminalHandler-8 2.17kB ± 0% 0.40kB ± 0% -81.46% (p=0.008 n=5+5) name old allocs/op new allocs/op delta TerminalHandler-8 33.0 ± 0% 5.0 ± 0% -84.85% (p=0.008 n=5+5) ``` I tried to _somewhat_ organize the commits, but the it might still be a bit chaotic. Some core insights: - The function `terminalHandler.Handl` uses a mutex, and writes all output immediately to 'upstream'. Thus, it can reuse a scratch-buffer every time. - This buffer can be propagated internally, making all the internal formatters either write directly to it, - OR, make use of the `tmp := buf.AvailableBuffer()` in some cases, where a byte buffer "extra capacity" can be temporarily used. - The `slog` package uses `Attr` by value. It makes sense to minimize operating on them, since iterating / collecting into a new slice, iterating again etc causes copy-on-heap. Better to operate on them only once. - If we want to do padding, it's better to copy from a constant `space`-buffer than to invoke `bytes.Repeat` every single time. * eth/tracers: tx-level state in debug_traceCall (ethereum#28460) * cmd/evm: fix Env struct json tag (ethereum#28635) * accounts/abi/bind: fixed typos (ethereum#28634) * Update auth.go * Update backend.go * Update bind.go * Update bind_test.go * eth/fetcher: fix invalid tracking of received at time for block (ethereum#28637) eth/fetcher: fix invalid tracking of received at time * accounts: run tests in parallel (ethereum#28544) * eth/tracers/logger: make structlog/json-log stack hex again (ethereum#28628) * common/hexutil: define hex wrappers for uint256.Int * eth/tracers/logger: make structlog/json-log stack hex again * common/hexutil: goimports * log: remove lazy, remove unused interfaces, unexport methods (ethereum#28622) This change - Removes interface `log.Format`, - Removes method `log.FormatFunc`, - unexports `TerminalHandler.TerminalFormat` formatting methods (renamed to `TerminalHandler.format`) - removes the notion of `log.Lazy` values The lazy handler was useful in the old log package, since it could defer the evaluation of costly attributes until later in the log pipeline: thus, if the logging was done at 'Trace', we could skip evaluation if logging only was set to 'Info'. With the move to slog, this way of deferring evaluation is no longer needed, since slog introduced 'Enabled': the caller can thus do the evaluate-or-not decision at the callsite, which is much more straight-forward than dealing with lazy reflect-based evaluation. Also, lazy evaluation would not work with 'native' slog, as in, these two statements would be evaluated differently: ```golang log.Info("foo", "my lazy", lazyObj) slog.Info("foo", "my lazy", lazyObj) ``` * .github: use github actions to run 32-bit linux tests (ethereum#28549) use github actions to run 32-bit linux tests * ethdb/pebble: remove a dependency (ethereum#28627) The dependency was not really used anyway, so we can get rid of it. Co-authored-by: Felix Lange <[email protected]> * tests/fuzzers/bls12381: deactivate BLS fuzzer when CGO_ENABLED=0 (ethereum#28653) tests/fuzzers/bls12381: deactivate fuzzer when CGO_ENABLED=0 * build: upgrade -dlgo version to Go 1.21.5 (ethereum#28648) * rpc: fix ns/µs mismatch in metrics (ethereum#28649) The rpc/duration/all meter was in nanoseconds, the individual meter in microseconds. This PR changes it so both of them use nanoseconds. * cmd/evm: fix dump after state-test exec (ethereum#28650) The dump after state-test didn't work, the problem was an error, "Already committed", which was silently ignored. This change re-initialises the state, so the dumping works again. * beacon/light: add CommitteeChain (ethereum#27766) This change implements CommitteeChain which is a key component of the beacon light client. It is a passive data structure that can validate, hold and update a chain of beacon light sync committees and updates, starting from a checkpoint that proves the starting committee through a beacon block hash, header and corresponding state. Once synced to the current sync period, CommitteeChain can also validate signed beacon headers. * cmd/utils, eth: disallow invalid snap sync / snapshot flag combos (ethereum#28657) * eth: prevent startup in snap mode without snapshots * cmd/utils: try to fix bad flag combos wrt snap sync and snapshot generation * trie: remove inconsistent trie nodes during sync in path mode (ethereum#28595) This fixes a database corruption issue that could occur during state healing. When sync is aborted while certain modifications were already committed, and a reorg occurs, the database would contain incorrect trie nodes stored by path. These nodes need to detected/deleted in order to obtain a complete and fully correct state after state healing. --------- Co-authored-by: Felix Lange <[email protected]> * cmd/utils: fix HTTPHost, WSHost flag priority (ethereum#28669) Co-authored-by: Felix Lange <[email protected]> * eth/protocols/eth: fix typos in comments (ethereum#28652) * core/txpool : small cleanup refactors (ethereum#28654) * eth/fetcher, eth/gasestimator: fix typos in comments (ethereum#28675) * all: fix typos in comments (ethereum#28662) Co-authored-by: Felix Lange <[email protected]> * miner: eliminate the dead loop possibility for `newWorkLoop` and `mainLoop` (ethereum#28677) discard the intervalAdjust message if the channel is full * all: fix typos in comments (ethereum#28682) chore(core,eth):fix a couple of typos * p2p/discover: add liveness check in collectTableNodes (ethereum#28686) * p2p/discover: add liveness check in collectTableNodes * p2p/discover: fix test * p2p/discover: rename to appendLiveNodes * p2p/discover: add dedup logic back * p2p/discover: simplify * p2p/discover: fix issue found by test * internal/flags: add missing flag types for auto-env-var generation (ethereum#28692) Certain flags, such as `--rpc.txfeecap` currently do not have an env-var auto-generated for them. This change adds three missing cli flag types to the auto env-var helper function to fix this. * cmd/evm: default to mirror mainnet forks enabled (ethereum#28691) cmd/evm: default to using dev chain config (all mainnet HFs activated at block/timestamp 0 * cmd/evm, cmd/clef, cmd/bootnode: fix / unify logging (ethereum#28696) This change fixes a problem with our non-core binaries: evm, clef, bootnode. First of all, they failed to convert from legacy loglevels 1 to 5, to the new slog loglevels -4 to 4. Secondly, the logging was actually setup in the init phase, and then overridden in the main. This is not needed for evm, since it used the same flag name as the main geth verbosity. Better to let the flags/internal handle the logging init. * cmd/evm: t8n support custom tracers (ethereum#28557) This change implements ability for the `evm t8n` tool to use custom tracers; either 'native' golang tracers or javascript tracers. * params: release go-ethereum v1.13.6 stable * Fix build errors * Fix test-integration --------- Co-authored-by: Guillaume Ballet <[email protected]> Co-authored-by: Sina Mahmoodi <[email protected]> Co-authored-by: Martin Holst Swende <[email protected]> Co-authored-by: VM <[email protected]> Co-authored-by: VM <[email protected]> Co-authored-by: jwasinger <[email protected]> Co-authored-by: Zoro <[email protected]> Co-authored-by: Håvard Anda Estensen <[email protected]> Co-authored-by: aliening <[email protected]> Co-authored-by: Halimao <[email protected]> Co-authored-by: danceratopz <[email protected]> Co-authored-by: levisyin <[email protected]> Co-authored-by: jp-imx <[email protected]> Co-authored-by: rjl493456442 <[email protected]> Co-authored-by: Haotian <[email protected]> Co-authored-by: haotian <[email protected]> Co-authored-by: Marius van der Wijden <[email protected]> Co-authored-by: Maciej Kulawik <[email protected]> Co-authored-by: ucwong <[email protected]> Co-authored-by: Mario Vega <[email protected]> Co-authored-by: Delweng <[email protected]> Co-authored-by: Felix Lange <[email protected]> Co-authored-by: lightclient <[email protected]> Co-authored-by: Mikel Cortes <[email protected]> Co-authored-by: Péter Szilágyi <[email protected]> Co-authored-by: Ng Wei Han <[email protected]> Co-authored-by: lightclient <[email protected]> Co-authored-by: Shivam Sandbhor <[email protected]> Co-authored-by: Jakub Freebit <[email protected]> Co-authored-by: Oren <[email protected]> Co-authored-by: BorkBorked <[email protected]> Co-authored-by: ddl <[email protected]> Co-authored-by: Manav Darji <[email protected]> Co-authored-by: Marius Kjærstad <[email protected]> Co-authored-by: Felföldi Zsolt <[email protected]> Co-authored-by: Ford <[email protected]> Co-authored-by: Ursulafe <[email protected]> Co-authored-by: Elias Rad <[email protected]> Co-authored-by: FletcherMan <[email protected]> Co-authored-by: alex <[email protected]> Co-authored-by: Sebastian Stammler <[email protected]>
1 parent 4a03cc0 commit 7e2be02

File tree

359 files changed

+6633
-30933
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

359 files changed

+6633
-30933
lines changed

.github/workflows/go.yml

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
name: i386 linux tests
2+
3+
on:
4+
push:
5+
branches: [ master ]
6+
pull_request:
7+
branches: [ master ]
8+
workflow_dispatch:
9+
10+
jobs:
11+
build:
12+
runs-on: self-hosted
13+
steps:
14+
- uses: actions/checkout@v2
15+
- name: Set up Go
16+
uses: actions/setup-go@v2
17+
with:
18+
go-version: 1.21.4
19+
- name: Run tests
20+
run: go test ./...
21+
env:
22+
GOOS: linux
23+
GOARCH: 386

accounts/abi/abi.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -274,7 +274,7 @@ var revertSelector = crypto.Keccak256([]byte("Error(string)"))[:4]
274274
var panicSelector = crypto.Keccak256([]byte("Panic(uint256)"))[:4]
275275

276276
// panicReasons map is for readable panic codes
277-
// see this linkage for the deails
277+
// see this linkage for the details
278278
// https://docs.soliditylang.org/en/v0.8.21/control-structures.html#panic-via-assert-and-error-via-require
279279
// the reason string list is copied from ether.js
280280
// https://github.com/ethers-io/ethers.js/blob/fa3a883ff7c88611ce766f58bdd4b8ac90814470/src.ts/abi/interface.ts#L207-L218

accounts/abi/abi_test.go

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -120,6 +120,7 @@ var methods = map[string]Method{
120120
}
121121

122122
func TestReader(t *testing.T) {
123+
t.Parallel()
123124
abi := ABI{
124125
Methods: methods,
125126
}
@@ -153,6 +154,7 @@ func TestReader(t *testing.T) {
153154
}
154155

155156
func TestInvalidABI(t *testing.T) {
157+
t.Parallel()
156158
json := `[{ "type" : "function", "name" : "", "constant" : fals }]`
157159

158160
_, err := JSON(strings.NewReader(json))
@@ -175,6 +177,7 @@ func TestInvalidABI(t *testing.T) {
175177
// constructor(uint256 a, uint256 b) public{}
176178
// }
177179
func TestConstructor(t *testing.T) {
180+
t.Parallel()
178181
json := `[{ "inputs": [{"internalType": "uint256","name": "a","type": "uint256" },{ "internalType": "uint256","name": "b","type": "uint256"}],"stateMutability": "nonpayable","type": "constructor"}]`
179182
method := NewMethod("", "", Constructor, "nonpayable", false, false, []Argument{{"a", Uint256, false}, {"b", Uint256, false}}, nil)
180183
// Test from JSON
@@ -207,6 +210,7 @@ func TestConstructor(t *testing.T) {
207210
}
208211

209212
func TestTestNumbers(t *testing.T) {
213+
t.Parallel()
210214
abi, err := JSON(strings.NewReader(jsondata))
211215
if err != nil {
212216
t.Fatal(err)
@@ -245,6 +249,7 @@ func TestTestNumbers(t *testing.T) {
245249
}
246250

247251
func TestMethodSignature(t *testing.T) {
252+
t.Parallel()
248253
m := NewMethod("foo", "foo", Function, "", false, false, []Argument{{"bar", String, false}, {"baz", String, false}}, nil)
249254
exp := "foo(string,string)"
250255

@@ -286,6 +291,7 @@ func TestMethodSignature(t *testing.T) {
286291
}
287292

288293
func TestOverloadedMethodSignature(t *testing.T) {
294+
t.Parallel()
289295
json := `[{"constant":true,"inputs":[{"name":"i","type":"uint256"},{"name":"j","type":"uint256"}],"name":"foo","outputs":[],"payable":false,"stateMutability":"pure","type":"function"},{"constant":true,"inputs":[{"name":"i","type":"uint256"}],"name":"foo","outputs":[],"payable":false,"stateMutability":"pure","type":"function"},{"anonymous":false,"inputs":[{"indexed":false,"name":"i","type":"uint256"}],"name":"bar","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"i","type":"uint256"},{"indexed":false,"name":"j","type":"uint256"}],"name":"bar","type":"event"}]`
290296

291297
abi, err := JSON(strings.NewReader(json))
@@ -311,6 +317,7 @@ func TestOverloadedMethodSignature(t *testing.T) {
311317
}
312318

313319
func TestCustomErrors(t *testing.T) {
320+
t.Parallel()
314321
json := `[{ "inputs": [ { "internalType": "uint256", "name": "", "type": "uint256" } ],"name": "MyError", "type": "error"} ]`
315322

316323
abi, err := JSON(strings.NewReader(json))
@@ -327,6 +334,7 @@ func TestCustomErrors(t *testing.T) {
327334
}
328335

329336
func TestMultiPack(t *testing.T) {
337+
t.Parallel()
330338
abi, err := JSON(strings.NewReader(jsondata))
331339
if err != nil {
332340
t.Fatal(err)
@@ -366,6 +374,7 @@ func ExampleJSON() {
366374
}
367375

368376
func TestInputVariableInputLength(t *testing.T) {
377+
t.Parallel()
369378
const definition = `[
370379
{ "type" : "function", "name" : "strOne", "constant" : true, "inputs" : [ { "name" : "str", "type" : "string" } ] },
371380
{ "type" : "function", "name" : "bytesOne", "constant" : true, "inputs" : [ { "name" : "str", "type" : "bytes" } ] },
@@ -498,6 +507,7 @@ func TestInputVariableInputLength(t *testing.T) {
498507
}
499508

500509
func TestInputFixedArrayAndVariableInputLength(t *testing.T) {
510+
t.Parallel()
501511
abi, err := JSON(strings.NewReader(jsondata))
502512
if err != nil {
503513
t.Error(err)
@@ -682,6 +692,7 @@ func TestInputFixedArrayAndVariableInputLength(t *testing.T) {
682692
}
683693

684694
func TestDefaultFunctionParsing(t *testing.T) {
695+
t.Parallel()
685696
const definition = `[{ "name" : "balance", "type" : "function" }]`
686697

687698
abi, err := JSON(strings.NewReader(definition))
@@ -695,6 +706,7 @@ func TestDefaultFunctionParsing(t *testing.T) {
695706
}
696707

697708
func TestBareEvents(t *testing.T) {
709+
t.Parallel()
698710
const definition = `[
699711
{ "type" : "event", "name" : "balance" },
700712
{ "type" : "event", "name" : "anon", "anonymous" : true},
@@ -776,6 +788,7 @@ func TestBareEvents(t *testing.T) {
776788
//
777789
// receipt{status=1 cgas=23949 bloom=00000000004000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000040200000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 logs=[log: b6818c8064f645cd82d99b59a1a267d6d61117ef [75fd880d39c1daf53b6547ab6cb59451fc6452d27caa90e5b6649dd8293b9eed] 000000000000000000000000376c47978271565f56deb45495afa69e59c16ab200000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000060000000000000000000000000000000000000000000000000000000000000000158 9ae378b6d4409eada347a5dc0c180f186cb62dc68fcc0f043425eb917335aa28 0 95d429d309bb9d753954195fe2d69bd140b4ae731b9b5b605c34323de162cf00 0]}
778790
func TestUnpackEvent(t *testing.T) {
791+
t.Parallel()
779792
const abiJSON = `[{"constant":false,"inputs":[{"name":"memo","type":"bytes"}],"name":"receive","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"anonymous":false,"inputs":[{"indexed":false,"name":"sender","type":"address"},{"indexed":false,"name":"amount","type":"uint256"},{"indexed":false,"name":"memo","type":"bytes"}],"name":"received","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"sender","type":"address"}],"name":"receivedAddr","type":"event"}]`
780793

781794
abi, err := JSON(strings.NewReader(abiJSON))
@@ -820,6 +833,7 @@ func TestUnpackEvent(t *testing.T) {
820833
}
821834

822835
func TestUnpackEventIntoMap(t *testing.T) {
836+
t.Parallel()
823837
const abiJSON = `[{"constant":false,"inputs":[{"name":"memo","type":"bytes"}],"name":"receive","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"anonymous":false,"inputs":[{"indexed":false,"name":"sender","type":"address"},{"indexed":false,"name":"amount","type":"uint256"},{"indexed":false,"name":"memo","type":"bytes"}],"name":"received","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"sender","type":"address"}],"name":"receivedAddr","type":"event"}]`
824838

825839
abi, err := JSON(strings.NewReader(abiJSON))
@@ -880,6 +894,7 @@ func TestUnpackEventIntoMap(t *testing.T) {
880894
}
881895

882896
func TestUnpackMethodIntoMap(t *testing.T) {
897+
t.Parallel()
883898
const abiJSON = `[{"constant":false,"inputs":[{"name":"memo","type":"bytes"}],"name":"receive","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[],"name":"send","outputs":[{"name":"amount","type":"uint256"}],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[{"name":"addr","type":"address"}],"name":"get","outputs":[{"name":"hash","type":"bytes"}],"payable":true,"stateMutability":"payable","type":"function"}]`
884899

885900
abi, err := JSON(strings.NewReader(abiJSON))
@@ -939,6 +954,7 @@ func TestUnpackMethodIntoMap(t *testing.T) {
939954
}
940955

941956
func TestUnpackIntoMapNamingConflict(t *testing.T) {
957+
t.Parallel()
942958
// Two methods have the same name
943959
var abiJSON = `[{"constant":false,"inputs":[{"name":"memo","type":"bytes"}],"name":"get","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[],"name":"send","outputs":[{"name":"amount","type":"uint256"}],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[{"name":"addr","type":"address"}],"name":"get","outputs":[{"name":"hash","type":"bytes"}],"payable":true,"stateMutability":"payable","type":"function"}]`
944960

@@ -1043,6 +1059,7 @@ func TestUnpackIntoMapNamingConflict(t *testing.T) {
10431059
}
10441060

10451061
func TestABI_MethodById(t *testing.T) {
1062+
t.Parallel()
10461063
abi, err := JSON(strings.NewReader(jsondata))
10471064
if err != nil {
10481065
t.Fatal(err)
@@ -1080,6 +1097,7 @@ func TestABI_MethodById(t *testing.T) {
10801097
}
10811098

10821099
func TestABI_EventById(t *testing.T) {
1100+
t.Parallel()
10831101
tests := []struct {
10841102
name string
10851103
json string
@@ -1149,6 +1167,7 @@ func TestABI_EventById(t *testing.T) {
11491167
}
11501168

11511169
func TestABI_ErrorByID(t *testing.T) {
1170+
t.Parallel()
11521171
abi, err := JSON(strings.NewReader(`[
11531172
{"inputs":[{"internalType":"uint256","name":"x","type":"uint256"}],"name":"MyError1","type":"error"},
11541173
{"inputs":[{"components":[{"internalType":"uint256","name":"a","type":"uint256"},{"internalType":"string","name":"b","type":"string"},{"internalType":"address","name":"c","type":"address"}],"internalType":"struct MyError.MyStruct","name":"x","type":"tuple"},{"internalType":"address","name":"y","type":"address"},{"components":[{"internalType":"uint256","name":"a","type":"uint256"},{"internalType":"string","name":"b","type":"string"},{"internalType":"address","name":"c","type":"address"}],"internalType":"struct MyError.MyStruct","name":"z","type":"tuple"}],"name":"MyError2","type":"error"},
@@ -1179,6 +1198,7 @@ func TestABI_ErrorByID(t *testing.T) {
11791198
// TestDoubleDuplicateMethodNames checks that if transfer0 already exists, there won't be a name
11801199
// conflict and that the second transfer method will be renamed transfer1.
11811200
func TestDoubleDuplicateMethodNames(t *testing.T) {
1201+
t.Parallel()
11821202
abiJSON := `[{"constant":false,"inputs":[{"name":"to","type":"address"},{"name":"value","type":"uint256"}],"name":"transfer","outputs":[{"name":"ok","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"to","type":"address"},{"name":"value","type":"uint256"},{"name":"data","type":"bytes"}],"name":"transfer0","outputs":[{"name":"ok","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"to","type":"address"},{"name":"value","type":"uint256"},{"name":"data","type":"bytes"},{"name":"customFallback","type":"string"}],"name":"transfer","outputs":[{"name":"ok","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"}]`
11831203

11841204
contractAbi, err := JSON(strings.NewReader(abiJSON))
@@ -1213,6 +1233,7 @@ func TestDoubleDuplicateMethodNames(t *testing.T) {
12131233
// event send();
12141234
// }
12151235
func TestDoubleDuplicateEventNames(t *testing.T) {
1236+
t.Parallel()
12161237
abiJSON := `[{"anonymous": false,"inputs": [{"indexed": false,"internalType": "uint256","name": "a","type": "uint256"}],"name": "send","type": "event"},{"anonymous": false,"inputs": [],"name": "send0","type": "event"},{ "anonymous": false, "inputs": [],"name": "send","type": "event"}]`
12171238

12181239
contractAbi, err := JSON(strings.NewReader(abiJSON))
@@ -1245,6 +1266,7 @@ func TestDoubleDuplicateEventNames(t *testing.T) {
12451266
// event send(uint256, uint256);
12461267
// }
12471268
func TestUnnamedEventParam(t *testing.T) {
1269+
t.Parallel()
12481270
abiJSON := `[{ "anonymous": false, "inputs": [{ "indexed": false,"internalType": "uint256", "name": "","type": "uint256"},{"indexed": false,"internalType": "uint256","name": "","type": "uint256"}],"name": "send","type": "event"}]`
12491271

12501272
contractAbi, err := JSON(strings.NewReader(abiJSON))
@@ -1282,7 +1304,9 @@ func TestUnpackRevert(t *testing.T) {
12821304
}
12831305

12841306
for index, c := range cases {
1307+
index, c := index, c
12851308
t.Run(fmt.Sprintf("case %d", index), func(t *testing.T) {
1309+
t.Parallel()
12861310
got, err := UnpackRevert(common.Hex2Bytes(c.input))
12871311
if c.expectErr != nil {
12881312
if err == nil {

tests/fuzzers/abi/abifuzzer_test.go renamed to accounts/abi/abifuzzer_test.go

Lines changed: 56 additions & 58 deletions
Original file line numberDiff line numberDiff line change
@@ -22,33 +22,32 @@ import (
2222
"strings"
2323
"testing"
2424

25-
"github.com/ethereum/go-ethereum/accounts/abi"
2625
fuzz "github.com/google/gofuzz"
2726
)
2827

2928
// TestReplicate can be used to replicate crashers from the fuzzing tests.
3029
// Just replace testString with the data in .quoted
3130
func TestReplicate(t *testing.T) {
32-
testString := "\x20\x20\x20\x20\x20\x20\x20\x20\x80\x00\x00\x00\x20\x20\x20\x20\x00"
33-
data := []byte(testString)
34-
fuzzAbi(data)
31+
t.Parallel()
32+
//t.Skip("Test only useful for reproducing issues")
33+
fuzzAbi([]byte("\x20\x20\x20\x20\x20\x20\x20\x20\x80\x00\x00\x00\x20\x20\x20\x20\x00"))
34+
//fuzzAbi([]byte("asdfasdfkadsf;lasdf;lasd;lfk"))
3535
}
3636

37-
func Fuzz(f *testing.F) {
37+
// FuzzABI is the main entrypoint for fuzzing
38+
func FuzzABI(f *testing.F) {
3839
f.Fuzz(func(t *testing.T, data []byte) {
3940
fuzzAbi(data)
4041
})
4142
}
4243

4344
var (
44-
names = []string{"_name", "name", "NAME", "name_", "__", "_name_", "n"}
45-
stateMut = []string{"", "pure", "view", "payable"}
46-
stateMutabilites = []*string{&stateMut[0], &stateMut[1], &stateMut[2], &stateMut[3]}
47-
pays = []string{"", "true", "false"}
48-
payables = []*string{&pays[0], &pays[1]}
49-
vNames = []string{"a", "b", "c", "d", "e", "f", "g"}
50-
varNames = append(vNames, names...)
51-
varTypes = []string{"bool", "address", "bytes", "string",
45+
names = []string{"_name", "name", "NAME", "name_", "__", "_name_", "n"}
46+
stateMut = []string{"pure", "view", "payable"}
47+
pays = []string{"true", "false"}
48+
vNames = []string{"a", "b", "c", "d", "e", "f", "g"}
49+
varNames = append(vNames, names...)
50+
varTypes = []string{"bool", "address", "bytes", "string",
5251
"uint8", "int8", "uint8", "int8", "uint16", "int16",
5352
"uint24", "int24", "uint32", "int32", "uint40", "int40", "uint48", "int48", "uint56", "int56",
5453
"uint64", "int64", "uint72", "int72", "uint80", "int80", "uint88", "int88", "uint96", "int96",
@@ -62,7 +61,7 @@ var (
6261
"bytes32", "bytes"}
6362
)
6463

65-
func unpackPack(abi abi.ABI, method string, input []byte) ([]interface{}, bool) {
64+
func unpackPack(abi ABI, method string, input []byte) ([]interface{}, bool) {
6665
if out, err := abi.Unpack(method, input); err == nil {
6766
_, err := abi.Pack(method, out...)
6867
if err != nil {
@@ -78,7 +77,7 @@ func unpackPack(abi abi.ABI, method string, input []byte) ([]interface{}, bool)
7877
return nil, false
7978
}
8079

81-
func packUnpack(abi abi.ABI, method string, input *[]interface{}) bool {
80+
func packUnpack(abi ABI, method string, input *[]interface{}) bool {
8281
if packed, err := abi.Pack(method, input); err == nil {
8382
outptr := reflect.New(reflect.TypeOf(input))
8483
err := abi.UnpackIntoInterface(outptr.Interface(), method, packed)
@@ -94,12 +93,12 @@ func packUnpack(abi abi.ABI, method string, input *[]interface{}) bool {
9493
return false
9594
}
9695

97-
type args struct {
96+
type arg struct {
9897
name string
9998
typ string
10099
}
101100

102-
func createABI(name string, stateMutability, payable *string, inputs []args) (abi.ABI, error) {
101+
func createABI(name string, stateMutability, payable *string, inputs []arg) (ABI, error) {
103102
sig := fmt.Sprintf(`[{ "type" : "function", "name" : "%v" `, name)
104103
if stateMutability != nil {
105104
sig += fmt.Sprintf(`, "stateMutability": "%v" `, *stateMutability)
@@ -126,56 +125,55 @@ func createABI(name string, stateMutability, payable *string, inputs []args) (ab
126125
sig += "} ]"
127126
}
128127
sig += `}]`
129-
130-
return abi.JSON(strings.NewReader(sig))
128+
//fmt.Printf("sig: %s\n", sig)
129+
return JSON(strings.NewReader(sig))
131130
}
132131

133-
func fuzzAbi(input []byte) int {
134-
good := false
135-
fuzzer := fuzz.NewFromGoFuzz(input)
136-
137-
name := names[getUInt(fuzzer)%len(names)]
138-
stateM := stateMutabilites[getUInt(fuzzer)%len(stateMutabilites)]
139-
payable := payables[getUInt(fuzzer)%len(payables)]
140-
maxLen := 5
141-
for k := 1; k < maxLen; k++ {
142-
var arg []args
143-
for i := k; i > 0; i-- {
144-
argName := varNames[i]
145-
argTyp := varTypes[getUInt(fuzzer)%len(varTypes)]
146-
if getUInt(fuzzer)%10 == 0 {
147-
argTyp += "[]"
148-
} else if getUInt(fuzzer)%10 == 0 {
149-
arrayArgs := getUInt(fuzzer)%30 + 1
150-
argTyp += fmt.Sprintf("[%d]", arrayArgs)
151-
}
152-
arg = append(arg, args{
153-
name: argName,
154-
typ: argTyp,
155-
})
132+
func fuzzAbi(input []byte) {
133+
var (
134+
fuzzer = fuzz.NewFromGoFuzz(input)
135+
name = oneOf(fuzzer, names)
136+
stateM = oneOfOrNil(fuzzer, stateMut)
137+
payable = oneOfOrNil(fuzzer, pays)
138+
arguments []arg
139+
)
140+
for i := 0; i < upTo(fuzzer, 10); i++ {
141+
argName := oneOf(fuzzer, varNames)
142+
argTyp := oneOf(fuzzer, varTypes)
143+
switch upTo(fuzzer, 10) {
144+
case 0: // 10% chance to make it a slice
145+
argTyp += "[]"
146+
case 1: // 10% chance to make it an array
147+
argTyp += fmt.Sprintf("[%d]", 1+upTo(fuzzer, 30))
148+
default:
156149
}
157-
abi, err := createABI(name, stateM, payable, arg)
158-
if err != nil {
159-
continue
160-
}
161-
structs, b := unpackPack(abi, name, input)
162-
c := packUnpack(abi, name, &structs)
163-
good = good || b || c
150+
arguments = append(arguments, arg{name: argName, typ: argTyp})
164151
}
165-
if good {
166-
return 1
152+
abi, err := createABI(name, stateM, payable, arguments)
153+
if err != nil {
154+
//fmt.Printf("err: %v\n", err)
155+
panic(err)
167156
}
168-
return 0
157+
structs, _ := unpackPack(abi, name, input)
158+
_ = packUnpack(abi, name, &structs)
169159
}
170160

171-
func getUInt(fuzzer *fuzz.Fuzzer) int {
161+
func upTo(fuzzer *fuzz.Fuzzer, max int) int {
172162
var i int
173163
fuzzer.Fuzz(&i)
174164
if i < 0 {
175-
i = -i
176-
if i < 0 {
177-
return 0
178-
}
165+
return (-1 - i) % max
166+
}
167+
return i % max
168+
}
169+
170+
func oneOf(fuzzer *fuzz.Fuzzer, options []string) string {
171+
return options[upTo(fuzzer, len(options))]
172+
}
173+
174+
func oneOfOrNil(fuzzer *fuzz.Fuzzer, options []string) *string {
175+
if i := upTo(fuzzer, len(options)+1); i < len(options) {
176+
return &options[i]
179177
}
180-
return i
178+
return nil
181179
}

0 commit comments

Comments
 (0)