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

[Upgrade] Go-Ethereum release v1.9.13 #1123

Merged
merged 125 commits into from
Feb 12, 2021
Merged
Show file tree
Hide file tree
Changes from 122 commits
Commits
Show all changes
125 commits
Select commit Hold shift + click to select a range
542df88
core: initial version of state snapshots
karalabe Aug 6, 2019
e146fbe
core/state: lazy sorting, snapshot invalidation
holiman Oct 4, 2019
d7d81d7
core/state/snapshot: extract and split cap method, cover corners
karalabe Oct 17, 2019
cdf3f01
snapshot: iteration and buffering optimizations
holiman Oct 23, 2019
d754091
core/state/snapshot: unlink snapshots from blocks, quad->linear cleanup
karalabe Nov 22, 2019
f300c0d
core/state/snapshot: replace bigcache with fastcache
holiman Nov 25, 2019
351a590
core/rawdb, core/state/snapshot: runtime snapshot generation
karalabe Nov 26, 2019
d5d7c0c
core/state/snapshot: fix difflayer origin-initalization after flatten
holiman Dec 1, 2019
fd39f72
core: journal the snapshot inside leveldb, not a flat file
karalabe Dec 2, 2019
3ad4335
core/state/snapshot: node behavioural difference on bloom content
holiman Dec 2, 2019
22c494d
core/state/snapshot: bloom, metrics and prefetcher fixes
karalabe Dec 3, 2019
7e38996
core/state/snapshot: implement snapshot layer iteration
holiman Nov 5, 2019
e567675
core/state/snapshot: move iterator out into its own files
karalabe Dec 5, 2019
e570835
core/state/snapshot: implement iterator priority for fast direct data…
holiman Dec 6, 2019
6ddb92a
core/state/snapshot: full featured account iteration
karalabe Dec 10, 2019
1909942
core/state/snapshot: faster account iteration, CLI integration
holiman Jan 19, 2020
06d4470
core: fix broken tests due to API changes + linter
karalabe Feb 24, 2020
92ec07d
core/state: fix an account resurrection issue
karalabe Feb 27, 2020
361a6f0
core/tests: test for destroy+recreate contract with storage
holiman Mar 2, 2020
fe8347e
squashme
holiman Mar 2, 2020
6e05ccd
core/state/snapshot, tests: sync snap gen + snaps in consensus tests
karalabe Mar 3, 2020
a4cf279
core/state: extend snapshotter to handle account resurrections
karalabe Mar 3, 2020
dcb22a9
core/state: fix account root hash update point
karalabe Mar 3, 2020
328de18
core/state: fix resurrection state clearing and access
karalabe Mar 4, 2020
eff7cfb
core/state/snapshot: handle deleted accounts in fast iterator
holiman Mar 4, 2020
bc5d742
core: more blockchain tests
holiman Mar 4, 2020
fab0ee3
core/state/snapshot: fix various iteration issues due to destruct set
karalabe Mar 4, 2020
8d7aa90
params: begin v1.9.13 release cycle
karalabe Mar 16, 2020
efd92d8
cmd/checkpoint-admin: add some documentation (#20697)
rjl493456442 Mar 18, 2020
5dd0cd1
go.mod: update duktape to fix sprintf warnings (#20777)
moreati Mar 18, 2020
20a092f
core/rawdb: fix freezer table test error check
meowsbits Mar 18, 2020
6283391
core/rawdb: improve table database (#20703)
rjl493456442 Mar 18, 2020
dc6e98d
eth: when triggering a sync, check the head header TD, not block
karalabe Mar 18, 2020
4655b60
Merge pull request #20780 from karalabe/fix-eth-mine-sync-race
karalabe Mar 18, 2020
e6ca195
internal/web3ext: fix clique console apis to work on missing arguments
karalabe Mar 18, 2020
36e93d2
Merge pull request #20779 from meowsbits/patch-3
karalabe Mar 18, 2020
0e6ea91
Merge pull request #20781 from karalabe/fix-clique-console-apis
karalabe Mar 19, 2020
e943f07
whisper/whisperv6: delete failing tests (#20788)
gballet Mar 20, 2020
93ffb85
rpc: dont log an error if user configures --rpcapi=rpc... (#20776)
meowsbits Mar 21, 2020
074efe6
core: fix two snapshot iterator flaws, decollide snap storage prefix
holiman Mar 6, 2020
613af7c
Merge pull request #20152 from karalabe/snapshot-5
karalabe Mar 23, 2020
a75c061
core/blockchain: simplify atomic store after writeBlockWithState (#20…
meowsbits Mar 23, 2020
0734c4b
node, cmd/clef: report actual port used for http rpc (#20789)
holiman Mar 23, 2020
39f5023
internal/ethapi: don't set sender-balance to maxuint, fixes #16999 (#…
holiman Mar 23, 2020
42e02ac
metrics: disable CPU stats (gosigar) on iOS
karalabe Mar 26, 2020
4690912
Merge pull request #20816 from karalabe/disable-gosigar-ios
karalabe Mar 26, 2020
1583e7d
cmd/devp2p: tweak DNS TTLs (#20801)
fjl Mar 26, 2020
87a411b
cmd/devp2p: lower route53 change limit again (#20819)
fjl Mar 26, 2020
d3c1e65
cmd/devp2p: be very correct about route53 change splitting (#20820)
fjl Mar 26, 2020
d7851e6
graphql, node, rpc: fix typos in comments (#20824)
renaynay Mar 27, 2020
d6c5f24
eth: improve shutdown synchronization (#20695)
fjl Mar 27, 2020
62cd943
les: fix dead lock (#20828)
rjl493456442 Mar 27, 2020
5d7e5b0
eth/filters: fix typo on unindexedLogs function's comment (#20827)
hadv Mar 27, 2020
55a73f5
core: bump txpool tx max size to 128KB
holiman Mar 30, 2020
84f4975
Merge pull request #20835 from holiman/bump
karalabe Mar 30, 2020
76eed9e
snapshotter/tests: verify snapdb post-state against trie (#20812)
holiman Mar 31, 2020
8f05cfa
cmd, consensus: add option to disable mmap for DAG caches/datasets (#…
de1acr0ix Mar 31, 2020
c56f4fa
cmd/clef: add newaccount command (#20782)
holiman Mar 31, 2020
03fe9de
eth: add debug_accountRange API (#19645)
jsvisa Mar 31, 2020
300c35b
travis: allow cocoapods deploy to fail (#20833)
adamschmideg Mar 31, 2020
3b69c14
whisper/whisperv6: decrease pow requirement in tests (#20815)
holiman Mar 31, 2020
32d31c3
metrics: improve TestTimerFunc (#20818)
holiman Mar 31, 2020
f78ffc0
les: create utilities as common package (#20509)
rjl493456442 Mar 31, 2020
f0be151
README: update private network genesis spec with istanbul (#20841)
shoenseiwaso Mar 31, 2020
a5a9fea
whisper: fix whisper go routine leak with sync wait group (#20844)
ucwong Apr 1, 2020
d56dc03
cmd/evm: Rework execution stats (#20792)
chfast Apr 1, 2020
1e2e1b4
cmd/devp2p, cmd/wnode, whisper: add missing calls to Timer.Stop (#20843)
ucwong Apr 1, 2020
bf35e27
p2p/server: add UDP port mapping goroutine to wait group (#20846)
ucwong Apr 1, 2020
f15849c
accounts/abi faster unpacking of int256 (#20850)
MariusVanDerWijden Apr 1, 2020
c87cdd3
p2p/discv5: add missing Timer.Stop calls (#20853)
ucwong Apr 2, 2020
ad4b60e
miner/worker: add missing timer.Stop call (#20857)
ucwong Apr 2, 2020
228a297
cmd/geth: fix bad genesis test (#20860)
holiman Apr 2, 2020
47f7c73
eth/filters: add missing Ticker.Stop call (#20862)
ucwong Apr 2, 2020
66ed58b
eth/fetcher: add missing timer.Stop calls (#20861)
ucwong Apr 2, 2020
4d891f2
les: add missing Ticker.Stop call (#20864)
ucwong Apr 2, 2020
0893ee6
event: add missing timer.Stop call in TestFeed (#20868)
ucwong Apr 2, 2020
53e034c
metrics: add missing calls to Ticker.Stop in tests (#20866)
ucwong Apr 2, 2020
37d6357
ethstats: add missing Ticker.Stop call (#20867)
ucwong Apr 2, 2020
0c359e4
p2p/discv5, p2p/testing: add missing Timer.Stop calls in tests (#20869)
ucwong Apr 2, 2020
f98caba
core: add missing Timer.Stop call in TestLogReorgs (#20870)
ucwong Apr 2, 2020
f7b29ec
rpc: add missing timer.Stop calls in websocket tests (#20863)
ucwong Apr 2, 2020
462ddce
crypto/ecies: improve concatKDF (#20836)
lukechampine Apr 3, 2020
be9172a
rpc: metrics for JSON-RPC method calls (#20847)
rjl493456442 Apr 3, 2020
98eab2d
mobile: use bind.NewKeyedTransactor instead of duplicating (#20888)
MariusVanDerWijden Apr 3, 2020
be6078a
all: fix a bunch of inconsequential goroutine leaks (#20667)
BurtonQin Apr 3, 2020
3cf7d2e
internal/ethapi: add CallArgs.ToMessage method (#20854)
wjmelements Apr 3, 2020
f0b5eb0
eth, les: fix flaky tests (#20897)
rjl493456442 Apr 7, 2020
0bec6a4
cmd/geth: enable metrics for geth import command (#20738)
holiman Apr 7, 2020
8dc8941
core/vm: use a callcontext struct (#20761)
holiman Apr 7, 2020
094996b
docs/audits: add discv5 protocol audits from LA and C53 (#20898)
holiman Apr 7, 2020
6a3daa2
.github: change gitter reference to discord link in issue template (#…
adamschmideg Apr 7, 2020
671f22b
couple of fixes to docs in clef (#20900)
renaynay Apr 7, 2020
b7394d7
p2p/discover: add initial discovery v5 implementation (#20750)
fjl Apr 8, 2020
c8e9a91
build: upgrade to golangci-lint 1.24.0 (#20901)
fjl Apr 8, 2020
6975172
whisper/mailserver : recover corrupt db files before opening (#20891)
ucwong Apr 8, 2020
5065cde
accounts/abi/bind: Refactored topics (#20851)
MariusVanDerWijden Apr 8, 2020
07d909f
node: allow websocket and HTTP on the same port (#20810)
renaynay Apr 8, 2020
fe9ffa5
crypto: improve error messages in LoadECDSA (#20718)
adamschmideg Apr 8, 2020
1bad861
changed date of rpcstack.go since new file (#20904)
renaynay Apr 8, 2020
023b87b
accounts/abi/bind: fixed erroneous filtering of negative ints (#20865)
MariusVanDerWijden Apr 9, 2020
15540ae
cmd: deprecate --testnet, use named networks instead (#20852)
q9f Apr 9, 2020
0851646
les, les/lespay/client: add service value statistics and API (#20837)
zsfelfoldi Apr 9, 2020
5a20cc0
README: update min go version to 1.13 (#20911)
ligi Apr 14, 2020
eb2fd82
travis, appveyor, build, Dockerfile: bump Go to 1.14.2 (#20913)
karalabe Apr 14, 2020
2a836bb
core/rawdb: fix data race between Retrieve and Close (#20919)
MariusVanDerWijden Apr 14, 2020
00064dd
accounts/abi: implement new fallback functions (#20764)
rjl493456442 Apr 15, 2020
6402c42
all: simplify and fix database iteration with prefix/start (#20808)
holiman Apr 15, 2020
d77d35a
params: update CHTs for the 1.9.13 release
karalabe Apr 15, 2020
359d9c3
Merge pull request #20925 from karalabe/cht-1.9.13
karalabe Apr 15, 2020
cbc4ac2
params: release Geth v1.9.13
karalabe Apr 16, 2020
ea9eda5
backup
ricardolyn Feb 9, 2021
0cdce11
Merge branch 'public_master' into upgrade/go-ethereum/v1.9.13-2021204…
ricardolyn Feb 9, 2021
e54fc49
fix: apply valid test cases for core/genesis_test.go, that should wor…
ricardolyn Feb 9, 2021
f95ea04
lint: fix lint issues
ricardolyn Feb 9, 2021
712bfcc
Merge branch 'master' into upgrade/go-ethereum/v1.9.13-2021204155332
ricardolyn Feb 9, 2021
29dd4ef
test: fix TestTransactionAllowedTxSize by using the custom transactio…
ricardolyn Feb 9, 2021
78f1334
lint: increase timeout
ricardolyn Feb 9, 2021
9cb6332
Merge branch 'master' of github.com:ConsenSys/quorum into upgrade/go-…
ricardolyn Feb 10, 2021
8420dd2
Merge branch 'master' into upgrade/go-ethereum/v1.9.13-2021204155332
ricardolyn Feb 10, 2021
15c2473
improvement: Created NewDual function to create pub and priv state at…
ricardolyn Feb 10, 2021
151602e
workflow: add 2 new AT
ricardolyn Feb 10, 2021
695ed71
workflow: remove extra ATs
ricardolyn Feb 11, 2021
1171737
fix: comments from review
ricardolyn Feb 12, 2021
1f871ab
Merge branch 'public_master' into upgrade/go-ethereum/v1.9.13-2021204…
ricardolyn Feb 12, 2021
e87075f
fix: tests and build issues
ricardolyn Feb 12, 2021
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/ISSUE_TEMPLATE.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ Hi there,

Please note that this is an issue tracker reserved for bug reports and feature requests.

For general questions please use the gitter channel or the Ethereum stack exchange at https://ethereum.stackexchange.com.
For general questions please use [discord](https://discord.gg/nthXNEv) or the Ethereum stack exchange at https://ethereum.stackexchange.com.

#### System information

Expand Down
65 changes: 52 additions & 13 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,21 @@ language: go
go_import_path: github.com/ethereum/go-ethereum
sudo: false
jobs:
allow_failures:
- stage: build
os: osx
go: 1.14.x
env:
- azure-osx
- azure-ios
- cocoapods-ios

include:
# This builder only tests code linters on latest version of Go
- stage: lint
os: linux
dist: xenial
go: 1.13.x
go: 1.14.x
env:
- lint
git:
Expand Down Expand Up @@ -35,19 +44,46 @@ jobs:
- go run build/ci.go install
- go run build/ci.go test -coverage $TEST_PACKAGES

# These are the latest Go versions.
- stage: build
os: linux
dist: xenial
go: 1.13.x
env:
- GO111MODULE=on
script:
- go run build/ci.go install
- go run build/ci.go test -coverage $TEST_PACKAGES

# These are the latest Go versions.
- stage: build
os: linux
arch: amd64
dist: xenial
go: 1.14.x
env:
- GO111MODULE=on
script:
- go run build/ci.go install
- go run build/ci.go test -coverage $TEST_PACKAGES

- stage: build
if: type = pull_request
os: linux
arch: arm64
dist: xenial
go: 1.14.x
env:
- GO111MODULE=on
script:
- go run build/ci.go install
- go run build/ci.go test -coverage $TEST_PACKAGES

- stage: build
os: osx
osx_image: xcode11.3
go: 1.13.x
go: 1.14.x
env:
- GO111MODULE=on
script:
- echo "Increase the maximum number of open file descriptors on macOS"
- NOFILE=20480
Expand All @@ -66,9 +102,10 @@ jobs:
if: type = push
os: linux
dist: xenial
go: 1.13.x
go: 1.14.x
env:
- ubuntu-ppa
- GO111MODULE=on
git:
submodules: false # avoid cloning ethereum/tests
addons:
Expand All @@ -80,22 +117,20 @@ jobs:
- fakeroot
- python-bzrlib
- python-paramiko
cache:
directories:
- $HOME/.gobundle
script:
- echo '|1|7SiYPr9xl3uctzovOTj4gMwAC1M=|t6ReES75Bo/PxlOPJ6/GsGbTrM0= ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEA0aKz5UTUndYgIGG7dQBV+HaeuEZJ2xPHo2DS2iSKvUL4xNMSAY4UguNW+pX56nAQmZKIZZ8MaEvSj6zMEDiq6HFfn5JcTlM80UwlnyKe8B8p7Nk06PPQLrnmQt5fh0HmEcZx+JU9TZsfCHPnX7MNz4ELfZE6cFsclClrKim3BHUIGq//t93DllB+h4O9LHjEUsQ1Sr63irDLSutkLJD6RXchjROXkNirlcNVHH/jwLWR5RcYilNX7S5bIkK8NlWPjsn/8Ua5O7I9/YoE97PpO6i73DTGLh5H9JN/SITwCKBkgSDWUt61uPK3Y11Gty7o2lWsBjhBUm2Y38CBsoGmBw==' >> ~/.ssh/known_hosts
- go run build/ci.go debsrc -upload ethereum/ethereum -sftp-user geth-ci -signer "Go Ethereum Linux Builder <[email protected]>" -goversion 1.13.4 -gohash 95dbeab442ee2746b9acf0934c8e2fc26414a0565c008631b04addb8c02e7624 -gobundle $HOME/.gobundle/go.tar.gz
- go run build/ci.go debsrc -goversion 1.14.2 -upload ethereum/ethereum -sftp-user geth-ci -signer "Go Ethereum Linux Builder <[email protected]>"

# This builder does the Linux Azure uploads
- stage: build
if: type = push
os: linux
dist: xenial
sudo: required
go: 1.13.x
go: 1.14.x
env:
- azure-linux
- GO111MODULE=on
git:
submodules: false # avoid cloning ethereum/tests
addons:
Expand Down Expand Up @@ -129,9 +164,10 @@ jobs:
dist: xenial
services:
- docker
go: 1.13.x
go: 1.14.x
env:
- azure-linux-mips
- GO111MODULE=on
git:
submodules: false # avoid cloning ethereum/tests
script:
Expand Down Expand Up @@ -172,10 +208,11 @@ jobs:
env:
- azure-android
- maven-android
- GO111MODULE=on
git:
submodules: false # avoid cloning ethereum/tests
before_install:
- curl https://dl.google.com/go/go1.13.8.linux-amd64.tar.gz | tar -xz
- curl https://dl.google.com/go/go1.14.2.linux-amd64.tar.gz | tar -xz
- export PATH=`pwd`/go/bin:$PATH
- export GOROOT=`pwd`/go
- export GOPATH=$HOME/go
Expand All @@ -193,11 +230,12 @@ jobs:
- stage: build
if: type = push
os: osx
go: 1.13.x
go: 1.14.x
env:
- azure-osx
- azure-ios
- cocoapods-ios
- GO111MODULE=on
git:
submodules: false # avoid cloning ethereum/tests
script:
Expand All @@ -224,9 +262,10 @@ jobs:
if: type = cron
os: linux
dist: xenial
go: 1.13.x
go: 1.14.x
env:
- azure-purge
- GO111MODULE=on
git:
submodules: false # avoid cloning ethereum/tests
script:
Expand Down
2 changes: 1 addition & 1 deletion Dockerfile.alltools
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# Build Geth in a stock Go builder container
FROM golang:1.13-alpine as builder
FROM golang:1.14-alpine as builder

RUN apk add --no-cache make gcc musl-dev linux-headers git

Expand Down
116 changes: 100 additions & 16 deletions accounts/abi/abi.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ package abi
import (
"bytes"
"encoding/json"
"errors"
"fmt"
"io"

Expand All @@ -32,6 +33,12 @@ type ABI struct {
Constructor Method
Methods map[string]Method
Events map[string]Event

// Additional "special" functions introduced in solidity v0.6.0.
// It's separated from the original default fallback. Each contract
// can only define one fallback and receive function.
Fallback Method // Note it's also used to represent legacy fallback before v0.6.0
Receive Method
}

// JSON returns a parsed ABI interface and error if it failed.
Expand All @@ -42,7 +49,6 @@ func JSON(reader io.Reader) (ABI, error) {
if err := dec.Decode(&abi); err != nil {
return ABI{}, err
}

return abi, nil
}

Expand Down Expand Up @@ -108,13 +114,22 @@ func (abi ABI) UnpackIntoMap(v map[string]interface{}, name string, data []byte)
// UnmarshalJSON implements json.Unmarshaler interface
func (abi *ABI) UnmarshalJSON(data []byte) error {
var fields []struct {
Type string
Name string
Constant bool
Type string
Name string
Inputs []Argument
Outputs []Argument

// Status indicator which can be: "pure", "view",
// "nonpayable" or "payable".
StateMutability string
Anonymous bool
Inputs []Argument
Outputs []Argument

// Deprecated Status indicators, but removed in v0.6.0.
Constant bool // True if function is either pure or view
Payable bool // True if function is payable

// Event relevant indicator represents the event is
// declared as anonymous.
Anonymous bool
}
if err := json.Unmarshal(data, &fields); err != nil {
return err
Expand All @@ -126,22 +141,82 @@ func (abi *ABI) UnmarshalJSON(data []byte) error {
case "constructor":
abi.Constructor = Method{
Inputs: field.Inputs,

// Note for constructor the `StateMutability` can only
// be payable or nonpayable according to the output of
// compiler. So constant is always false.
StateMutability: field.StateMutability,

// Legacy fields, keep them for backward compatibility
Constant: field.Constant,
Payable: field.Payable,
}
// empty defaults to function according to the abi spec
case "function", "":
case "function":
name := field.Name
_, ok := abi.Methods[name]
for idx := 0; ok; idx++ {
name = fmt.Sprintf("%s%d", field.Name, idx)
_, ok = abi.Methods[name]
}
isConst := field.Constant || field.StateMutability == "pure" || field.StateMutability == "view"
abi.Methods[name] = Method{
Name: name,
RawName: field.Name,
Const: isConst,
Inputs: field.Inputs,
Outputs: field.Outputs,
Name: name,
RawName: field.Name,
StateMutability: field.StateMutability,
Inputs: field.Inputs,
Outputs: field.Outputs,

// Legacy fields, keep them for backward compatibility
Constant: field.Constant,
Payable: field.Payable,
}
case "fallback":
// New introduced function type in v0.6.0, check more detail
// here https://solidity.readthedocs.io/en/v0.6.0/contracts.html#fallback-function
if abi.HasFallback() {
return errors.New("only single fallback is allowed")
}
abi.Fallback = Method{
Name: "",
RawName: "",

// The `StateMutability` can only be payable or nonpayable,
// so the constant is always false.
StateMutability: field.StateMutability,
IsFallback: true,

// Fallback doesn't have any input or output
Inputs: nil,
Outputs: nil,

// Legacy fields, keep them for backward compatibility
Constant: field.Constant,
Payable: field.Payable,
}
case "receive":
// New introduced function type in v0.6.0, check more detail
// here https://solidity.readthedocs.io/en/v0.6.0/contracts.html#fallback-function
if abi.HasReceive() {
return errors.New("only single receive is allowed")
}
if field.StateMutability != "payable" {
return errors.New("the statemutability of receive can only be payable")
}
abi.Receive = Method{
Name: "",
RawName: "",

// The `StateMutability` can only be payable, so constant
// is always true while payable is always false.
StateMutability: field.StateMutability,
IsReceive: true,

// Receive doesn't have any input or output
Inputs: nil,
Outputs: nil,

// Legacy fields, keep them for backward compatibility
Constant: field.Constant,
Payable: field.Payable,
}
case "event":
name := field.Name
Expand All @@ -158,7 +233,6 @@ func (abi *ABI) UnmarshalJSON(data []byte) error {
}
}
}

return nil
}

Expand Down Expand Up @@ -186,3 +260,13 @@ func (abi *ABI) EventByID(topic common.Hash) (*Event, error) {
}
return nil, fmt.Errorf("no event with id: %#x", topic.Hex())
}

// HasFallback returns an indicator whether a fallback function is included.
func (abi *ABI) HasFallback() bool {
return abi.Fallback.IsFallback
}

// HasReceive returns an indicator whether a receive function is included.
func (abi *ABI) HasReceive() bool {
return abi.Receive.IsReceive
}
Loading