From a611a72e657fc57504c81e7b5f859cb1ad84725f Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Fri, 14 Jun 2024 16:22:49 +0000 Subject: [PATCH 01/17] DRAFT --- .github/workflows/test.yml | 11 + go.mod | 79 ++++--- go.sum | 207 ++++++++-------- tests/flows/teleporter_registry.go | 6 +- tests/flows/validator_churn.go | 16 +- tests/flows/validator_set_sig.go | 6 +- tests/interfaces/local_network.go | 8 +- tests/local/network.go | 363 ++++++++++++++++------------- tests/local/network_utils.go | 25 +- tests/utils/warp-genesis.json | 4 +- 10 files changed, 384 insertions(+), 341 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index ed3606688..095d1f068 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -69,3 +69,14 @@ jobs: export PATH=$PATH:$HOME/.foundry/bin export PATH="$PATH:$GOPATH/bin" ./scripts/local/e2e_test.sh + + - name: Upload tmpnet network dir + uses: actions/upload-artifact@v4 + if: always() + with: + name: e2e-tmpnet-data + path: | + ~/.tmpnet/networks + ~/.tmpnet/prometheus/prometheus.log + ~/.tmpnet/promtail/promtail.log + if-no-files-found: error diff --git a/go.mod b/go.mod index d5d3810e8..ad6a832a7 100644 --- a/go.mod +++ b/go.mod @@ -3,14 +3,13 @@ module github.com/ava-labs/teleporter go 1.21.12 require ( - github.com/ava-labs/avalanchego v1.11.1 + github.com/ava-labs/avalanchego v1.11.9-0.20240703222923-9d71967ccbba github.com/supranational/blst v0.3.11 // indirect ) require ( - github.com/ava-labs/avalanche-network-runner v1.7.6 - github.com/ava-labs/subnet-evm v0.6.1 - github.com/ethereum/go-ethereum v1.12.0 + github.com/ava-labs/subnet-evm v0.6.6 + github.com/ethereum/go-ethereum v1.13.8 github.com/onsi/ginkgo/v2 v2.19.0 github.com/onsi/gomega v1.33.1 github.com/pkg/errors v0.9.1 @@ -21,56 +20,62 @@ require ( require ( github.com/DataDog/zstd v1.5.2 // indirect - github.com/Microsoft/go-winio v0.5.2 // indirect github.com/NYTimes/gziphandler v1.1.1 // indirect - github.com/VictoriaMetrics/fastcache v1.10.0 // indirect - github.com/ava-labs/coreth v0.13.0-rc.0 // indirect + github.com/VictoriaMetrics/fastcache v1.12.1 // indirect + github.com/ava-labs/coreth v0.13.5-rc.0 // indirect github.com/beorn7/perks v1.0.1 // indirect + github.com/bits-and-blooms/bitset v1.10.0 // indirect github.com/btcsuite/btcd/btcec/v2 v2.3.2 // indirect github.com/btcsuite/btcd/btcutil v1.1.3 // indirect - github.com/cenkalti/backoff/v4 v4.1.3 // indirect + github.com/cenkalti/backoff/v4 v4.2.1 // indirect github.com/cespare/xxhash/v2 v2.2.0 // indirect github.com/cockroachdb/errors v1.9.1 // indirect github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b // indirect - github.com/cockroachdb/pebble v0.0.0-20230209160836-829675f94811 // indirect + github.com/cockroachdb/pebble v0.0.0-20230928194634-aa077af62593 // indirect github.com/cockroachdb/redact v1.1.3 // indirect + github.com/cockroachdb/tokenbucket v0.0.0-20230807174530-cc333fc44b06 // indirect + github.com/consensys/bavard v0.1.13 // indirect + github.com/consensys/gnark-crypto v0.12.1 // indirect github.com/cpuguy83/go-md2man/v2 v2.0.4 // indirect + github.com/crate-crypto/go-ipa v0.0.0-20231025140028-3c0104f4b233 // indirect + github.com/crate-crypto/go-kzg-4844 v0.7.0 // indirect github.com/davecgh/go-spew v1.1.1 // indirect github.com/deckarep/golang-set/v2 v2.1.0 // indirect github.com/decred/dcrd/dcrec/secp256k1/v4 v4.1.0 // indirect github.com/dlclark/regexp2 v1.7.0 // indirect - github.com/dop251/goja v0.0.0-20230605162241-28ee0ee714f3 // indirect + github.com/dop251/goja v0.0.0-20230806174421-c933cf95e127 // indirect + github.com/ethereum/c-kzg-4844 v0.4.0 // indirect github.com/fjl/memsize v0.0.0-20190710130421-bcb5799ab5e5 // indirect github.com/fsnotify/fsnotify v1.6.0 // indirect github.com/gballet/go-libpcsclite v0.0.0-20191108122812-4678299bea08 // indirect + github.com/gballet/go-verkle v0.1.1-0.20231031103413-a67434b50f46 // indirect github.com/getsentry/sentry-go v0.18.0 // indirect github.com/go-cmd/cmd v1.4.1 // indirect github.com/go-logr/logr v1.4.1 // indirect github.com/go-logr/stdr v1.2.2 // indirect github.com/go-ole/go-ole v1.2.6 // indirect github.com/go-sourcemap/sourcemap v2.1.3+incompatible // indirect - github.com/go-stack/stack v1.8.1 // indirect github.com/go-task/slim-sprig/v3 v3.0.0 // indirect github.com/gogo/protobuf v1.3.2 // indirect - github.com/golang-jwt/jwt/v4 v4.3.0 // indirect - github.com/golang/protobuf v1.5.3 // indirect + github.com/golang/protobuf v1.5.4 // indirect github.com/golang/snappy v0.0.5-0.20220116011046-fa5810519dcb // indirect github.com/google/btree v1.1.2 // indirect github.com/google/go-cmp v0.6.0 // indirect github.com/google/pprof v0.0.0-20240424215950-a892ee059fd6 // indirect github.com/google/renameio/v2 v2.0.0 // indirect - github.com/google/uuid v1.3.0 // indirect + github.com/google/uuid v1.6.0 // indirect github.com/gorilla/mux v1.8.0 // indirect github.com/gorilla/rpc v1.2.0 // indirect github.com/gorilla/websocket v1.4.2 // indirect github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 // indirect - github.com/grpc-ecosystem/grpc-gateway/v2 v2.15.2 // indirect + github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.0 // indirect github.com/hashicorp/go-bexpr v0.1.10 // indirect github.com/hashicorp/golang-lru v0.5.5-0.20210104140557-80c98217689d // indirect github.com/hashicorp/hcl v1.0.0 // indirect + github.com/holiman/billy v0.0.0-20230718173358-1c7e68d277a7 // indirect github.com/holiman/bloomfilter/v2 v2.0.3 // indirect - github.com/holiman/uint256 v1.2.3 // indirect - github.com/huin/goupnp v1.0.3 // indirect + github.com/holiman/uint256 v1.2.4 // indirect + github.com/huin/goupnp v1.3.0 // indirect github.com/inconshreveable/mousetrap v1.1.0 // indirect github.com/jackpal/gateway v1.0.6 // indirect github.com/jackpal/go-nat-pmp v1.0.2 // indirect @@ -79,15 +84,15 @@ require ( github.com/kr/text v0.2.0 // indirect github.com/magiconair/properties v1.8.7 // indirect github.com/mattn/go-colorable v0.1.13 // indirect - github.com/mattn/go-isatty v0.0.16 // indirect - github.com/mattn/go-runewidth v0.0.9 // indirect + github.com/mattn/go-isatty v0.0.17 // indirect + github.com/mattn/go-runewidth v0.0.13 // indirect github.com/matttproud/golang_protobuf_extensions v1.0.4 // indirect github.com/mitchellh/mapstructure v1.5.0 // indirect github.com/mitchellh/pointerstructure v1.2.0 // indirect + github.com/mmcloughlin/addchain v0.4.0 // indirect github.com/mr-tron/base58 v1.2.0 // indirect github.com/nbutton23/zxcvbn-go v0.0.0-20180912185939-ae427f1e4c1d // indirect github.com/olekukonko/tablewriter v0.0.5 // indirect - github.com/otiai10/copy v1.11.0 // indirect github.com/pelletier/go-toml/v2 v2.0.8 // indirect github.com/pires/go-proxyproto v0.6.2 // indirect github.com/pmezard/go-difflib v1.0.0 // indirect @@ -95,6 +100,7 @@ require ( github.com/prometheus/client_model v0.3.0 // indirect github.com/prometheus/common v0.42.0 // indirect github.com/prometheus/procfs v0.10.1 // indirect + github.com/rivo/uniseg v0.2.0 // indirect github.com/rogpeppe/go-internal v1.10.0 // indirect github.com/rs/cors v1.7.0 // indirect github.com/russross/blackfriday/v2 v2.1.0 // indirect @@ -107,25 +113,24 @@ require ( github.com/status-im/keycard-go v0.2.0 // indirect github.com/subosito/gotenv v1.4.2 // indirect github.com/syndtr/goleveldb v1.0.1-0.20220614013038-64ee5596c38a // indirect - github.com/tklauser/go-sysconf v0.3.5 // indirect - github.com/tklauser/numcpus v0.2.2 // indirect + github.com/tklauser/go-sysconf v0.3.12 // indirect + github.com/tklauser/numcpus v0.6.1 // indirect github.com/tyler-smith/go-bip39 v1.1.0 // indirect - github.com/urfave/cli/v2 v2.17.2-0.20221006022127-8f469abc00aa // indirect + github.com/urfave/cli/v2 v2.25.7 // indirect github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673 // indirect github.com/yusufpapurcu/wmi v1.2.2 // indirect - go.opentelemetry.io/otel v1.11.0 // indirect - go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.11.0 // indirect - go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.11.0 // indirect - go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.11.0 // indirect - go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.11.0 // indirect - go.opentelemetry.io/otel/sdk v1.11.0 // indirect - go.opentelemetry.io/otel/trace v1.11.0 // indirect - go.opentelemetry.io/proto/otlp v0.19.0 // indirect + go.opentelemetry.io/otel v1.22.0 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.22.0 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.22.0 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.22.0 // indirect + go.opentelemetry.io/otel/metric v1.22.0 // indirect + go.opentelemetry.io/otel/sdk v1.22.0 // indirect + go.opentelemetry.io/otel/trace v1.22.0 // indirect + go.opentelemetry.io/proto/otlp v1.0.0 // indirect go.uber.org/mock v0.4.0 // indirect go.uber.org/multierr v1.11.0 // indirect golang.org/x/crypto v0.23.0 // indirect golang.org/x/exp v0.0.0-20231127185646-65229373498e // indirect - golang.org/x/mod v0.17.0 // indirect golang.org/x/net v0.25.0 // indirect golang.org/x/sync v0.7.0 // indirect golang.org/x/sys v0.20.0 // indirect @@ -134,12 +139,12 @@ require ( golang.org/x/time v0.3.0 // indirect golang.org/x/tools v0.21.0 // indirect gonum.org/v1/gonum v0.11.0 // indirect - google.golang.org/genproto v0.0.0-20230711160842-782d3b101e98 // indirect - google.golang.org/genproto/googleapis/api v0.0.0-20230711160842-782d3b101e98 // indirect - google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98 // indirect - google.golang.org/grpc v1.58.3 // indirect - google.golang.org/protobuf v1.33.0 // indirect + google.golang.org/genproto/googleapis/api v0.0.0-20240318140521-94a12d6c2237 // indirect + google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237 // indirect + google.golang.org/grpc v1.64.0 // indirect + google.golang.org/protobuf v1.34.2 // indirect gopkg.in/ini.v1 v1.67.0 // indirect gopkg.in/natefinch/lumberjack.v2 v2.0.0 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect + rsc.io/tmplfunc v0.0.3 // indirect ) diff --git a/go.sum b/go.sum index f127546a4..0cbf5b639 100644 --- a/go.sum +++ b/go.sum @@ -46,31 +46,27 @@ github.com/CloudyKit/jet/v3 v3.0.0/go.mod h1:HKQPgSJmdK8hdoAbKUUWajkHyHo4RaU5rMd github.com/DataDog/zstd v1.5.2 h1:vUG4lAyuPCXO0TLbXvPv7EB7cNK1QV/luu55UHLrrn8= github.com/DataDog/zstd v1.5.2/go.mod h1:g4AWEaM3yOg3HYfnJ3YIawPnVdXJh9QME85blwSAmyw= github.com/Joker/hpp v1.0.0/go.mod h1:8x5n+M1Hp5hC0g8okX3sR3vFQwynaX/UgSOM9MeBKzY= -github.com/Microsoft/go-winio v0.5.2 h1:a9IhgEQBCUEk6QCdml9CiJGhAws+YwffDHEMp1VMrpA= -github.com/Microsoft/go-winio v0.5.2/go.mod h1:WpS1mjBmmwHBEWmogvA2mj8546UReBk4v8QkMxJ6pZY= github.com/NYTimes/gziphandler v1.1.1 h1:ZUDjpQae29j0ryrS0u/B8HZfJBtBQHjqw2rQ2cqUQ3I= github.com/NYTimes/gziphandler v1.1.1/go.mod h1:n/CVRwUEOgIxrgPvAQhUUr9oeUtvrhMomdKFjzJNB0c= -github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU= github.com/Shopify/goreferrer v0.0.0-20181106222321-ec9c9a553398/go.mod h1:a1uqRtAwp2Xwc6WNPJEufxJ7fx3npB4UV/JOLmbu5I0= -github.com/VictoriaMetrics/fastcache v1.10.0 h1:5hDJnLsKLpnUEToub7ETuRu8RCkb40woBZAUiKonXzY= -github.com/VictoriaMetrics/fastcache v1.10.0/go.mod h1:tjiYeEfYXCqacuvYw/7UoDIeJaNxq6132xHICNP77w8= +github.com/VictoriaMetrics/fastcache v1.12.1 h1:i0mICQuojGDL3KblA7wUNlY5lOK6a4bwt3uRKnkZU40= +github.com/VictoriaMetrics/fastcache v1.12.1/go.mod h1:tX04vaqcNoQeGLD+ra5pU5sWkuxnzWhEzLwhP9w653o= github.com/aead/siphash v1.0.1/go.mod h1:Nywa3cDsYNNK3gaciGTWPwHt0wlpNV15vwmswBAUSII= github.com/ajg/form v1.5.1/go.mod h1:uL1WgH+h2mgNtvBq0339dVnzXdBETtL2LeUXaIv25UY= github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156 h1:eMwmnE/GDgah4HI848JfFxHt+iPb26b4zyfspmqY0/8= github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM= -github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY= github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8= -github.com/ava-labs/avalanche-network-runner v1.7.6 h1:2yXa2Zq099t900ffpn0RG9D5dca98fs3l+/hF7AumIY= -github.com/ava-labs/avalanche-network-runner v1.7.6/go.mod h1:+Br4mCjreTMtnDiUDNXJba500fnchMk0Ygu5qWVj6A4= -github.com/ava-labs/avalanchego v1.11.1 h1:NSelfZ/Di8uGCsRoFK32HOR262eHlpUFmAu8pbfg0Jo= -github.com/ava-labs/avalanchego v1.11.1/go.mod h1:+UpgT8X2fNN93+iE100efkZL7ePfBRfRdmpJ/i3YnyY= -github.com/ava-labs/coreth v0.13.0-rc.0 h1:V2l3qj2ek3geKDJAnF2M94mYJK8kg2kePixujfJ0bmk= -github.com/ava-labs/coreth v0.13.0-rc.0/go.mod h1:eUMbBLDhlZASJjcbf0gIcD2GMn2rRRCUxC8MXLt5QQk= -github.com/ava-labs/subnet-evm v0.6.1 h1:NyknPPWBKGN9VIwfKi1+oR6NpvephiNkWEwzjGcNLkA= -github.com/ava-labs/subnet-evm v0.6.1/go.mod h1:PRwf9C3KgXzrANnrCvKa/gQVvIBomKzQgZM2ucECGYE= +github.com/ava-labs/avalanchego v1.11.9-0.20240703222923-9d71967ccbba h1:G861YmZfj+m1fSb9TUMojYo7u5pG0jvDL4jHeyLOsG8= +github.com/ava-labs/avalanchego v1.11.9-0.20240703222923-9d71967ccbba/go.mod h1:Nc85yoe/YatXafBLUesyiUrFT3+bpOrd7UFRFBtzn9A= +github.com/ava-labs/coreth v0.13.5-rc.0 h1:PJQbR9o2RrW3j9ba4r1glXnmM2PNAP3xR569+gMcBd0= +github.com/ava-labs/coreth v0.13.5-rc.0/go.mod h1:cm5c12xo5NiTgtbmeduv8i2nYdzgkczz9Wm3yiwwTRU= +github.com/ava-labs/subnet-evm v0.6.6 h1:F2s40f2SE2Yt/e97ZA6jMVaqDW+/1PLewcqOiUWDFd0= +github.com/ava-labs/subnet-evm v0.6.6/go.mod h1:xq048mtkxCkNPl7Yb0wSkWzXX70aYkPnYQUvfCaBW3U= github.com/aymerick/raymond v2.0.3-0.20180322193309-b565731e1464+incompatible/go.mod h1:osfaiScAUVup+UC9Nfq76eWqDhXlp+4UYaA8uhTBO6g= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= +github.com/bits-and-blooms/bitset v1.10.0 h1:ePXTeiPEazB5+opbv5fr8umg2R/1NlzgDsyepwsSr88= +github.com/bits-and-blooms/bitset v1.10.0/go.mod h1:7hO7Gc7Pp1vODcmWvKMRA9BNmbv6a/7QIWpPxHddWR8= github.com/btcsuite/btcd v0.20.1-beta/go.mod h1:wVuoA8VJLEcwgqHBwHmzLRazpKxTv13Px/pDuV7OomQ= github.com/btcsuite/btcd v0.22.0-beta.0.20220111032746-97732e52810c/go.mod h1:tjmYdS6MLJ5/s0Fj4DbLgSbDHbEqLJrtnHecBFkdz5M= github.com/btcsuite/btcd v0.23.0 h1:V2/ZgjfDFIygAX3ZapeigkVBoVUtOJKSwrhZdlpSvaA= @@ -95,14 +91,11 @@ github.com/btcsuite/snappy-go v0.0.0-20151229074030-0bdef8d06723/go.mod h1:8woku github.com/btcsuite/snappy-go v1.0.0/go.mod h1:8woku9dyThutzjeg+3xrA5iCpBRH8XEEg3lh6TiUghc= github.com/btcsuite/websocket v0.0.0-20150119174127-31079b680792/go.mod h1:ghJtEyQwv5/p4Mg4C0fgbePVuGr935/5ddU9Z3TmDRY= github.com/btcsuite/winsvc v1.0.0/go.mod h1:jsenWakMcC0zFBFurPLEAyrnc/teJEM1O46fmI40EZs= -github.com/cenkalti/backoff/v4 v4.1.3 h1:cFAlzYUlVYDysBEH2T5hyJZMh3+5+WCBvSnK6Q8UtC4= -github.com/cenkalti/backoff/v4 v4.1.3/go.mod h1:scbssz8iZGpm3xbr14ovlUdkxfGXNInqkPWOWmG2CLw= +github.com/cenkalti/backoff/v4 v4.2.1 h1:y4OZtCnogmCPw98Zjyt5a6+QwPLGkiQsYW5oUqylYbM= +github.com/cenkalti/backoff/v4 v4.2.1/go.mod h1:Y3VNntkOUPxTVeUxJ/G5vcM//AlwfmyYozVcomhLiZE= github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= github.com/cespare/cp v0.1.0 h1:SE+dxFebS7Iik5LK0tsi1k9ZCxEaFX4AjQmoyA+1dJk= github.com/cespare/cp v0.1.0/go.mod h1:SOGHArjBr4JWaSDEVpWpo/hNg6RoKrls6Oh40hiwW+s= -github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc= -github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= -github.com/cespare/xxhash/v2 v2.1.2/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= github.com/cespare/xxhash/v2 v2.2.0 h1:DC2CZ1Ep5Y4k3ZQ899DldepgrayRUGE6BBZ/cd9Cj44= github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI= @@ -115,29 +108,35 @@ github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDk github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= github.com/cncf/udpa/go v0.0.0-20200629203442-efcf912fb354/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= -github.com/cncf/udpa/go v0.0.0-20210930031921-04548b0d99d4/go.mod h1:6pvJx4me5XPnfI9Z40ddWsdw2W/uZgQLFXToKeRcDiI= -github.com/cncf/xds/go v0.0.0-20210312221358-fbca930ec8ed/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= -github.com/cncf/xds/go v0.0.0-20210805033703-aa0b78936158/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= -github.com/cncf/xds/go v0.0.0-20210922020428-25de7278fc84/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= -github.com/cncf/xds/go v0.0.0-20211011173535-cb28da3451f1/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= -github.com/cockroachdb/datadriven v1.0.2 h1:H9MtNqVoVhvd9nCBwOyDjUEdZCREqbIdCJD93PBm/jA= github.com/cockroachdb/datadriven v1.0.2/go.mod h1:a9RdTaap04u637JoCzcUoIcDmvwSUtcUFtT/C3kJlTU= +github.com/cockroachdb/datadriven v1.0.3-0.20230413201302-be42291fc80f h1:otljaYPt5hWxV3MUfO5dFPFiOXg9CyG5/kCfayTqsJ4= +github.com/cockroachdb/datadriven v1.0.3-0.20230413201302-be42291fc80f/go.mod h1:a9RdTaap04u637JoCzcUoIcDmvwSUtcUFtT/C3kJlTU= github.com/cockroachdb/errors v1.9.1 h1:yFVvsI0VxmRShfawbt/laCIDy/mtTqqnvoNgiy5bEV8= github.com/cockroachdb/errors v1.9.1/go.mod h1:2sxOtL2WIc096WSZqZ5h8fa17rdDq9HZOZLBCor4mBk= github.com/cockroachdb/logtags v0.0.0-20211118104740-dabe8e521a4f/go.mod h1:Vz9DsVWQQhf3vs21MhPMZpMGSht7O/2vFW2xusFUVOs= github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b h1:r6VH0faHjZeQy818SGhaone5OnYfxFR/+AzdY3sf5aE= github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b/go.mod h1:Vz9DsVWQQhf3vs21MhPMZpMGSht7O/2vFW2xusFUVOs= -github.com/cockroachdb/pebble v0.0.0-20230209160836-829675f94811 h1:ytcWPaNPhNoGMWEhDvS3zToKcDpRsLuRolQJBVGdozk= -github.com/cockroachdb/pebble v0.0.0-20230209160836-829675f94811/go.mod h1:Nb5lgvnQ2+oGlE/EyZy4+2/CxRh9KfvCXnag1vtpxVM= +github.com/cockroachdb/pebble v0.0.0-20230928194634-aa077af62593 h1:aPEJyR4rPBvDmeyi+l/FS/VtA00IWvjeFvjen1m1l1A= +github.com/cockroachdb/pebble v0.0.0-20230928194634-aa077af62593/go.mod h1:6hk1eMY/u5t+Cf18q5lFMUA1Rc+Sm5I6Ra1QuPyxXCo= github.com/cockroachdb/redact v1.1.3 h1:AKZds10rFSIj7qADf0g46UixK8NNLwWTNdCIGS5wfSQ= github.com/cockroachdb/redact v1.1.3/go.mod h1:BVNblN9mBWFyMyqK1k3AAiSxhvhfK2oOZZ2lK+dpvRg= +github.com/cockroachdb/tokenbucket v0.0.0-20230807174530-cc333fc44b06 h1:zuQyyAKVxetITBuuhv3BI9cMrmStnpT18zmgmTxunpo= +github.com/cockroachdb/tokenbucket v0.0.0-20230807174530-cc333fc44b06/go.mod h1:7nc4anLGjupUW/PeY5qiNYsdNXj7zopG+eqsS7To5IQ= github.com/codegangsta/inject v0.0.0-20150114235600-33e0aa1cb7c0/go.mod h1:4Zcjuz89kmFXt9morQgcfYZAYZ5n8WHjt81YYWIwtTM= +github.com/consensys/bavard v0.1.13 h1:oLhMLOFGTLdlda/kma4VOJazblc7IM5y5QPd2A/YjhQ= +github.com/consensys/bavard v0.1.13/go.mod h1:9ItSMtA/dXMAiL7BG6bqW2m3NdSEObYWoH223nGHukI= +github.com/consensys/gnark-crypto v0.12.1 h1:lHH39WuuFgVHONRl3J0LRBtuYdQTumFSDtJF7HpyG8M= +github.com/consensys/gnark-crypto v0.12.1/go.mod h1:v2Gy7L/4ZRosZ7Ivs+9SfUDr0f5UlG+EM5t7MPHiLuY= github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk= github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwcJI5acqYI6dE= github.com/cpuguy83/go-md2man/v2 v2.0.4 h1:wfIWP927BUkWJb2NmU/kNDYIBTh/ziUX91+lVfRxZq4= github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= +github.com/crate-crypto/go-ipa v0.0.0-20231025140028-3c0104f4b233 h1:d28BXYi+wUpz1KBmiF9bWrjEMacUEREV6MBi2ODnrfQ= +github.com/crate-crypto/go-ipa v0.0.0-20231025140028-3c0104f4b233/go.mod h1:geZJZH3SzKCqnz5VT0q/DyIG/tvu/dZk+VIfXicupJs= +github.com/crate-crypto/go-kzg-4844 v0.7.0 h1:C0vgZRk4q4EZ/JgPfzuSoxdCq3C3mOZMBShovmncxvA= +github.com/crate-crypto/go-kzg-4844 v0.7.0/go.mod h1:1kMhvPgI0Ky3yIa+9lFySEBUBXkYxeOi8ZF1sYioxhc= github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= github.com/davecgh/go-spew v0.0.0-20171005155431-ecdeabc65495/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -157,8 +156,8 @@ github.com/dlclark/regexp2 v1.4.1-0.20201116162257-a2a8dda75c91/go.mod h1:2pZnwu github.com/dlclark/regexp2 v1.7.0 h1:7lJfhqlPssTb1WQx4yvTHN0uElPEv52sbaECrAQxjAo= github.com/dlclark/regexp2 v1.7.0/go.mod h1:DHkYz0B9wPfa6wondMfaivmHpzrQ3v9q8cnmRbL6yW8= github.com/dop251/goja v0.0.0-20211022113120-dc8c55024d06/go.mod h1:R9ET47fwRVRPZnOGvHxxhuZcbrMCuiqOz3Rlrh4KSnk= -github.com/dop251/goja v0.0.0-20230605162241-28ee0ee714f3 h1:+3HCtB74++ClLy8GgjUQYeC8R4ILzVcIe8+5edAJJnE= -github.com/dop251/goja v0.0.0-20230605162241-28ee0ee714f3/go.mod h1:QMWlm50DNe14hD7t24KEqZuUdC9sOTy8W6XbCU1mlw4= +github.com/dop251/goja v0.0.0-20230806174421-c933cf95e127 h1:qwcF+vdFrvPSEUDSX5RVoRccG8a5DhOdWdQ4zN62zzo= +github.com/dop251/goja v0.0.0-20230806174421-c933cf95e127/go.mod h1:QMWlm50DNe14hD7t24KEqZuUdC9sOTy8W6XbCU1mlw4= github.com/dop251/goja_nodejs v0.0.0-20210225215109-d91c329300e7/go.mod h1:hn7BA7c8pLvoGndExHudxTDKZ84Pyvv+90pbBjbTz0Y= github.com/dop251/goja_nodejs v0.0.0-20211022123610-8dd9abb0616d/go.mod h1:DngW8aVqWbuLRMHItjPUyqdj+HWPvnQe8V8y1nDpIbM= github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= @@ -169,12 +168,12 @@ github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1m github.com/envoyproxy/go-control-plane v0.9.7/go.mod h1:cwu0lG7PUMfa9snN8LXBig5ynNVH9qI8YYLbd1fK2po= github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= -github.com/envoyproxy/go-control-plane v0.9.9-0.20210512163311-63b5d3c536b0/go.mod h1:hliV/p42l8fGbc6Y9bQ70uLwIvmJyVE5k4iMKlh8wCQ= -github.com/envoyproxy/go-control-plane v0.9.10-0.20210907150352-cf90f659a021/go.mod h1:AFq3mo9L8Lqqiid3OhADV3RfLJnjiw63cSpi+fDTRC0= github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= github.com/etcd-io/bbolt v1.3.3/go.mod h1:ZF2nL25h33cCyBtcyWeZ2/I3HQOfTP+0PIEvHjkjCrw= -github.com/ethereum/go-ethereum v1.12.0 h1:bdnhLPtqETd4m3mS8BGMNvBTf36bO5bx/hxE2zljOa0= -github.com/ethereum/go-ethereum v1.12.0/go.mod h1:/oo2X/dZLJjf2mJ6YT9wcWxa4nNJDBKDBU6sFIpx1Gs= +github.com/ethereum/c-kzg-4844 v0.4.0 h1:3MS1s4JtA868KpJxroZoepdV0ZKBp3u/O5HcZ7R3nlY= +github.com/ethereum/c-kzg-4844 v0.4.0/go.mod h1:VewdlzQmpT5QSrVhbBuGoCdFJkpaJlO1aQputP83wc0= +github.com/ethereum/go-ethereum v1.13.8 h1:1od+thJel3tM52ZUNQwvpYOeRHlbkVFZ5S8fhi0Lgsg= +github.com/ethereum/go-ethereum v1.13.8/go.mod h1:sc48XYQxCzH3fG9BcrXCOOgQk2JfZzNAmIKnceogzsA= github.com/fasthttp-contrib/websocket v0.0.0-20160511215533-1f3b11f56072/go.mod h1:duJ4Jxv5lDcvg4QuQr0oowTf7dz4/CR8NtyCooz9HL8= github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M= github.com/fjl/memsize v0.0.0-20190710130421-bcb5799ab5e5 h1:FtmdgXiUlNeRsoNMFlKLDt+S+6hbjVMEW6RGQ7aUf7c= @@ -189,10 +188,11 @@ github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbS github.com/gavv/httpexpect v2.0.0+incompatible/go.mod h1:x+9tiU1YnrOvnB725RkpoLv1M62hOWzwo5OXotisrKc= github.com/gballet/go-libpcsclite v0.0.0-20191108122812-4678299bea08 h1:f6D9Hr8xV8uYKlyuj8XIruxlh9WjVjdh1gIicAS7ays= github.com/gballet/go-libpcsclite v0.0.0-20191108122812-4678299bea08/go.mod h1:x7DCsMOv1taUwEWCzT4cmDeAkigA5/QCwUodaVOe8Ww= +github.com/gballet/go-verkle v0.1.1-0.20231031103413-a67434b50f46 h1:BAIP2GihuqhwdILrV+7GJel5lyPV3u1+PgzrWLc0TkE= +github.com/gballet/go-verkle v0.1.1-0.20231031103413-a67434b50f46/go.mod h1:QNpY22eby74jVhqH4WhDLDwxc/vqsern6pW+u2kbkpc= github.com/getsentry/sentry-go v0.12.0/go.mod h1:NSap0JBYWzHND8oMbyi0+XZhUalc1TBdRL1M71JZW2c= github.com/getsentry/sentry-go v0.18.0 h1:MtBW5H9QgdcJabtZcuJG80BMOwaBpkRDZkxRkNC1sN0= github.com/getsentry/sentry-go v0.18.0/go.mod h1:Kgon4Mby+FJ7ZWHFUAZgVaIa8sxHtnRJRLTXZr51aKQ= -github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= github.com/gin-contrib/sse v0.0.0-20190301062529-5545eab6dad3/go.mod h1:VJ0WA2NBN22VlZ2dKZQPAPnyWw5XTlK1KymzLKsr59s= github.com/gin-gonic/gin v1.4.0/go.mod h1:OW2EZn3DO8Ln9oIKOvM++LBO+5UPHJJDH72/q/3rZdM= github.com/go-check/check v0.0.0-20180628173108-788fd7840127/go.mod h1:9ES+weclKsC9YodN5RgxqK/VD9HM9JsCSh7rNhMZE98= @@ -214,8 +214,6 @@ github.com/go-ole/go-ole v1.2.6 h1:/Fpf6oFPoeFik9ty7siob0G6Ke8QvQEuVcuChpwXzpY= github.com/go-ole/go-ole v1.2.6/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0= github.com/go-sourcemap/sourcemap v2.1.3+incompatible h1:W1iEw64niKVGogNgBN3ePyLFfuisuzeidWPMPWmECqU= github.com/go-sourcemap/sourcemap v2.1.3+incompatible/go.mod h1:F8jJfvm2KbVjc5NqelyYJmf/v5J0dwNLS2mL4sNA1Jg= -github.com/go-stack/stack v1.8.1 h1:ntEHSVwIt7PNXNpgPmVfMrNhLtgjlmnZha2kOpuRiDw= -github.com/go-stack/stack v1.8.1/go.mod h1:dcoOX6HbPZSZptuspn9bctJ+N/CnF5gGygcUP3XYfe4= github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE= github.com/go-task/slim-sprig/v3 v3.0.0 h1:sUs3vkvUymDpBKi3qH1YSqBQk9+9D/8M2mN1vB6EwHI= github.com/go-task/slim-sprig/v3 v3.0.0/go.mod h1:W848ghGpv3Qj3dhTPRyJypKRiqCdHZiAzKg9hl15HA8= @@ -231,12 +229,9 @@ github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/gogo/status v1.1.0/go.mod h1:BFv9nrluPLmrS0EmGVvLaPNmRosr9KapBYd5/hpY1WM= github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I= -github.com/golang-jwt/jwt/v4 v4.3.0 h1:kHL1vqdqWNfATmA0FNMdmZNMyZI1U6O31X4rlIPoBog= -github.com/golang-jwt/jwt/v4 v4.3.0/go.mod h1:/xlHOz8bRuivTWchD4jCa+NbatV+wEUSzwAxVc6locg= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= -github.com/golang/glog v1.0.0/go.mod h1:EWib/APOK0SL3dFbYqvxE3UYd8E6s1ouQ7iEp/0LWV4= -github.com/golang/glog v1.1.0 h1:/d3pCKDPWNnvIWe0vVUpNP32qc8U3PDVxySP/y360qE= -github.com/golang/glog v1.1.0/go.mod h1:pfYeQZ3JWZoXTV5sFc986z3HTpwQs9At6P4ImfuP3NQ= +github.com/golang/glog v1.2.0 h1:uCdmnmatrKCgMBlM4rMuJZWOkPDqdbZPnrMXDY4gI68= +github.com/golang/glog v1.2.0/go.mod h1:6AhwSGph0fcJtXVM/PEHPqZlFeoLxhs7/t5UDAwmO+w= github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/groupcache v0.0.0-20191227052852-215e87163ea7/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= @@ -263,8 +258,8 @@ github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= -github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg= -github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= +github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek= +github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps= github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= github.com/golang/snappy v0.0.5-0.20220116011046-fa5810519dcb h1:PBC98N2aIaM3XXiurYmW7fx4GZkL8feAMVq7nEjURHk= github.com/golang/snappy v0.0.5-0.20220116011046-fa5810519dcb/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= @@ -283,7 +278,6 @@ github.com/google/go-cmp v0.5.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/ github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= github.com/google/go-querystring v1.0.0/go.mod h1:odCYkC5MyYFN7vkCjXpyrEuKhc/BUO6wN/zVPAxq5ck= @@ -308,9 +302,10 @@ github.com/google/pprof v0.0.0-20240424215950-a892ee059fd6/go.mod h1:kf6iHlnVGwg github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= github.com/google/renameio/v2 v2.0.0 h1:UifI23ZTGY8Tt29JbYFiuyIU3eX+RNFtUwefq9qAhxg= github.com/google/renameio/v2 v2.0.0/go.mod h1:BtmJXm5YlszgC+TD4HOEEUFgkJP3nLxehU6hfe7jRt4= +github.com/google/subcommands v1.2.0/go.mod h1:ZjhPrFU+Olkh9WazFPsl27BQ4UPiG37m3yTrtFlrHVk= github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= -github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I= -github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= +github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg= github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= github.com/googleapis/google-cloud-go-testing v0.0.0-20200911160855-bcd43fbb19e8/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g= @@ -324,10 +319,8 @@ github.com/gorilla/websocket v1.4.2 h1:+/TMaTYc4QFitKJxsQ7Yye35DkWvkdLcvGKqM+x0U github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 h1:Ovs26xHkKqVztRpIrF/92BcuyuQ/YW4NSIpoGtfXNho= github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk= -github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw= -github.com/grpc-ecosystem/grpc-gateway/v2 v2.7.0/go.mod h1:hgWBS7lorOAVIJEQMi4ZsPv9hVvWI6+ch50m39Pf2Ks= -github.com/grpc-ecosystem/grpc-gateway/v2 v2.15.2 h1:gDLXvp5S9izjldquuoAhDzccbskOL6tDC5jMSyx3zxE= -github.com/grpc-ecosystem/grpc-gateway/v2 v2.15.2/go.mod h1:7pdNwVWBBHGiCxa9lAszqCJMbfTISJ7oMftp8+UGV08= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.0 h1:YBftPWNWd4WwGqtY2yeZL2ef8rHAxPBD8KFhJpmcqms= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.0/go.mod h1:YN5jB8ie0yfIUg6VvR9Kz84aCaG7AsGZnLjhHbUqwPg= github.com/hashicorp/go-bexpr v0.1.10 h1:9kuI5PFotCboP3dkDYFr/wi0gg0QVbSNz5oFRpxn4uE= github.com/hashicorp/go-bexpr v0.1.10/go.mod h1:oxlubA2vC/gFVfX1A6JGp7ls7uCDlfJn732ehYYg+g0= github.com/hashicorp/go-version v1.2.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA= @@ -337,14 +330,15 @@ github.com/hashicorp/golang-lru v0.5.5-0.20210104140557-80c98217689d h1:dg1dEPuW github.com/hashicorp/golang-lru v0.5.5-0.20210104140557-80c98217689d/go.mod h1:iADmTwqILo4mZ8BN3D2Q6+9jd8WM5uGBxy+E8yxSoD4= github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= +github.com/holiman/billy v0.0.0-20230718173358-1c7e68d277a7 h1:3JQNjnMRil1yD0IfZKHF9GxxWKDJGj8I0IqOUol//sw= +github.com/holiman/billy v0.0.0-20230718173358-1c7e68d277a7/go.mod h1:5GuXa7vkL8u9FkFuWdVvfR5ix8hRB7DbOAaYULamFpc= github.com/holiman/bloomfilter/v2 v2.0.3 h1:73e0e/V0tCydx14a0SCYS/EWCxgwLZ18CZcZKVu0fao= github.com/holiman/bloomfilter/v2 v2.0.3/go.mod h1:zpoh+gs7qcpqrHr3dB55AMiJwo0iURXE7ZOP9L9hSkA= -github.com/holiman/uint256 v1.2.3 h1:K8UWO1HUJpRMXBxbmaY1Y8IAMZC/RsKB+ArEnnK4l5o= -github.com/holiman/uint256 v1.2.3/go.mod h1:SC8Ryt4n+UBbPbIBKaG9zbbDlp4jOru9xFZmPzLUTxw= +github.com/holiman/uint256 v1.2.4 h1:jUc4Nk8fm9jZabQuqr2JzednajVmBpC+oiTiXZJEApU= +github.com/holiman/uint256 v1.2.4/go.mod h1:EOMSn4q6Nyt9P6efbI3bueV4e1b3dGlUCXeiRV4ng7E= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= -github.com/huin/goupnp v1.0.3 h1:N8No57ls+MnjlB+JPiCVSOyy/ot7MJTqlo7rn+NYSqQ= -github.com/huin/goupnp v1.0.3/go.mod h1:ZxNlw5WqJj6wSsRK5+YfflQGXYfccj5VgQsMNixHM7Y= -github.com/huin/goutil v0.0.0-20170803182201-1ca381bf3150/go.mod h1:PpLOETDnJ0o3iZrZfqZzyLl6l7F3c6L1oWn7OICBi6o= +github.com/huin/goupnp v1.3.0 h1:UvLUlWDNpoUdYzb2TCn+MuTWtcjXKSza2n6CBdQ0xXc= +github.com/huin/goupnp v1.3.0/go.mod h1:gnGPsThkYa7bFi/KWmEysQRf48l2dvR5bxr2OFckNX8= github.com/hydrogen18/memlistener v0.0.0-20200120041712-dcc25e7acd91/go.mod h1:qEIFzExnS6016fRpRfxrExeVn2gbClQA99gQhnIcdhE= github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= @@ -413,10 +407,12 @@ github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hd github.com/mattn/go-isatty v0.0.9/go.mod h1:YNRxwqDuOph6SZLI9vUUz6OYw3QyUt7WiY2yME+cCiQ= github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94= -github.com/mattn/go-isatty v0.0.16 h1:bq3VjFmv/sOjHtdEhmkEV4x1AJtvUvOJ2PFAZ5+peKQ= github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= -github.com/mattn/go-runewidth v0.0.9 h1:Lm995f3rfxdpd6TSmuVCHVb/QhupuXlYr8sCI/QdE+0= +github.com/mattn/go-isatty v0.0.17 h1:BTarxUcIeDqL27Mc+vyvdWYSL28zpIhv3RoTdsLMPng= +github.com/mattn/go-isatty v0.0.17/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= github.com/mattn/go-runewidth v0.0.9/go.mod h1:H031xJmbD/WCDINGzjvQ9THkh0rPKHF+m2gUSrubnMI= +github.com/mattn/go-runewidth v0.0.13 h1:lTGmDsbAYt5DmK6OnoV7EuIF1wEIFAcxld6ypU4OSgU= +github.com/mattn/go-runewidth v0.0.13/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w= github.com/mattn/goveralls v0.0.2/go.mod h1:8d1ZMHsd7fW6IRPKQh46F2WRpyib5/X4FOpevwGNQEw= github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo= github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= @@ -429,6 +425,9 @@ github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyua github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= github.com/mitchellh/pointerstructure v1.2.0 h1:O+i9nHnXS3l/9Wu7r4NrEdwA2VFTicjUEN1uBnDo34A= github.com/mitchellh/pointerstructure v1.2.0/go.mod h1:BRAsLI5zgXmw97Lf6s25bs8ohIXc3tViBH44KcwB2g4= +github.com/mmcloughlin/addchain v0.4.0 h1:SobOdjm2xLj1KkXN5/n0xTIWyZA2+s99UCY1iPfkHRY= +github.com/mmcloughlin/addchain v0.4.0/go.mod h1:A86O+tHqZLMNO4w6ZZ4FlVQEadcoqkyU72HC5wJ4RlU= +github.com/mmcloughlin/profile v0.1.1/go.mod h1:IhHD7q1ooxgwTgjxQYkACGA77oFTDdFVejUS1/tS/qU= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= @@ -466,10 +465,6 @@ github.com/onsi/gomega v1.17.0/go.mod h1:HnhC7FXeEQY45zxNK3PPoIUhzk/80Xly9PcubAl github.com/onsi/gomega v1.19.0/go.mod h1:LY+I3pBVzYsTBU1AnDwOSxaYi9WoWiqgwooUqq9yPro= github.com/onsi/gomega v1.33.1 h1:dsYjIxxSR755MDmKVsaFQTE22ChNBcuuTWgkUDSubOk= github.com/onsi/gomega v1.33.1/go.mod h1:U4R44UsT+9eLIaYRB2a5qajjtQYn0hauxvRm16AVYg0= -github.com/otiai10/copy v1.11.0 h1:OKBD80J/mLBrwnzXqGtFCzprFSGioo30JcmR4APsNwc= -github.com/otiai10/copy v1.11.0/go.mod h1:rSaLseMUsZFFbsFGc7wCJnnkTAvdc5L6VWxPE4308Ww= -github.com/otiai10/mint v1.5.1 h1:XaPLeE+9vGbuyEHem1JNk3bYc7KKqyI/na0/mLd/Kks= -github.com/otiai10/mint v1.5.1/go.mod h1:MJm72SBthJjz8qhefc4z1PYEieWmy8Bku7CjcAqyUSM= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= github.com/pelletier/go-toml/v2 v2.0.8 h1:0ctb6s9mE31h0/lhu+J6OPmVeDxJn+kYnJc2jZR9tGQ= github.com/pelletier/go-toml/v2 v2.0.8/go.mod h1:vuYfssBdrU2XDZ9bYydBu6t+6a6PYNcZljzZR9VXg+4= @@ -493,7 +488,8 @@ github.com/prometheus/common v0.42.0 h1:EKsfXEYo4JpWMHH5cg+KOUWeuJSov1Id8zGR8eeI github.com/prometheus/common v0.42.0/go.mod h1:xBwqVerjNdUDjgODMpudtOMwlOwf2SaTr1yjz4b7Zbc= github.com/prometheus/procfs v0.10.1 h1:kYK1Va/YMlutzCGazswoHKo//tZVlFpKYh+PymziUAg= github.com/prometheus/procfs v0.10.1/go.mod h1:nwNm2aOCAYw8uTR/9bWRREkZFxAUcWzPHWJq+XBB/FM= -github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= +github.com/rivo/uniseg v0.2.0 h1:S1pD9weZBuJdFmowNwbpi7BJ8TNftyUImj/0WQi72jY= +github.com/rivo/uniseg v0.2.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc= github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= github.com/rogpeppe/go-internal v1.6.1/go.mod h1:xXDCJY+GAPziupqXw64V24skbSoqbTEfhy4qGm1nDQc= github.com/rogpeppe/go-internal v1.8.1/go.mod h1:JeRgkft04UBgHMgCIwADu4Pn6Mtm5d4nPKWu0nJ5d+o= @@ -513,10 +509,8 @@ github.com/sergi/go-diff v1.0.0/go.mod h1:0CfEIISq7TuYL3j771MWULgwwjU+GofnZX9QAm github.com/shirou/gopsutil v3.21.11+incompatible h1:+1+c1VGhc88SSonWP6foOcLhvnKlUeu/erjjvaPEYiI= github.com/shirou/gopsutil v3.21.11+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMTu2PcXUg8+E1lC7eC3UO/RA= github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= -github.com/sirupsen/logrus v1.7.0/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0= github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc= github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA= -github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA= github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ= github.com/spf13/afero v1.9.5 h1:stMpOSZFs//0Lv29HduCmli3GUfpFoF3Y1Q/aXj/wVM= github.com/spf13/afero v1.9.5/go.mod h1:UBogFpq8E9Hx+xc5CNTTEpTnuHVmXDwZcZcE1eb/UhQ= @@ -540,8 +534,6 @@ github.com/status-im/keycard-go v0.2.0/go.mod h1:wlp8ZLbsmrF6g6WjugPAx+IzoLrkdf9 github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= -github.com/stretchr/objx v0.5.2 h1:xuMeJ0Sdp5ZMRXx/aWO6RZxdr3beISkG5/G/aIRr3pY= -github.com/stretchr/objx v0.5.2/go.mod h1:FRsXN1f5AsAjCGJKqEizvkpNtU+EGNCLh3NxZ/8L+MA= github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= @@ -562,18 +554,18 @@ github.com/syndtr/goleveldb v1.0.1-0.20220614013038-64ee5596c38a h1:1ur3QoCqvE5f github.com/syndtr/goleveldb v1.0.1-0.20220614013038-64ee5596c38a/go.mod h1:RRCYJbIwD5jmqPI9XoAFR0OcDxqUctll6zUj/+B4S48= github.com/thepudds/fzgen v0.4.2 h1:HlEHl5hk2/cqEomf2uK5SA/FeJc12s/vIHmOG+FbACw= github.com/thepudds/fzgen v0.4.2/go.mod h1:kHCWdsv5tdnt32NIHYDdgq083m6bMtaY0M+ipiO9xWE= -github.com/tklauser/go-sysconf v0.3.5 h1:uu3Xl4nkLzQfXNsWn15rPc/HQCJKObbt1dKJeWp3vU4= -github.com/tklauser/go-sysconf v0.3.5/go.mod h1:MkWzOF4RMCshBAMXuhXJs64Rte09mITnppBXY/rYEFI= -github.com/tklauser/numcpus v0.2.2 h1:oyhllyrScuYI6g+h/zUvNXNp1wy7x8qQy3t/piefldA= -github.com/tklauser/numcpus v0.2.2/go.mod h1:x3qojaO3uyYt0i56EW/VUYs7uBvdl2fkfZFu0T9wgjM= +github.com/tklauser/go-sysconf v0.3.12 h1:0QaGUFOdQaIVdPgfITYzaTegZvdCjmYO52cSFAEVmqU= +github.com/tklauser/go-sysconf v0.3.12/go.mod h1:Ho14jnntGE1fpdOqQEEaiKRpvIavV0hSfmBq8nJbHYI= +github.com/tklauser/numcpus v0.6.1 h1:ng9scYS7az0Bk4OZLvrNXNSAO2Pxr1XXRAPyjhIx+Fk= +github.com/tklauser/numcpus v0.6.1/go.mod h1:1XfjsgE2zo8GVw7POkMbHENHzVg3GzmoZ9fESEdAacY= github.com/tyler-smith/go-bip39 v1.1.0 h1:5eUemwrMargf3BSLRRCalXT93Ns6pQJIjYQN2nyfOP8= github.com/tyler-smith/go-bip39 v1.1.0/go.mod h1:gUYDtqQw1JS3ZJ8UWVcGTGqqr6YIN3CWg+kkNaLt55U= github.com/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc= github.com/ugorji/go v1.1.7/go.mod h1:kZn38zHttfInRq0xu/PH0az30d+z6vm202qpg1oXVMw= github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0= github.com/ugorji/go/codec v1.1.7/go.mod h1:Ax+UKWsSmolVDwsd+7N3ZtXu+yMGCf907BLYF3GoBXY= -github.com/urfave/cli/v2 v2.17.2-0.20221006022127-8f469abc00aa h1:5SqCsI/2Qya2bCzK15ozrqo2sZxkh0FHynJZOTVoV6Q= -github.com/urfave/cli/v2 v2.17.2-0.20221006022127-8f469abc00aa/go.mod h1:1CNUng3PtjQMtRzJO4FMXBQvkGtuYRxxiR9xMa7jMwI= +github.com/urfave/cli/v2 v2.25.7 h1:VAzn5oq403l5pHjc4OhD54+XGO9cdKVL/7lDjF+iKUs= +github.com/urfave/cli/v2 v2.25.7/go.mod h1:8qnjx1vcq5s2/wpsqoZFndg2CE5tNFyrTvS6SinrnYQ= github.com/urfave/negroni v1.0.0/go.mod h1:Meg73S6kFm/4PpbYdq35yYWoCZ9mS/YSx+lKnmiohz4= github.com/valyala/bytebufferpool v1.0.0/go.mod h1:6bBcMArwyJ5K/AmCkWv1jt77kVWyCJ6HpOuEn7z0Csc= github.com/valyala/fasthttp v1.6.0/go.mod h1:FstJa9V+Pj9vQ7OJie2qMHdwemEDaDiSdBnvPM1Su9w= @@ -604,23 +596,22 @@ go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk= -go.opentelemetry.io/otel v1.11.0 h1:kfToEGMDq6TrVrJ9Vht84Y8y9enykSZzDDZglV0kIEk= -go.opentelemetry.io/otel v1.11.0/go.mod h1:H2KtuEphyMvlhZ+F7tg9GRhAOe60moNx61Ex+WmiKkk= -go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.11.0 h1:0dly5et1i/6Th3WHn0M6kYiJfFNzhhxanrJ0bOfnjEo= -go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.11.0/go.mod h1:+Lq4/WkdCkjbGcBMVHHg2apTbv8oMBf29QCnyCCJjNQ= -go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.11.0 h1:eyJ6njZmH16h9dOKCi7lMswAnGsSOwgTqWzfxqcuNr8= -go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.11.0/go.mod h1:FnDp7XemjN3oZ3xGunnfOUTVwd2XcvLbtRAuOSU3oc8= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.11.0 h1:j2RFV0Qdt38XQ2Jvi4WIsQ56w8T7eSirYbMw19VXRDg= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.11.0/go.mod h1:pILgiTEtrqvZpoiuGdblDgS5dbIaTgDrkIuKfEFkt+A= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.11.0 h1:v29I/NbVp7LXQYMFZhU6q17D0jSEbYOAVONlrO1oH5s= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.11.0/go.mod h1:/RpLsmbQLDO1XCbWAM4S6TSwj8FKwwgyKKyqtvVfAnw= -go.opentelemetry.io/otel/sdk v1.11.0 h1:ZnKIL9V9Ztaq+ME43IUi/eo22mNsb6a7tGfzaOWB5fo= -go.opentelemetry.io/otel/sdk v1.11.0/go.mod h1:REusa8RsyKaq0OlyangWXaw97t2VogoO4SSEeKkSTAk= -go.opentelemetry.io/otel/trace v1.11.0 h1:20U/Vj42SX+mASlXLmSGBg6jpI1jQtv682lZtTAOVFI= -go.opentelemetry.io/otel/trace v1.11.0/go.mod h1:nyYjis9jy0gytE9LXGU+/m1sHTKbRY0fX0hulNNDP1U= -go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqeYNgFYFoEGnI= -go.opentelemetry.io/proto/otlp v0.19.0 h1:IVN6GR+mhC4s5yfcTbmzHYODqvWAp3ZedA2SJPI1Nnw= -go.opentelemetry.io/proto/otlp v0.19.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= +go.opentelemetry.io/otel v1.22.0 h1:xS7Ku+7yTFvDfDraDIJVpw7XPyuHlB9MCiqqX5mcJ6Y= +go.opentelemetry.io/otel v1.22.0/go.mod h1:eoV4iAi3Ea8LkAEI9+GFT44O6T/D0GWAVFyZVCC6pMI= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.22.0 h1:9M3+rhx7kZCIQQhQRYaZCdNu1V73tm4TvXs2ntl98C4= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.22.0/go.mod h1:noq80iT8rrHP1SfybmPiRGc9dc5M8RPmGvtwo7Oo7tc= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.22.0 h1:H2JFgRcGiyHg7H7bwcwaQJYrNFqCqrbTQ8K4p1OvDu8= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.22.0/go.mod h1:WfCWp1bGoYK8MeULtI15MmQVczfR+bFkk0DF3h06QmQ= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.22.0 h1:FyjCyI9jVEfqhUh2MoSkmolPjfh5fp2hnV0b0irxH4Q= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.22.0/go.mod h1:hYwym2nDEeZfG/motx0p7L7J1N1vyzIThemQsb4g2qY= +go.opentelemetry.io/otel/metric v1.22.0 h1:lypMQnGyJYeuYPhOM/bgjbFM6WE44W1/T45er4d8Hhg= +go.opentelemetry.io/otel/metric v1.22.0/go.mod h1:evJGjVpZv0mQ5QBRJoBF64yMuOf4xCWdXjK8pzFvliY= +go.opentelemetry.io/otel/sdk v1.22.0 h1:6coWHw9xw7EfClIC/+O31R8IY3/+EiRFHevmHafB2Gw= +go.opentelemetry.io/otel/sdk v1.22.0/go.mod h1:iu7luyVGYovrRpe2fmj3CVKouQNdTOkxtLzPvPz1DOc= +go.opentelemetry.io/otel/trace v1.22.0 h1:Hg6pPujv0XG9QaVbGOBVHunyuLcCC3jN7WEhPx83XD0= +go.opentelemetry.io/otel/trace v1.22.0/go.mod h1:RbbHXVqKES9QhzZq/fE5UnOSILqRt40a21sPw2He1xo= +go.opentelemetry.io/proto/otlp v1.0.0 h1:T0TX0tmXU8a3CbNXzEKGeU5mIVOdf0oykP+u2lIVU/I= +go.opentelemetry.io/proto/otlp v1.0.0/go.mod h1:Sy6pihPLfYHkr3NkUbEhGHFhINUSI/v80hjKIs5JXpM= go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto= go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE= go.uber.org/mock v0.4.0 h1:VcM4ZOtdbR4f6VXfiOpwpVJDL6lCReaZ6mw31wqh7KU= @@ -682,8 +673,6 @@ golang.org/x/mod v0.4.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.1/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= -golang.org/x/mod v0.17.0 h1:zY54UmvipHiNd+pm+m0x9KhZ9hl1/7QNMyxXbc6ICqA= -golang.org/x/mod v0.17.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= golang.org/x/net v0.0.0-20180719180050-a680a1efc54d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= @@ -740,7 +729,6 @@ golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43/go.mod h1:KelEdhl1UZF7XfJ golang.org/x/oauth2 v0.0.0-20201109201403-9fd604954f58/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= golang.org/x/oauth2 v0.0.0-20201208152858-08078c50e5b5/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= golang.org/x/oauth2 v0.0.0-20210218202405-ba52d332ba99/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= -golang.org/x/oauth2 v0.0.0-20211104180415-d3ed0bb246c8/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -773,7 +761,6 @@ golang.org/x/sys v0.0.0-20190904154756-749cb33beabd/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191001151750-bb3f8db39f24/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191120155948-bd437916bb0e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191204072324-ce4227a45e2e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -800,9 +787,7 @@ golang.org/x/sys v0.0.0-20201201145000-ef89a241ccb3/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20210104204734-6f8348627aad/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210112080510-489259a85091/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210225134936-a50acf3fe073/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210316164454-77fc1eacc6aa/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210403161142-5e06dd20ab57/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -815,12 +800,14 @@ golang.org/x/sys v0.0.0-20211007075335-d3039528d8ac/go.mod h1:oPkhp1MJrh7nUepCBc golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220209214540-3681064d5158/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220310020820-b874c991c1a5/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.0.0-20220405052023-b1e9470b6e64/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220412211240-33da011f77ad/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.20.0 h1:Od9JTbYCk261bKm4M/mw7AklTlFYIa0bIp9BgSm1S8Y= golang.org/x/sys v0.20.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= @@ -959,7 +946,6 @@ google.golang.org/genproto v0.0.0-20200312145019-da6875a35672/go.mod h1:55QSHmfG google.golang.org/genproto v0.0.0-20200331122359-1ee6d9798940/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= google.golang.org/genproto v0.0.0-20200430143042-b979b6f78d84/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= google.golang.org/genproto v0.0.0-20200511104702-f5ebc3bea380/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= -google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= google.golang.org/genproto v0.0.0-20200515170657-fc4c6c6a6587/go.mod h1:YsZOwe1myG/8QRHRsmBRE1LrgQY60beZKjly0O1fX9U= google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo= google.golang.org/genproto v0.0.0-20200618031413-b414f8b61790/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA= @@ -974,13 +960,10 @@ google.golang.org/genproto v0.0.0-20201214200347-8c77b98c765d/go.mod h1:FWY/as6D google.golang.org/genproto v0.0.0-20210108203827-ffc7fda8c3d7/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= google.golang.org/genproto v0.0.0-20210226172003-ab064af71705/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= google.golang.org/genproto v0.0.0-20210624195500-8bfb893ecb84/go.mod h1:SzzZ/N+nwJDaO1kznhnlzqS8ocJICar6hYhVyhi++24= -google.golang.org/genproto v0.0.0-20211118181313-81c1377c94b1/go.mod h1:5CzLGKJ67TSI2B9POpiiyGha0AjJvZIUgRMt1dSmuhc= -google.golang.org/genproto v0.0.0-20230711160842-782d3b101e98 h1:Z0hjGZePRE0ZBWotvtrwxFNrNE9CUAGtplaDK5NNI/g= -google.golang.org/genproto v0.0.0-20230711160842-782d3b101e98/go.mod h1:S7mY02OqCJTD0E1OiQy1F72PWFB4bZJ87cAtLPYgDR0= -google.golang.org/genproto/googleapis/api v0.0.0-20230711160842-782d3b101e98 h1:FmF5cCW94Ij59cfpoLiwTgodWmm60eEV0CjlsVg2fuw= -google.golang.org/genproto/googleapis/api v0.0.0-20230711160842-782d3b101e98/go.mod h1:rsr7RhLuwsDKL7RmgDDCUc6yaGr1iqceVb5Wv6f6YvQ= -google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98 h1:bVf09lpb+OJbByTj913DRJioFFAjf/ZGxEz7MajTp2U= -google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98/go.mod h1:TUfxEVdsvPg18p6AslUXFoLdpED4oBnGwyqk3dV1XzM= +google.golang.org/genproto/googleapis/api v0.0.0-20240318140521-94a12d6c2237 h1:RFiFrvy37/mpSpdySBDrUdipW/dHwsRwh3J3+A9VgT4= +google.golang.org/genproto/googleapis/api v0.0.0-20240318140521-94a12d6c2237/go.mod h1:Z5Iiy3jtmioajWHDGFk7CeugTyHtPvMHA4UTmUkyalE= +google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237 h1:NnYq6UN9ReLM9/Y01KWNOWyI5xQ9kbIms5GGJVwS/Yc= +google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237/go.mod h1:WtryC6hu0hhx87FDGxWCDptyssuo68sk10vYjF+T9fY= google.golang.org/grpc v1.12.0/go.mod h1:yo6s7OP7yaDglbqo1J04qKzAhqBH6lvTonzMVmEdcZw= google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= google.golang.org/grpc v1.20.1/go.mod h1:10oTOabMzJvdu6/UiuZezV6QK5dSlG84ov/aaiqXj38= @@ -995,16 +978,12 @@ google.golang.org/grpc v1.29.1/go.mod h1:itym6AZVZYACWQqET3MqgPpjcuV5QH3BxFS3Iji google.golang.org/grpc v1.30.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= google.golang.org/grpc v1.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= google.golang.org/grpc v1.31.1/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= -google.golang.org/grpc v1.33.1/go.mod h1:fr5YgcSWrqhRRxogOsw7RzIpsmvOZ6IcH4kBYTpR3n0= google.golang.org/grpc v1.33.2/go.mod h1:JMHMWHQWaTccqQQlmk3MJZS+GWXOdAesneDmEnv2fbc= google.golang.org/grpc v1.34.0/go.mod h1:WotjhfgOW/POjDeRt8vscBtXq+2VjORFy659qA51WJ8= google.golang.org/grpc v1.35.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= -google.golang.org/grpc v1.36.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= google.golang.org/grpc v1.38.0/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM= -google.golang.org/grpc v1.40.0/go.mod h1:ogyxbiOoUXAkP+4+xa6PZSE9DZgIHtSpzjDTB9KAK34= -google.golang.org/grpc v1.42.0/go.mod h1:k+4IHHFw41K8+bbowsex27ge2rCb65oeWqe4jJ590SU= -google.golang.org/grpc v1.58.3 h1:BjnpXut1btbtgN/6sp+brB2Kbm2LjNXnidYujAVbSoQ= -google.golang.org/grpc v1.58.3/go.mod h1:tgX3ZQDlNJGU96V6yHh1T/JeoBQ2TXdr43YbYSsCJk0= +google.golang.org/grpc v1.64.0 h1:KH3VH9y/MgNQg1dE7b3XfVK0GsPSIzJwdF617gUSbvY= +google.golang.org/grpc v1.64.0/go.mod h1:oxjF8E3FBnjp+/gVFYdWacaLDx9na1aqy9oovLpxQYg= google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= @@ -1017,9 +996,8 @@ google.golang.org/protobuf v1.24.0/go.mod h1:r/3tXBNzIEhYS9I1OUVjXDlt8tc493IdKGj google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c= google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= -google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= -google.golang.org/protobuf v1.33.0 h1:uNO2rsAINq/JlFpSdYEKIZ0uKD/R9cpdv0T+yoGwGmI= -google.golang.org/protobuf v1.33.0/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= +google.golang.org/protobuf v1.34.2 h1:6xV6lTsCfpGD21XK49h7MhtcApnLqkfYgPcdHftf6hg= +google.golang.org/protobuf v1.34.2/go.mod h1:qYOHts0dSfpeUzUFpOMr/WGzszTmLH+DiWniOlNbLDw= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= @@ -1039,7 +1017,6 @@ gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkep gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.2.3/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= @@ -1059,3 +1036,5 @@ honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9 rsc.io/binaryregexp v0.2.0/go.mod h1:qTv7/COck+e2FymRvadv62gMdZztPaShugOCi3I+8D8= rsc.io/quote/v3 v3.1.0/go.mod h1:yEA65RcK8LyAZtP9Kv3t0HmxON59tX3rD+tICJqUlj0= rsc.io/sampler v1.3.0/go.mod h1:T1hPZKmBbMNahiBKFy5HrXp6adAjACjK9JXDnKaTXpA= +rsc.io/tmplfunc v0.0.3 h1:53XFQh69AfOa8Tw0Jm7t+GV7KZhOi6jzsCzTtKbMvzU= +rsc.io/tmplfunc v0.0.3/go.mod h1:AG3sTPzElb1Io3Yg4voV9AGZJuleGAwaVRxL9M49PhA= diff --git a/tests/flows/teleporter_registry.go b/tests/flows/teleporter_registry.go index 3562e4b85..92b4859de 100644 --- a/tests/flows/teleporter_registry.go +++ b/tests/flows/teleporter_registry.go @@ -3,7 +3,6 @@ package flows import ( "context" - runner_sdk "github.com/ava-labs/avalanche-network-runner/client" "github.com/ava-labs/subnet-evm/accounts/abi/bind" "github.com/ava-labs/teleporter/tests/interfaces" "github.com/ava-labs/teleporter/tests/utils" @@ -76,8 +75,9 @@ func TeleporterRegistry(network interfaces.LocalNetwork) { utils.SetChainConfig(chainConfigs, subnetAInfo, warpEnabledChainConfigA) // Restart nodes with new chain config - nodeNames := network.GetAllNodeNames() - network.RestartNodes(ctx, nodeNames, runner_sdk.WithChainConfigs(chainConfigs)) + nodeIDs := network.GetAllNodeIDs() + network.SetChainConfigs(chainConfigs) + network.RestartNodes(ctx, nodeIDs) // Call addProtocolVersion on subnetB to register the new Teleporter version utils.AddProtocolVersionAndWaitForAcceptance( diff --git a/tests/flows/validator_churn.go b/tests/flows/validator_churn.go index 9b12c2ef2..cc313ce0f 100644 --- a/tests/flows/validator_churn.go +++ b/tests/flows/validator_churn.go @@ -2,7 +2,6 @@ package flows import ( "context" - "fmt" "math/big" "github.com/ava-labs/subnet-evm/accounts/abi/bind" @@ -63,7 +62,7 @@ func ValidatorChurn(network interfaces.LocalNetwork) { // // Add new nodes to the validator set - network.AddSubnetValidators(ctx, subnetAInfo.SubnetID, constructNodesToAddNames(network)) + network.AddSubnetValidators(ctx, subnetAInfo.SubnetID, newNodeCount) // Refresh the subnet info subnetAInfo, subnetBInfo = utils.GetTwoSubnets(network) @@ -128,16 +127,3 @@ func ValidatorChurn(network interfaces.LocalNetwork) { // If this changes in the future, this test will need to perform cleanup by removing the nodes that were added // and re-adding the nodes that were removed. } - -// Each subnet is assumed to have {nodesPerSubnet} nodes named nodeN-bls, where -// N is unique across each subnet. Nodes to be added should thus be named nodeN-bls -// where N starts one greater than the current total number of nodes. -func constructNodesToAddNames(network interfaces.Network) []string { - startingNodeId := len(network.GetSubnetsInfo())*nodesPerSubnet + 1 - var nodesToAdd []string - for i := startingNodeId; i < startingNodeId+newNodeCount; i++ { - n := fmt.Sprintf("node%d-bls", i) - nodesToAdd = append(nodesToAdd, n) - } - return nodesToAdd -} diff --git a/tests/flows/validator_set_sig.go b/tests/flows/validator_set_sig.go index e79c9eb4a..81965f447 100644 --- a/tests/flows/validator_set_sig.go +++ b/tests/flows/validator_set_sig.go @@ -4,7 +4,6 @@ import ( "context" "math/big" - runner_sdk "github.com/ava-labs/avalanche-network-runner/client" "github.com/ava-labs/subnet-evm/accounts/abi/bind" exampleerc20 "github.com/ava-labs/teleporter/abi-bindings/go/Mocks/ExampleERC20" validatorsetsig "github.com/ava-labs/teleporter/abi-bindings/go/Utilities/ValidatorSetSig" @@ -132,8 +131,9 @@ func ValidatorSetSig(network interfaces.LocalNetwork) { utils.SetChainConfig(chainConfigs, subnetB, warpEnabledChainConfigWithMsg) // Restart nodes with new chain config - nodeNames := network.GetAllNodeNames() - network.RestartNodes(ctx, nodeNames, runner_sdk.WithChainConfigs(chainConfigs)) + network.SetChainConfigs(chainConfigs) + nodeIDs := network.GetAllNodeIDs() + network.RestartNodes(ctx, nodeIDs) // ************************************************************************************************ // Test Case 1: validatorChain (subnetB) != targetChain (subnetA) diff --git a/tests/interfaces/local_network.go b/tests/interfaces/local_network.go index fdd465531..b27b4650a 100644 --- a/tests/interfaces/local_network.go +++ b/tests/interfaces/local_network.go @@ -4,7 +4,6 @@ import ( "context" "crypto/ecdsa" - runner_sdk "github.com/ava-labs/avalanche-network-runner/client" "github.com/ava-labs/avalanchego/ids" avalancheWarp "github.com/ava-labs/avalanchego/vms/platformvm/warp" "github.com/ava-labs/subnet-evm/core/types" @@ -13,15 +12,16 @@ import ( type LocalNetwork interface { Network - AddSubnetValidators(ctx context.Context, subnetID ids.ID, nodeNames []string) + AddSubnetValidators(ctx context.Context, subnetID ids.ID, count uint) ConstructSignedWarpMessage( ctx context.Context, sourceReceipt *types.Receipt, source SubnetTestInfo, destination SubnetTestInfo, ) *avalancheWarp.Message - GetAllNodeNames() []string - RestartNodes(ctx context.Context, nodeNames []string, opts ...runner_sdk.OpOption) + GetAllNodeIDs() []ids.NodeID + SetChainConfigs(chainConfigs map[string]string) + RestartNodes(ctx context.Context, nodeIDs []ids.NodeID) DeployTeleporterContracts( transactionBytes []byte, deployerAddress common.Address, diff --git a/tests/local/network.go b/tests/local/network.go index 90dda648d..1a0cbba21 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -3,26 +3,28 @@ package local import ( "context" "crypto/ecdsa" - "fmt" + "encoding/hex" + "encoding/json" "math/big" "os" + "slices" "time" - runner_sdk "github.com/ava-labs/avalanche-network-runner/client" - "github.com/ava-labs/avalanche-network-runner/rpcpb" + "github.com/ava-labs/avalanchego/api/info" + "github.com/ava-labs/avalanchego/config" "github.com/ava-labs/avalanchego/ids" + "github.com/ava-labs/avalanchego/tests/fixture/tmpnet" "github.com/ava-labs/avalanchego/utils/constants" - "github.com/ava-labs/avalanchego/utils/logging" + "github.com/ava-labs/avalanchego/utils/crypto/secp256k1" "github.com/ava-labs/avalanchego/vms/platformvm" avalancheWarp "github.com/ava-labs/avalanchego/vms/platformvm/warp" "github.com/ava-labs/subnet-evm/accounts/abi/bind" "github.com/ava-labs/subnet-evm/core/types" "github.com/ava-labs/subnet-evm/ethclient" subnetEvmInterfaces "github.com/ava-labs/subnet-evm/interfaces" - "github.com/ava-labs/subnet-evm/plugin/evm" "github.com/ava-labs/subnet-evm/precompile/contracts/warp" "github.com/ava-labs/subnet-evm/rpc" - "github.com/ava-labs/subnet-evm/tests/utils/runner" + subnetEvmTestUtils "github.com/ava-labs/subnet-evm/tests/utils" warpBackend "github.com/ava-labs/subnet-evm/warp" teleportermessenger "github.com/ava-labs/teleporter/abi-bindings/go/Teleporter/TeleporterMessenger" @@ -42,15 +44,13 @@ var _ interfaces.LocalNetwork = &LocalNetwork{} type LocalNetwork struct { teleporterContractAddress common.Address primaryNetworkInfo *interfaces.SubnetTestInfo - subnetAID, subnetBID ids.ID subnetsInfo map[ids.ID]*interfaces.SubnetTestInfo - subnetNodeNames map[ids.ID][]string + extraNodes []*tmpnet.Node globalFundedKey *ecdsa.PrivateKey // Internal vars only used to set up the local network - anrClient runner_sdk.Client - manager *runner.NetworkManager + tmpnet *tmpnet.Network warpChainConfigPath string } @@ -69,17 +69,11 @@ func NewLocalNetwork(warpGenesisFile string) *LocalNetwork { ctx := context.Background() var err error - // Name 10 new validators (which should have BLS key registered) - var subnetANodeNames []string - var subnetBNodeNames []string - for i := 1; i <= 10; i++ { - n := fmt.Sprintf("node%d-bls", i) - if i <= 5 { - subnetANodeNames = append(subnetANodeNames, n) - } else { - subnetBNodeNames = append(subnetBNodeNames, n) - } - } + // Declare 10 new validators (which should have BLS key registered) + subnetANodes := subnetEvmTestUtils.NewTmpnetNodes(5) + subnetBNodes := subnetEvmTestUtils.NewTmpnetNodes(5) + // and some extra nodes to be used to add more validators later: + extraNodes := subnetEvmTestUtils.NewTmpnetNodes(5) f, err := os.CreateTemp(os.TempDir(), "config.json") Expect(err).Should(BeNil()) @@ -91,81 +85,66 @@ func NewLocalNetwork(warpGenesisFile string) *LocalNetwork { _, err = os.Stat(warpGenesisFile) Expect(err).Should(BeNil()) - anrConfig := runner.NewDefaultANRConfig() - anrConfig.GlobalCChainConfig = warpEnabledChainConfig - manager := runner.NewNetworkManager(anrConfig) + subnetA := subnetEvmTestUtils.NewTmpnetSubnet( + "A", + warpGenesisFile, + subnetEvmTestUtils.DefaultChainConfig, + subnetANodes..., + ) - // Construct the network using the avalanche-network-runner - _, err = manager.StartDefaultNetwork(ctx) - Expect(err).Should(BeNil()) - err = manager.SetupNetwork( - ctx, - anrConfig.AvalancheGoExecPath, - []*rpcpb.BlockchainSpec{ - { - VmName: evm.IDStr, - Genesis: warpGenesisFile, - ChainConfig: warpChainConfigPath, - SubnetSpec: &rpcpb.SubnetSpec{ - SubnetConfig: "", - Participants: subnetANodeNames, - }, - }, - { - VmName: evm.IDStr, - Genesis: warpGenesisFile, - ChainConfig: warpChainConfigPath, - SubnetSpec: &rpcpb.SubnetSpec{ - SubnetConfig: "", - Participants: subnetBNodeNames, - }, - }, - }, + subnetB := subnetEvmTestUtils.NewTmpnetSubnet( + "B", + warpGenesisFile, + subnetEvmTestUtils.DefaultChainConfig, + subnetBNodes..., ) - Expect(err).Should(BeNil()) - // Issue transactions to activate the proposerVM fork on the chains - globalFundedKey, err := crypto.HexToECDSA(fundedKeyStr) + network := subnetEvmTestUtils.NewTmpnetNetwork( + "teleporter-test-local-network", + append(subnetANodes, append(subnetBNodes, extraNodes...)...), + tmpnet.FlagsMap{}, + subnetA, + subnetB, + ) + Expect(network).ShouldNot(BeNil()) + + avalancheGoBuildPath, ok := os.LookupEnv("AVALANCHEGO_BUILD_PATH") + Expect(ok).Should(Equal(true)) + + ctxWithTimeout, cancelBootstrap := context.WithTimeout(ctx, time.Minute*5) + err = tmpnet.BootstrapNewNetwork( + ctxWithTimeout, + os.Stdout, + network, + "", + avalancheGoBuildPath+"/avalanchego", + avalancheGoBuildPath+"/plugins", + ) + defer cancelBootstrap() Expect(err).Should(BeNil()) - setupProposerVM(ctx, globalFundedKey, manager, 0) - setupProposerVM(ctx, globalFundedKey, manager, 1) - // Create the ANR client - logLevel, err := logging.ToLevel("info") + fundedKeyBytes, err := hex.DecodeString(fundedKeyStr) Expect(err).Should(BeNil()) - - logFactory := logging.NewFactory(logging.Config{ - DisplayLevel: logLevel, - LogLevel: logLevel, - }) - zapLog, err := logFactory.Make("main") + fundedKeySecp256k1, err := secp256k1.ToPrivateKey(fundedKeyBytes) Expect(err).Should(BeNil()) + network.PreFundedKeys = append(network.PreFundedKeys, fundedKeySecp256k1) - anrClient, err := runner_sdk.New(runner_sdk.Config{ - Endpoint: "0.0.0.0:12352", - DialTimeout: 10 * time.Second, - }, zapLog) + globalFundedKey, err := crypto.HexToECDSA(fundedKeyStr) Expect(err).Should(BeNil()) - // On initial startup, we need to first set the subnet node names - // before calling setSubnetValues for the two subnets - subnetIDs := manager.GetSubnets() - Expect(len(subnetIDs)).Should(Equal(2)) - subnetAID := subnetIDs[0] - subnetBID := subnetIDs[1] + subnetAID := network.GetSubnet("A").SubnetID + subnetBID := network.GetSubnet("B").SubnetID + + // Issue transactions to activate the proposerVM fork on the chains + setupProposerVM(ctx, globalFundedKey, network, subnetAID) + setupProposerVM(ctx, globalFundedKey, network, subnetBID) res := &LocalNetwork{ - subnetAID: subnetAID, - subnetBID: subnetBID, - primaryNetworkInfo: &interfaces.SubnetTestInfo{}, - subnetsInfo: make(map[ids.ID]*interfaces.SubnetTestInfo), - subnetNodeNames: map[ids.ID][]string{ - subnetAID: subnetANodeNames, - subnetBID: subnetBNodeNames, - }, + primaryNetworkInfo: &interfaces.SubnetTestInfo{}, + subnetsInfo: make(map[ids.ID]*interfaces.SubnetTestInfo), + extraNodes: extraNodes, globalFundedKey: globalFundedKey, - anrClient: anrClient, - manager: manager, + tmpnet: network, warpChainConfigPath: warpChainConfigPath, } res.setSubnetValues(subnetAID) @@ -179,22 +158,20 @@ func (n *LocalNetwork) setPrimaryNetworkValues() { // Get the C-Chain node URIs. // All subnet nodes validate the C-Chain, so we can include them all here var nodeURIs []string - nodeURIs = append(nodeURIs, n.subnetsInfo[n.subnetAID].NodeURIs...) - nodeURIs = append(nodeURIs, n.subnetsInfo[n.subnetBID].NodeURIs...) - pChainClient := platformvm.NewClient(nodeURIs[0]) - blockChains, err := pChainClient.GetBlockchains(context.Background()) - Expect(err).Should(BeNil()) - - var cChainBlockchainID ids.ID - for _, chain := range blockChains { - if chain.Name == "C-Chain" { - cChainBlockchainID = chain.ID - } + nodeURIs = append(nodeURIs, n.subnetsInfo[n.tmpnet.GetSubnet("A").SubnetID].NodeURIs...) + nodeURIs = append(nodeURIs, n.subnetsInfo[n.tmpnet.GetSubnet("B").SubnetID].NodeURIs...) + for _, extraNode := range n.extraNodes { + uri, err := n.tmpnet.GetURIForNodeID(extraNode.NodeID) + Expect(err).Should(BeNil()) + nodeURIs = append(nodeURIs, uri) } + + cChainBlockchainID, err := info.NewClient(nodeURIs[0]).GetBlockchainID(context.Background(), "C") + Expect(err).Should(BeNil()) Expect(cChainBlockchainID).ShouldNot(Equal(ids.Empty)) - chainWSURI := utils.HttpToWebsocketURI(nodeURIs[0], utils.CChainPathSpecifier) - chainRPCURI := utils.HttpToRPCURI(nodeURIs[0], utils.CChainPathSpecifier) + chainWSURI := utils.HttpToWebsocketURI(nodeURIs[0], cChainBlockchainID.String()) + chainRPCURI := utils.HttpToRPCURI(nodeURIs[0], cChainBlockchainID.String()) if n.primaryNetworkInfo != nil && n.primaryNetworkInfo.WSClient != nil { n.primaryNetworkInfo.WSClient.Close() } @@ -220,22 +197,26 @@ func (n *LocalNetwork) setPrimaryNetworkValues() { } func (n *LocalNetwork) setSubnetValues(subnetID ids.ID) { - subnetDetails, ok := n.manager.GetSubnet(subnetID) - Expect(ok).Should(BeTrue()) - blockchainID := subnetDetails.BlockchainID - - // Reset the validator URIs, as they may have changed - subnetDetails.ValidatorURIs = nil - status, err := n.anrClient.Status(context.Background()) - Expect(err).Should(BeNil()) - nodeInfos := status.GetClusterInfo().GetNodeInfos() + subnet := n.tmpnet.Subnets[slices.IndexFunc( + n.tmpnet.Subnets, + func(s *tmpnet.Subnet) bool { return s.SubnetID == subnetID }, + )] + + blockchainID := subnet.Chains[slices.IndexFunc( + subnet.Chains, + func(c *tmpnet.Chain) bool { + // pick the chain ID for the chain that's not the c-chain + return c.ChainID.String() != "11111111111111111111111111111111LpoYY" + }, + )].ChainID - for _, nodeName := range n.subnetNodeNames[subnetID] { - log.Info("Adding validator URI", "nodeName", nodeName, "uri", nodeInfos[nodeName].Uri) - subnetDetails.ValidatorURIs = append(subnetDetails.ValidatorURIs, nodeInfos[nodeName].Uri) - } var chainNodeURIs []string - chainNodeURIs = append(chainNodeURIs, subnetDetails.ValidatorURIs...) + for _, validatorID := range subnet.ValidatorIDs { + uri, err := n.tmpnet.GetURIForNodeID(validatorID) + Expect(err).Should(BeNil(), "failed to get URI for node ID %s", validatorID) + Expect(uri).ShouldNot(HaveLen(0)) + chainNodeURIs = append(chainNodeURIs, uri) + } chainWSURI := utils.HttpToWebsocketURI(chainNodeURIs[0], blockchainID.String()) chainRPCURI := utils.HttpToRPCURI(chainNodeURIs[0], blockchainID.String()) @@ -363,8 +344,8 @@ func (n *LocalNetwork) DeployTeleporterRegistryContracts( func (n *LocalNetwork) GetSubnetsInfo() []interfaces.SubnetTestInfo { return []interfaces.SubnetTestInfo{ - *n.subnetsInfo[n.subnetAID], - *n.subnetsInfo[n.subnetBID], + *n.subnetsInfo[n.tmpnet.GetSubnet("A").SubnetID], + *n.subnetsInfo[n.tmpnet.GetSubnet("B").SubnetID], } } @@ -453,74 +434,146 @@ func (n *LocalNetwork) RelayMessage(ctx context.Context, } func (n *LocalNetwork) setAllSubnetValues() { - subnetIDs := n.manager.GetSubnets() + subnetIDs := n.GetSubnetsInfo() Expect(len(subnetIDs)).Should(Equal(2)) - n.subnetAID = subnetIDs[0] - n.setSubnetValues(n.subnetAID) - - n.subnetBID = subnetIDs[1] - n.setSubnetValues(n.subnetBID) + n.setSubnetValues(n.tmpnet.GetSubnet("A").SubnetID) + n.setSubnetValues(n.tmpnet.GetSubnet("B").SubnetID) n.setPrimaryNetworkValues() } func (n *LocalNetwork) TearDownNetwork() { log.Info("Tearing down network") - Expect(n.manager).ShouldNot(BeNil()) - Expect(n.manager.TeardownNetwork()).Should(BeNil()) + Expect(n).ShouldNot(BeNil()) + Expect(n.tmpnet).ShouldNot(BeNil()) + Expect(n.tmpnet.Stop(context.Background())).Should(BeNil()) Expect(os.Remove(n.warpChainConfigPath)).Should(BeNil()) } -func (n *LocalNetwork) AddSubnetValidators(ctx context.Context, subnetID ids.ID, nodeNames []string) { - _, err := n.anrClient.AddSubnetValidators(ctx, []*rpcpb.SubnetValidatorsSpec{ - { - SubnetId: subnetID.String(), - NodeNames: nodeNames, - }, - }) +func (n *LocalNetwork) AddSubnetValidators(ctx context.Context, subnetID ids.ID, count uint) { + Expect(count > 0).Should(BeTrue(), "can't add 0 validators") + Expect(uint(len(n.extraNodes)) >= count).Should( + BeTrue(), + "not enough extra nodes to use", + ) + + subnet := n.tmpnet.Subnets[slices.IndexFunc( + n.tmpnet.Subnets, + func(s *tmpnet.Subnet) bool { return s.SubnetID == subnetID }, + )] + + // consume some of the extraNodes + newValidatorNodes := n.extraNodes[0:count] + slices.Delete(n.extraNodes, 0, int(count)) + + apiURI, err := n.tmpnet.GetURIForNodeID(subnet.ValidatorIDs[0]) Expect(err).Should(BeNil()) - // Add the new node names - n.subnetNodeNames[subnetID] = append(n.subnetNodeNames[subnetID], nodeNames...) + ctx, cancel := context.WithTimeout(ctx, 30*time.Second) + defer cancel() + err = subnet.AddValidators( + ctx, + os.Stdout, + apiURI, + newValidatorNodes..., + ) + Expect(err).Should(BeNil()) + + for _, node := range newValidatorNodes { + subnet.ValidatorIDs = append(subnet.ValidatorIDs, node.NodeID) + node.Flags[config.TrackSubnetsKey] = subnetID.String() + } + + tmpnet.WaitForActiveValidators(ctx, os.Stdout, platformvm.NewClient(n.tmpnet.Nodes[0].URI), subnet) + + nodeIdsToRestart := make([]ids.NodeID, len(newValidatorNodes)) + for i, node := range newValidatorNodes { + nodeIdsToRestart[i] = node.NodeID + } + n.RestartNodes(ctx, nodeIdsToRestart) n.setAllSubnetValues() } -// GetAllNodeNames returns a slice that copies all node names in the network -func (n *LocalNetwork) GetAllNodeNames() []string { - // The network starts off with 5 nodes that validate the primary network. - // These nodes were not added by this network setup, and are not in n.subnetNodeNames. - // So we query the ANR client to get the full list of node names. - status, err := n.anrClient.Status(context.Background()) - Expect(err).Should(BeNil()) - return status.GetClusterInfo().GetNodeNames() +// GetAllNodeIDs returns a slice that copies the NodeID's of all nodes in the network +func (n *LocalNetwork) GetAllNodeIDs() []ids.NodeID { + nodeIDs := make([]ids.NodeID, len(n.tmpnet.Nodes)) + for i, node := range n.tmpnet.Nodes { + nodeIDs[i] = node.NodeID + } + return nodeIDs } -func (n *LocalNetwork) RestartNodes(ctx context.Context, nodeNames []string, opts ...runner_sdk.OpOption) { - log.Info("Network restarting nodes", "nodeNames", nodeNames) - opts = append(opts, - runner_sdk.WithExecPath(n.manager.ANRConfig.AvalancheGoExecPath), - runner_sdk.WithPluginDir(n.manager.ANRConfig.PluginDir)) - for _, nodeName := range nodeNames { - _, err := n.anrClient.RestartNode(ctx, nodeName, opts...) +func (n *LocalNetwork) RestartNodes(ctx context.Context, nodeIDs []ids.NodeID) { + log.Info("Restarting nodes", "nodeIDs", nodeIDs) + var nodes []*tmpnet.Node + for _, nodeID := range nodeIDs { + for _, node := range n.tmpnet.Nodes { + if node.NodeID == nodeID { + nodes = append(nodes, node) + } + } + } + + for _, node := range nodes { + ctx, cancel := context.WithTimeout(ctx, 30*time.Second) + defer cancel() + err := node.SaveAPIPort() + Expect(err).Should(BeNil()) + + err = node.Stop(ctx) + Expect(err).Should(BeNil()) + + err = n.tmpnet.StartNode(ctx, os.Stdout, node) Expect(err).Should(BeNil()) } - log.Info("Waiting for all VMs to report healthy") - for { - v, err := n.anrClient.Health(ctx) - log.Info("Pinged CLI Health", "result", v, "err", err) - if err != nil { - time.Sleep(1 * time.Second) - continue - } - break + log.Info("Waiting for all nodes to report healthy") + ctx, cancel := context.WithTimeout(ctx, 30*time.Second) + defer cancel() + for _, node := range nodes { + err := tmpnet.WaitForHealthy(ctx, node) + Expect(err).Should(BeNil()) } n.setAllSubnetValues() } +func (n *LocalNetwork) SetChainConfigs(chainConfigs map[string]string) { + for chainIdStr, chainConfig := range chainConfigs { + if chainIdStr == utils.CChainPathSpecifier { + var cfg tmpnet.FlagsMap + err := json.Unmarshal([]byte(chainConfig), &cfg) + if err != nil { + log.Error( + "failed to unmarshal chain config", + "error", err, + "chainConfig", chainConfig, + ) + } + n.tmpnet.ChainConfigs[utils.CChainPathSpecifier] = cfg + continue + } + + for _, subnet := range n.tmpnet.Subnets { + for _, chain := range subnet.Chains { + if chain.ChainID.String() == chainIdStr { + chain.Config = chainConfig + } + } + } + } + err := n.tmpnet.Write() + if err != nil { + log.Error("failed to write network", "error", err) + } + err = n.tmpnet.WriteSubnets() + if err != nil { + log.Error("failed to write subnets", "error", err) + } +} + func (n *LocalNetwork) ConstructSignedWarpMessage( ctx context.Context, sourceReceipt *types.Receipt, @@ -591,7 +644,5 @@ func (n *LocalNetwork) GetSignedMessage( } func (n *LocalNetwork) GetNetworkID() uint32 { - status, err := n.anrClient.Status(context.Background()) - Expect(err).Should(BeNil()) - return status.GetClusterInfo().GetNetworkId() + return n.tmpnet.Genesis.NetworkID } diff --git a/tests/local/network_utils.go b/tests/local/network_utils.go index 5339b64ff..cd297d6d4 100644 --- a/tests/local/network_utils.go +++ b/tests/local/network_utils.go @@ -3,12 +3,13 @@ package local import ( "context" "crypto/ecdsa" + "slices" "time" "github.com/ava-labs/avalanchego/ids" + "github.com/ava-labs/avalanchego/tests/fixture/tmpnet" "github.com/ava-labs/subnet-evm/ethclient" subnetEvmUtils "github.com/ava-labs/subnet-evm/tests/utils" - "github.com/ava-labs/subnet-evm/tests/utils/runner" "github.com/ava-labs/teleporter/tests/utils" "github.com/ethereum/go-ethereum/log" @@ -16,13 +17,23 @@ import ( ) // Issues txs to activate the proposer VM fork on the specified subnet index in the manager -func setupProposerVM(ctx context.Context, fundedKey *ecdsa.PrivateKey, manager *runner.NetworkManager, index int) { - subnet := manager.GetSubnets()[index] - subnetDetails, ok := manager.GetSubnet(subnet) - Expect(ok).Should(BeTrue()) +func setupProposerVM(ctx context.Context, fundedKey *ecdsa.PrivateKey, network *tmpnet.Network, subnetID ids.ID) { + subnetDetails := network.Subnets[slices.IndexFunc( + network.Subnets, + func(s *tmpnet.Subnet) bool { return s.SubnetID == subnetID }, + )] - chainID := subnetDetails.BlockchainID - uri := utils.HttpToWebsocketURI(subnetDetails.ValidatorURIs[0], chainID.String()) + chainID := subnetDetails.Chains[slices.IndexFunc( + subnetDetails.Chains, + func(c *tmpnet.Chain) bool { + // pick the chain that's NOT the C-Chain: + return c.ChainID.String() != "11111111111111111111111111111111LpoYY" + }, + )].ChainID + + nodeURI, err := network.GetURIForNodeID(subnetDetails.ValidatorIDs[0]) + Expect(err).Should(BeNil()) + uri := utils.HttpToWebsocketURI(nodeURI, chainID.String()) client, err := ethclient.Dial(uri) Expect(err).Should(BeNil()) diff --git a/tests/utils/warp-genesis.json b/tests/utils/warp-genesis.json index 821b9bdad..4035b5a72 100644 --- a/tests/utils/warp-genesis.json +++ b/tests/utils/warp-genesis.json @@ -22,7 +22,7 @@ "blockGasCostStep": 500000 }, "warpConfig": { - "blockTimestamp": 0 + "blockTimestamp": 1719343601 }, "contractNativeMinterConfig": { "blockTimestamp": 0, @@ -35,7 +35,7 @@ } }, "nonce": "0x0", - "timestamp": "0x0", + "timestamp": "0x667B19F0", "extraData": "0x00", "gasLimit": "0x1312D00", "difficulty": "0x0", From ff521f84b126917eb4c419a607cfbc1fd609b77c Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Mon, 8 Jul 2024 18:38:55 +0000 Subject: [PATCH 02/17] inline call to `GetAllNodeIDs()` addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1668952201 --- tests/flows/validator_set_sig.go | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/tests/flows/validator_set_sig.go b/tests/flows/validator_set_sig.go index 81965f447..e0cbabbef 100644 --- a/tests/flows/validator_set_sig.go +++ b/tests/flows/validator_set_sig.go @@ -132,8 +132,7 @@ func ValidatorSetSig(network interfaces.LocalNetwork) { // Restart nodes with new chain config network.SetChainConfigs(chainConfigs) - nodeIDs := network.GetAllNodeIDs() - network.RestartNodes(ctx, nodeIDs) + network.RestartNodes(ctx, network.GetAllNodeIDs()) // ************************************************************************************************ // Test Case 1: validatorChain (subnetB) != targetChain (subnetA) From eb248d9dd51bf6deebba45698e6714a045e9b56b Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Mon, 8 Jul 2024 22:16:04 +0000 Subject: [PATCH 03/17] clarify chain config map util abstraction (partially?) addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669269756 --- tests/flows/teleporter_registry.go | 8 ++++---- tests/flows/validator_set_sig.go | 4 ++-- tests/utils/utils.go | 8 +++++--- 3 files changed, 11 insertions(+), 9 deletions(-) diff --git a/tests/flows/teleporter_registry.go b/tests/flows/teleporter_registry.go index 92b4859de..96ad2a413 100644 --- a/tests/flows/teleporter_registry.go +++ b/tests/flows/teleporter_registry.go @@ -69,10 +69,10 @@ func TeleporterRegistry(network interfaces.LocalNetwork) { ) // Create chain config with off chain messages - chainConfigs := make(map[string]string) - utils.SetChainConfig(chainConfigs, cChainInfo, warpEnabledChainConfigC) - utils.SetChainConfig(chainConfigs, subnetBInfo, warpEnabledChainConfigB) - utils.SetChainConfig(chainConfigs, subnetAInfo, warpEnabledChainConfigA) + chainConfigs := make(utils.ChainConfigMap) + chainConfigs.Add(cChainInfo, warpEnabledChainConfigC) + chainConfigs.Add(subnetBInfo, warpEnabledChainConfigB) + chainConfigs.Add(subnetAInfo, warpEnabledChainConfigA) // Restart nodes with new chain config nodeIDs := network.GetAllNodeIDs() diff --git a/tests/flows/validator_set_sig.go b/tests/flows/validator_set_sig.go index e0cbabbef..827139ad8 100644 --- a/tests/flows/validator_set_sig.go +++ b/tests/flows/validator_set_sig.go @@ -127,8 +127,8 @@ func ValidatorSetSig(network interfaces.LocalNetwork) { ) // Create chain config with off-chain messages - chainConfigs := make(map[string]string) - utils.SetChainConfig(chainConfigs, subnetB, warpEnabledChainConfigWithMsg) + chainConfigs := make(utils.ChainConfigMap) + chainConfigs.Add(subnetB, warpEnabledChainConfigWithMsg) // Restart nodes with new chain config network.SetChainConfigs(chainConfigs) diff --git a/tests/utils/utils.go b/tests/utils/utils.go index 4505b318e..9e6e1f6a2 100644 --- a/tests/utils/utils.go +++ b/tests/utils/utils.go @@ -1130,12 +1130,14 @@ func DeployNewTeleporterVersion( return teleporterContractAddress } +type ChainConfigMap map[string]string + // Sets the chain config in customChainConfigs for the specified subnet -func SetChainConfig(customChainConfigs map[string]string, subnet interfaces.SubnetTestInfo, chainConfig string) { +func (m ChainConfigMap) Add(subnet interfaces.SubnetTestInfo, chainConfig string) { if subnet.SubnetID == constants.PrimaryNetworkID { - customChainConfigs[CChainPathSpecifier] = chainConfig + m[CChainPathSpecifier] = chainConfig } else { - customChainConfigs[subnet.BlockchainID.String()] = chainConfig + m[subnet.BlockchainID.String()] = chainConfig } } From 6ede518c697c3315170b18dc3f45e66bea3787d8 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Tue, 9 Jul 2024 15:59:16 +0000 Subject: [PATCH 04/17] bump up and unify timeout values addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669203425 --- tests/local/network.go | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/tests/local/network.go b/tests/local/network.go index 1a0cbba21..e0db9a88c 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -63,6 +63,8 @@ const ( "internal-debug","internal-account","internal-personal", "debug","debug-tracer","debug-file-tracer","debug-handler"] }` + + timeout = 60 * time.Second ) func NewLocalNetwork(warpGenesisFile string) *LocalNetwork { @@ -111,7 +113,7 @@ func NewLocalNetwork(warpGenesisFile string) *LocalNetwork { avalancheGoBuildPath, ok := os.LookupEnv("AVALANCHEGO_BUILD_PATH") Expect(ok).Should(Equal(true)) - ctxWithTimeout, cancelBootstrap := context.WithTimeout(ctx, time.Minute*5) + ctxWithTimeout, cancelBootstrap := context.WithTimeout(ctx, timeout) err = tmpnet.BootstrapNewNetwork( ctxWithTimeout, os.Stdout, @@ -470,7 +472,7 @@ func (n *LocalNetwork) AddSubnetValidators(ctx context.Context, subnetID ids.ID, apiURI, err := n.tmpnet.GetURIForNodeID(subnet.ValidatorIDs[0]) Expect(err).Should(BeNil()) - ctx, cancel := context.WithTimeout(ctx, 30*time.Second) + ctx, cancel := context.WithTimeout(ctx, timeout) defer cancel() err = subnet.AddValidators( ctx, @@ -517,7 +519,7 @@ func (n *LocalNetwork) RestartNodes(ctx context.Context, nodeIDs []ids.NodeID) { } for _, node := range nodes { - ctx, cancel := context.WithTimeout(ctx, 30*time.Second) + ctx, cancel := context.WithTimeout(ctx, timeout) defer cancel() err := node.SaveAPIPort() Expect(err).Should(BeNil()) From 32f349e1a4eb65f5c0491f16bd69bc2fbaac34e9 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Wed, 10 Jul 2024 02:01:05 +0000 Subject: [PATCH 05/17] instantiate subnet genesis from template w/chainID addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669335458 --- tests/local/e2e_test.go | 5 ++- tests/local/network.go | 10 ++--- tests/utils/utils.go | 39 +++++++++++++++++++ ...enesis.json => warp-genesis-template.json} | 2 +- 4 files changed, 46 insertions(+), 10 deletions(-) rename tests/utils/{warp-genesis.json => warp-genesis-template.json} (97%) diff --git a/tests/local/e2e_test.go b/tests/local/e2e_test.go index ec9fb43e4..dfe9353cf 100644 --- a/tests/local/e2e_test.go +++ b/tests/local/e2e_test.go @@ -16,7 +16,8 @@ import ( const ( teleporterByteCodeFile = "./contracts/out/TeleporterMessenger.sol/TeleporterMessenger.json" - warpGenesisFile = "./tests/utils/warp-genesis.json" + + warpGenesisTemplateFile = "./tests/utils/warp-genesis-template.json" teleporterMessengerLabel = "TeleporterMessenger" upgradeabilityLabel = "upgradeability" @@ -40,7 +41,7 @@ func TestE2E(t *testing.T) { // Define the Teleporter before and after suite functions. var _ = ginkgo.BeforeSuite(func() { // Create the local network instance - LocalNetworkInstance = NewLocalNetwork(warpGenesisFile) + LocalNetworkInstance = NewLocalNetwork(warpGenesisTemplateFile) // Generate the Teleporter deployment values teleporterDeployerTransaction, teleporterDeployerAddress, teleporterContractAddress, err := diff --git a/tests/local/network.go b/tests/local/network.go index e0db9a88c..2de76b426 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -67,7 +67,7 @@ const ( timeout = 60 * time.Second ) -func NewLocalNetwork(warpGenesisFile string) *LocalNetwork { +func NewLocalNetwork(warpGenesisTemplateFile string) *LocalNetwork { ctx := context.Background() var err error @@ -83,20 +83,16 @@ func NewLocalNetwork(warpGenesisFile string) *LocalNetwork { Expect(err).Should(BeNil()) warpChainConfigPath := f.Name() - // Make sure that the warp genesis file exists - _, err = os.Stat(warpGenesisFile) - Expect(err).Should(BeNil()) - subnetA := subnetEvmTestUtils.NewTmpnetSubnet( "A", - warpGenesisFile, + utils.InstantiateGenesisTemplate(warpGenesisTemplateFile, 12345), subnetEvmTestUtils.DefaultChainConfig, subnetANodes..., ) subnetB := subnetEvmTestUtils.NewTmpnetSubnet( "B", - warpGenesisFile, + utils.InstantiateGenesisTemplate(warpGenesisTemplateFile, 54321), subnetEvmTestUtils.DefaultChainConfig, subnetBNodes..., ) diff --git a/tests/utils/utils.go b/tests/utils/utils.go index 9e6e1f6a2..3b65edd7d 100644 --- a/tests/utils/utils.go +++ b/tests/utils/utils.go @@ -4,6 +4,7 @@ package utils import ( + "bufio" "bytes" "context" "crypto/ecdsa" @@ -11,6 +12,7 @@ import ( "errors" "fmt" "math/big" + "os" "strconv" "strings" "time" @@ -1177,3 +1179,40 @@ func GetChainConfigWithOffChainMessages(offChainMessages []avalancheWarp.Unsigne return string(offChainMessageJson) } + +// read in the template file, make the substitutions declared at the beginning +// of the function, write out the instantiation to a temp file, and then return +// the path to that temp file. +func InstantiateGenesisTemplate( + templateFileName string, + chainID uint64, +) string { + substitutions := []struct { + Target string + Value string + }{ + { + "", + strconv.FormatUint(chainID, 10), + }, + } + + templateFile, err := os.Open(templateFileName) + Expect(err).Should(BeNil()) + + subnetGenesisFile, err := os.CreateTemp(os.TempDir(), "") + Expect(err).Should(BeNil()) + + scanner := bufio.NewScanner(templateFile) + for scanner.Scan() { + var replaced string + replaced = scanner.Text() + for _, s := range substitutions { + replaced = strings.Replace(replaced, s.Target, s.Value, 1) + } + + subnetGenesisFile.WriteString(replaced) + } + + return subnetGenesisFile.Name() +} diff --git a/tests/utils/warp-genesis.json b/tests/utils/warp-genesis-template.json similarity index 97% rename from tests/utils/warp-genesis.json rename to tests/utils/warp-genesis-template.json index 4035b5a72..e01efd464 100644 --- a/tests/utils/warp-genesis.json +++ b/tests/utils/warp-genesis-template.json @@ -1,6 +1,6 @@ { "config": { - "chainId": 99999, + "chainId": , "homesteadBlock": 0, "eip150Block": 0, "eip150Hash": "0x2086799aeebeae135c246c65021c82b4e15a2c451340993aacfd2751886514f0", From f5a74112e90ec7fe43ff663511d9f5cb8369e339 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Wed, 10 Jul 2024 02:27:52 +0000 Subject: [PATCH 06/17] stop appending funded key to tmpnet's array addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669344918 --- tests/local/network.go | 8 -------- 1 file changed, 8 deletions(-) diff --git a/tests/local/network.go b/tests/local/network.go index 2de76b426..4dd9418c3 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -3,7 +3,6 @@ package local import ( "context" "crypto/ecdsa" - "encoding/hex" "encoding/json" "math/big" "os" @@ -15,7 +14,6 @@ import ( "github.com/ava-labs/avalanchego/ids" "github.com/ava-labs/avalanchego/tests/fixture/tmpnet" "github.com/ava-labs/avalanchego/utils/constants" - "github.com/ava-labs/avalanchego/utils/crypto/secp256k1" "github.com/ava-labs/avalanchego/vms/platformvm" avalancheWarp "github.com/ava-labs/avalanchego/vms/platformvm/warp" "github.com/ava-labs/subnet-evm/accounts/abi/bind" @@ -121,12 +119,6 @@ func NewLocalNetwork(warpGenesisTemplateFile string) *LocalNetwork { defer cancelBootstrap() Expect(err).Should(BeNil()) - fundedKeyBytes, err := hex.DecodeString(fundedKeyStr) - Expect(err).Should(BeNil()) - fundedKeySecp256k1, err := secp256k1.ToPrivateKey(fundedKeyBytes) - Expect(err).Should(BeNil()) - network.PreFundedKeys = append(network.PreFundedKeys, fundedKeySecp256k1) - globalFundedKey, err := crypto.HexToECDSA(fundedKeyStr) Expect(err).Should(BeNil()) From 1e4e260794b27ac10ebb0e0d69aca70696290d12 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Wed, 10 Jul 2024 02:32:13 +0000 Subject: [PATCH 07/17] document `extraNodes` addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669338202 --- tests/local/network.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tests/local/network.go b/tests/local/network.go index 4dd9418c3..e03832122 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -43,7 +43,8 @@ type LocalNetwork struct { teleporterContractAddress common.Address primaryNetworkInfo *interfaces.SubnetTestInfo subnetsInfo map[ids.ID]*interfaces.SubnetTestInfo - extraNodes []*tmpnet.Node + + extraNodes []*tmpnet.Node // to add as more subnet vaidators in the tests globalFundedKey *ecdsa.PrivateKey From 9b690bddf11f2143a4043594f5e2c8817d670744 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Wed, 10 Jul 2024 02:46:27 +0000 Subject: [PATCH 08/17] stop filtering out chains that aren't even there addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669346961 --- tests/local/network.go | 8 +------- tests/local/network_utils.go | 8 +------- 2 files changed, 2 insertions(+), 14 deletions(-) diff --git a/tests/local/network.go b/tests/local/network.go index e03832122..5f33818ef 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -193,13 +193,7 @@ func (n *LocalNetwork) setSubnetValues(subnetID ids.ID) { func(s *tmpnet.Subnet) bool { return s.SubnetID == subnetID }, )] - blockchainID := subnet.Chains[slices.IndexFunc( - subnet.Chains, - func(c *tmpnet.Chain) bool { - // pick the chain ID for the chain that's not the c-chain - return c.ChainID.String() != "11111111111111111111111111111111LpoYY" - }, - )].ChainID + blockchainID := subnet.Chains[0].ChainID var chainNodeURIs []string for _, validatorID := range subnet.ValidatorIDs { diff --git a/tests/local/network_utils.go b/tests/local/network_utils.go index cd297d6d4..da166a6e0 100644 --- a/tests/local/network_utils.go +++ b/tests/local/network_utils.go @@ -23,13 +23,7 @@ func setupProposerVM(ctx context.Context, fundedKey *ecdsa.PrivateKey, network * func(s *tmpnet.Subnet) bool { return s.SubnetID == subnetID }, )] - chainID := subnetDetails.Chains[slices.IndexFunc( - subnetDetails.Chains, - func(c *tmpnet.Chain) bool { - // pick the chain that's NOT the C-Chain: - return c.ChainID.String() != "11111111111111111111111111111111LpoYY" - }, - )].ChainID + chainID := subnetDetails.Chains[0].ChainID nodeURI, err := network.GetURIForNodeID(subnetDetails.ValidatorIDs[0]) Expect(err).Should(BeNil()) From 850c0d574cd4b29dbac31c1e287964bb0df22ece Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Thu, 11 Jul 2024 20:04:58 +0000 Subject: [PATCH 09/17] parameterize subnet specification addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669370377 --- tests/local/e2e_test.go | 16 ++++++++++- tests/local/network.go | 62 ++++++++++++++++++++++------------------- 2 files changed, 49 insertions(+), 29 deletions(-) diff --git a/tests/local/e2e_test.go b/tests/local/e2e_test.go index dfe9353cf..1e443a385 100644 --- a/tests/local/e2e_test.go +++ b/tests/local/e2e_test.go @@ -41,7 +41,21 @@ func TestE2E(t *testing.T) { // Define the Teleporter before and after suite functions. var _ = ginkgo.BeforeSuite(func() { // Create the local network instance - LocalNetworkInstance = NewLocalNetwork(warpGenesisTemplateFile) + LocalNetworkInstance = NewLocalNetwork( + warpGenesisTemplateFile, + []SubnetSpec{ + { + Name: "A", + EVMChainID: 12345, + NodeCount: 5, + }, + { + Name: "B", + EVMChainID: 54321, + NodeCount: 5, + }, + }, + ) // Generate the Teleporter deployment values teleporterDeployerTransaction, teleporterDeployerAddress, teleporterContractAddress, err := diff --git a/tests/local/network.go b/tests/local/network.go index 5f33818ef..145561c35 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -66,14 +66,17 @@ const ( timeout = 60 * time.Second ) -func NewLocalNetwork(warpGenesisTemplateFile string) *LocalNetwork { +type SubnetSpec struct { + Name string + EVMChainID uint64 + NodeCount int +} + +func NewLocalNetwork(warpGenesisTemplateFile string, subnetSpecs []SubnetSpec) *LocalNetwork { ctx := context.Background() var err error - // Declare 10 new validators (which should have BLS key registered) - subnetANodes := subnetEvmTestUtils.NewTmpnetNodes(5) - subnetBNodes := subnetEvmTestUtils.NewTmpnetNodes(5) - // and some extra nodes to be used to add more validators later: + // declare some extra nodes to be used to add more validators later: extraNodes := subnetEvmTestUtils.NewTmpnetNodes(5) f, err := os.CreateTemp(os.TempDir(), "config.json") @@ -82,26 +85,30 @@ func NewLocalNetwork(warpGenesisTemplateFile string) *LocalNetwork { Expect(err).Should(BeNil()) warpChainConfigPath := f.Name() - subnetA := subnetEvmTestUtils.NewTmpnetSubnet( - "A", - utils.InstantiateGenesisTemplate(warpGenesisTemplateFile, 12345), - subnetEvmTestUtils.DefaultChainConfig, - subnetANodes..., - ) - - subnetB := subnetEvmTestUtils.NewTmpnetSubnet( - "B", - utils.InstantiateGenesisTemplate(warpGenesisTemplateFile, 54321), - subnetEvmTestUtils.DefaultChainConfig, - subnetBNodes..., - ) + allNodes := slices.Clone(extraNodes) // to be appended w/ subnet validators + + var subnets []*tmpnet.Subnet + for _, subnetSpec := range subnetSpecs { + nodes := subnetEvmTestUtils.NewTmpnetNodes(subnetSpec.NodeCount) + allNodes = append(allNodes, nodes...) + + subnet := subnetEvmTestUtils.NewTmpnetSubnet( + subnetSpec.Name, + utils.InstantiateGenesisTemplate( + warpGenesisTemplateFile, + subnetSpec.EVMChainID, + ), + subnetEvmTestUtils.DefaultChainConfig, + nodes..., + ) + subnets = append(subnets, subnet) + } network := subnetEvmTestUtils.NewTmpnetNetwork( "teleporter-test-local-network", - append(subnetANodes, append(subnetBNodes, extraNodes...)...), + allNodes, tmpnet.FlagsMap{}, - subnetA, - subnetB, + subnets..., ) Expect(network).ShouldNot(BeNil()) @@ -123,12 +130,10 @@ func NewLocalNetwork(warpGenesisTemplateFile string) *LocalNetwork { globalFundedKey, err := crypto.HexToECDSA(fundedKeyStr) Expect(err).Should(BeNil()) - subnetAID := network.GetSubnet("A").SubnetID - subnetBID := network.GetSubnet("B").SubnetID - // Issue transactions to activate the proposerVM fork on the chains - setupProposerVM(ctx, globalFundedKey, network, subnetAID) - setupProposerVM(ctx, globalFundedKey, network, subnetBID) + for _, subnet := range network.Subnets { + setupProposerVM(ctx, globalFundedKey, network, subnet.SubnetID) + } res := &LocalNetwork{ primaryNetworkInfo: &interfaces.SubnetTestInfo{}, @@ -138,8 +143,9 @@ func NewLocalNetwork(warpGenesisTemplateFile string) *LocalNetwork { tmpnet: network, warpChainConfigPath: warpChainConfigPath, } - res.setSubnetValues(subnetAID) - res.setSubnetValues(subnetBID) + for _, subnet := range network.Subnets { + res.setSubnetValues(subnet.SubnetID) + } res.setPrimaryNetworkValues() return res } From bf37499482d8b603fb4ec8ab431401d3f03d3ff5 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Thu, 11 Jul 2024 20:18:54 +0000 Subject: [PATCH 10/17] NewLocalNetwork: parameterize network name addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669372404 --- tests/local/e2e_test.go | 1 + tests/local/network.go | 8 ++++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/tests/local/e2e_test.go b/tests/local/e2e_test.go index 1e443a385..a66d31895 100644 --- a/tests/local/e2e_test.go +++ b/tests/local/e2e_test.go @@ -42,6 +42,7 @@ func TestE2E(t *testing.T) { var _ = ginkgo.BeforeSuite(func() { // Create the local network instance LocalNetworkInstance = NewLocalNetwork( + "teleporter-test-local-network", warpGenesisTemplateFile, []SubnetSpec{ { diff --git a/tests/local/network.go b/tests/local/network.go index 145561c35..261fa403a 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -72,7 +72,11 @@ type SubnetSpec struct { NodeCount int } -func NewLocalNetwork(warpGenesisTemplateFile string, subnetSpecs []SubnetSpec) *LocalNetwork { +func NewLocalNetwork( + name string, + warpGenesisTemplateFile string, + subnetSpecs []SubnetSpec, +) *LocalNetwork { ctx := context.Background() var err error @@ -105,7 +109,7 @@ func NewLocalNetwork(warpGenesisTemplateFile string, subnetSpecs []SubnetSpec) * } network := subnetEvmTestUtils.NewTmpnetNetwork( - "teleporter-test-local-network", + name, allNodes, tmpnet.FlagsMap{}, subnets..., From eab5471972e6d8797159e43f8fc2d68902d9c3b2 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Thu, 11 Jul 2024 20:23:41 +0000 Subject: [PATCH 11/17] NewLocalNetwork: parameterize extra node count --- tests/local/e2e_test.go | 1 + tests/local/network.go | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/tests/local/e2e_test.go b/tests/local/e2e_test.go index a66d31895..a73109365 100644 --- a/tests/local/e2e_test.go +++ b/tests/local/e2e_test.go @@ -56,6 +56,7 @@ var _ = ginkgo.BeforeSuite(func() { NodeCount: 5, }, }, + 5, ) // Generate the Teleporter deployment values diff --git a/tests/local/network.go b/tests/local/network.go index 261fa403a..d54cdf471 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -76,12 +76,13 @@ func NewLocalNetwork( name string, warpGenesisTemplateFile string, subnetSpecs []SubnetSpec, + extraNodeCount int, // for use by tests, eg to add new subnet validators ) *LocalNetwork { ctx := context.Background() var err error // declare some extra nodes to be used to add more validators later: - extraNodes := subnetEvmTestUtils.NewTmpnetNodes(5) + extraNodes := subnetEvmTestUtils.NewTmpnetNodes(extraNodeCount) f, err := os.CreateTemp(os.TempDir(), "config.json") Expect(err).Should(BeNil()) From 956420b13cc5c5ca3768f97d082d37f6004082ff Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Thu, 11 Jul 2024 23:31:51 +0000 Subject: [PATCH 12/17] inform test user of tmpnet dir addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1669212049 --- tests/local/e2e_test.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/tests/local/e2e_test.go b/tests/local/e2e_test.go index a73109365..ae399863e 100644 --- a/tests/local/e2e_test.go +++ b/tests/local/e2e_test.go @@ -79,6 +79,12 @@ var _ = ginkgo.BeforeSuite(func() { LocalNetworkInstance.DeployTeleporterRegistryContracts(teleporterContractAddress, fundedKey) log.Info("Set up ginkgo before suite") + + ginkgo.AddReportEntry( + "network directory with has node logs & configs; useful in the case of failures", + LocalNetworkInstance.tmpnet.Dir, + ginkgo.ReportEntryVisibilityFailureOrVerbose, + ) }) var _ = ginkgo.AfterSuite(func() { From 87c644bd65f95de93f7f83b5765a4b43b094df5e Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Fri, 12 Jul 2024 11:20:00 -0400 Subject: [PATCH 13/17] Apply suggestions from code review Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com> Signed-off-by: F. Eugene Aumson --- tests/flows/teleporter_registry.go | 3 +-- tests/local/network.go | 8 ++++---- tests/utils/utils.go | 3 +-- 3 files changed, 6 insertions(+), 8 deletions(-) diff --git a/tests/flows/teleporter_registry.go b/tests/flows/teleporter_registry.go index 96ad2a413..edd1a0d24 100644 --- a/tests/flows/teleporter_registry.go +++ b/tests/flows/teleporter_registry.go @@ -75,9 +75,8 @@ func TeleporterRegistry(network interfaces.LocalNetwork) { chainConfigs.Add(subnetAInfo, warpEnabledChainConfigA) // Restart nodes with new chain config - nodeIDs := network.GetAllNodeIDs() network.SetChainConfigs(chainConfigs) - network.RestartNodes(ctx, nodeIDs) + network.RestartNodes(ctx, network.GetAllNodeIDs()) // Call addProtocolVersion on subnetB to register the new Teleporter version utils.AddProtocolVersionAndWaitForAcceptance( diff --git a/tests/local/network.go b/tests/local/network.go index d54cdf471..8d355a4a6 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -81,7 +81,7 @@ func NewLocalNetwork( ctx := context.Background() var err error - // declare some extra nodes to be used to add more validators later: + // Create extra nodes to be used to add more validators later extraNodes := subnetEvmTestUtils.NewTmpnetNodes(extraNodeCount) f, err := os.CreateTemp(os.TempDir(), "config.json") @@ -537,8 +537,8 @@ func (n *LocalNetwork) RestartNodes(ctx context.Context, nodeIDs []ids.NodeID) { } func (n *LocalNetwork) SetChainConfigs(chainConfigs map[string]string) { - for chainIdStr, chainConfig := range chainConfigs { - if chainIdStr == utils.CChainPathSpecifier { + for chainIDStr, chainConfig := range chainConfigs { + if chainIDStr == utils.CChainPathSpecifier { var cfg tmpnet.FlagsMap err := json.Unmarshal([]byte(chainConfig), &cfg) if err != nil { @@ -554,7 +554,7 @@ func (n *LocalNetwork) SetChainConfigs(chainConfigs map[string]string) { for _, subnet := range n.tmpnet.Subnets { for _, chain := range subnet.Chains { - if chain.ChainID.String() == chainIdStr { + if chain.ChainID.String() == chainIDStr { chain.Config = chainConfig } } diff --git a/tests/utils/utils.go b/tests/utils/utils.go index 3b65edd7d..f8a8d7881 100644 --- a/tests/utils/utils.go +++ b/tests/utils/utils.go @@ -1205,8 +1205,7 @@ func InstantiateGenesisTemplate( scanner := bufio.NewScanner(templateFile) for scanner.Scan() { - var replaced string - replaced = scanner.Text() + replaced := scanner.Text() for _, s := range substitutions { replaced = strings.Replace(replaced, s.Target, s.Value, 1) } From 6f790165bb4257b5fa4eed916e3366f4f87c98e3 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Fri, 12 Jul 2024 15:29:25 +0000 Subject: [PATCH 14/17] setSubnetValues(): accept a Subnet, not a SubnetID addresses review comment https://github.com/ava-labs/teleporter/pull/401#discussion_r1675980090 --- tests/local/network.go | 15 ++++++--------- 1 file changed, 6 insertions(+), 9 deletions(-) diff --git a/tests/local/network.go b/tests/local/network.go index 8d355a4a6..2b0dbbac3 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -149,7 +149,7 @@ func NewLocalNetwork( warpChainConfigPath: warpChainConfigPath, } for _, subnet := range network.Subnets { - res.setSubnetValues(subnet.SubnetID) + res.setSubnetValues(subnet) } res.setPrimaryNetworkValues() return res @@ -198,12 +198,7 @@ func (n *LocalNetwork) setPrimaryNetworkValues() { // TeleporterRegistryAddress is set in DeployTeleporterRegistryContracts } -func (n *LocalNetwork) setSubnetValues(subnetID ids.ID) { - subnet := n.tmpnet.Subnets[slices.IndexFunc( - n.tmpnet.Subnets, - func(s *tmpnet.Subnet) bool { return s.SubnetID == subnetID }, - )] - +func (n *LocalNetwork) setSubnetValues(subnet *tmpnet.Subnet) { blockchainID := subnet.Chains[0].ChainID var chainNodeURIs []string @@ -217,6 +212,8 @@ func (n *LocalNetwork) setSubnetValues(subnetID ids.ID) { chainWSURI := utils.HttpToWebsocketURI(chainNodeURIs[0], blockchainID.String()) chainRPCURI := utils.HttpToRPCURI(chainNodeURIs[0], blockchainID.String()) + subnetID := subnet.SubnetID + if n.subnetsInfo[subnetID] != nil && n.subnetsInfo[subnetID].WSClient != nil { n.subnetsInfo[subnetID].WSClient.Close() } @@ -433,8 +430,8 @@ func (n *LocalNetwork) setAllSubnetValues() { subnetIDs := n.GetSubnetsInfo() Expect(len(subnetIDs)).Should(Equal(2)) - n.setSubnetValues(n.tmpnet.GetSubnet("A").SubnetID) - n.setSubnetValues(n.tmpnet.GetSubnet("B").SubnetID) + n.setSubnetValues(n.tmpnet.GetSubnet("A")) + n.setSubnetValues(n.tmpnet.GetSubnet("B")) n.setPrimaryNetworkValues() } From bc9b1b6963eefde530e41c186684330cadaf51d6 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Fri, 12 Jul 2024 18:20:49 +0000 Subject: [PATCH 15/17] genesis template: ReadFile; close output file addresses review comments https://github.com/ava-labs/teleporter/pull/401#discussion_r1676291801 and https://github.com/ava-labs/teleporter/pull/401#discussion_r1676294251 --- tests/utils/utils.go | 17 +++++++---------- 1 file changed, 7 insertions(+), 10 deletions(-) diff --git a/tests/utils/utils.go b/tests/utils/utils.go index f8a8d7881..4f9927a11 100644 --- a/tests/utils/utils.go +++ b/tests/utils/utils.go @@ -4,7 +4,6 @@ package utils import ( - "bufio" "bytes" "context" "crypto/ecdsa" @@ -1197,21 +1196,19 @@ func InstantiateGenesisTemplate( }, } - templateFile, err := os.Open(templateFileName) + templateFileBytes, err := os.ReadFile(templateFileName) Expect(err).Should(BeNil()) subnetGenesisFile, err := os.CreateTemp(os.TempDir(), "") + defer subnetGenesisFile.Close() Expect(err).Should(BeNil()) - scanner := bufio.NewScanner(templateFile) - for scanner.Scan() { - replaced := scanner.Text() - for _, s := range substitutions { - replaced = strings.Replace(replaced, s.Target, s.Value, 1) - } - - subnetGenesisFile.WriteString(replaced) + var replaced string = string(templateFileBytes[:]) + for _, s := range substitutions { + replaced = strings.Replace(replaced, s.Target, s.Value, 1) } + subnetGenesisFile.WriteString(replaced) + return subnetGenesisFile.Name() } From ddbbfb1ca2af0679ea2730fec2c59c0a1f60a776 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Wed, 17 Jul 2024 16:22:15 +0000 Subject: [PATCH 16/17] adapt to my merged avalanchego changes https://github.com/ava-labs/avalanchego/commit/250daa5c9e99ebc56035afbfbef209d319a37754 --- go.mod | 4 ++-- go.sum | 8 ++++---- tests/local/network.go | 10 ++++++---- 3 files changed, 12 insertions(+), 10 deletions(-) diff --git a/go.mod b/go.mod index ad6a832a7..45bc5ae03 100644 --- a/go.mod +++ b/go.mod @@ -3,7 +3,7 @@ module github.com/ava-labs/teleporter go 1.21.12 require ( - github.com/ava-labs/avalanchego v1.11.9-0.20240703222923-9d71967ccbba + github.com/ava-labs/avalanchego v1.11.10-0.20240713194721-250daa5c9e99 github.com/supranational/blst v0.3.11 // indirect ) @@ -22,7 +22,7 @@ require ( github.com/DataDog/zstd v1.5.2 // indirect github.com/NYTimes/gziphandler v1.1.1 // indirect github.com/VictoriaMetrics/fastcache v1.12.1 // indirect - github.com/ava-labs/coreth v0.13.5-rc.0 // indirect + github.com/ava-labs/coreth v0.13.6-rc.1.0.20240702201359-ba2ce5367874 // indirect github.com/beorn7/perks v1.0.1 // indirect github.com/bits-and-blooms/bitset v1.10.0 // indirect github.com/btcsuite/btcd/btcec/v2 v2.3.2 // indirect diff --git a/go.sum b/go.sum index 0cbf5b639..fc5942558 100644 --- a/go.sum +++ b/go.sum @@ -56,10 +56,10 @@ github.com/ajg/form v1.5.1/go.mod h1:uL1WgH+h2mgNtvBq0339dVnzXdBETtL2LeUXaIv25UY github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156 h1:eMwmnE/GDgah4HI848JfFxHt+iPb26b4zyfspmqY0/8= github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM= github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8= -github.com/ava-labs/avalanchego v1.11.9-0.20240703222923-9d71967ccbba h1:G861YmZfj+m1fSb9TUMojYo7u5pG0jvDL4jHeyLOsG8= -github.com/ava-labs/avalanchego v1.11.9-0.20240703222923-9d71967ccbba/go.mod h1:Nc85yoe/YatXafBLUesyiUrFT3+bpOrd7UFRFBtzn9A= -github.com/ava-labs/coreth v0.13.5-rc.0 h1:PJQbR9o2RrW3j9ba4r1glXnmM2PNAP3xR569+gMcBd0= -github.com/ava-labs/coreth v0.13.5-rc.0/go.mod h1:cm5c12xo5NiTgtbmeduv8i2nYdzgkczz9Wm3yiwwTRU= +github.com/ava-labs/avalanchego v1.11.10-0.20240713194721-250daa5c9e99 h1:xCDwMK05FcilIFXmh05c+eNTstLdduWHrS3kR74z2Oo= +github.com/ava-labs/avalanchego v1.11.10-0.20240713194721-250daa5c9e99/go.mod h1:NlSe4PE40EWD9rBLoNQrEvhABjcOyrV5McUpD3Q6h3Y= +github.com/ava-labs/coreth v0.13.6-rc.1.0.20240702201359-ba2ce5367874 h1:aTDg0jvO07EvUvBYebmLO25bffe1DAaZZPPL0ooGhIA= +github.com/ava-labs/coreth v0.13.6-rc.1.0.20240702201359-ba2ce5367874/go.mod h1:VhNDxZBsqZQQaUTmIkzdyY8UicIsoTDXlRmPaPL9lkA= github.com/ava-labs/subnet-evm v0.6.6 h1:F2s40f2SE2Yt/e97ZA6jMVaqDW+/1PLewcqOiUWDFd0= github.com/ava-labs/subnet-evm v0.6.6/go.mod h1:xq048mtkxCkNPl7Yb0wSkWzXX70aYkPnYQUvfCaBW3U= github.com/aymerick/raymond v2.0.3-0.20180322193309-b565731e1464+incompatible/go.mod h1:osfaiScAUVup+UC9Nfq76eWqDhXlp+4UYaA8uhTBO6g= diff --git a/tests/local/network.go b/tests/local/network.go index 7160c08fe..23640b4ba 100644 --- a/tests/local/network.go +++ b/tests/local/network.go @@ -90,7 +90,7 @@ func NewLocalNetwork( Expect(err).Should(BeNil()) warpChainConfigPath := f.Name() - allNodes := slices.Clone(extraNodes) // to be appended w/ subnet validators + allNodes := extraNodes // to be appended w/ subnet validators var subnets []*tmpnet.Subnet for _, subnetSpec := range subnetSpecs { @@ -561,9 +561,11 @@ func (n *LocalNetwork) SetChainConfigs(chainConfigs map[string]string) { if err != nil { log.Error("failed to write network", "error", err) } - err = n.tmpnet.WriteSubnets() - if err != nil { - log.Error("failed to write subnets", "error", err) + for _, subnet := range n.tmpnet.Subnets { + err := subnet.Write(n.tmpnet.GetSubnetDir(), n.tmpnet.GetChainConfigDir()) + if err != nil { + log.Error("failed to write subnets", "error", err) + } } } From 51c0c0d4f64d5214a6be9a18938a945bc62d6589 Mon Sep 17 00:00:00 2001 From: "F. Eugene Aumson" Date: Thu, 18 Jul 2024 13:57:42 +0000 Subject: [PATCH 17/17] use latest commits of avalanchego & subnet-evm --- go.mod | 6 +++--- go.sum | 12 ++++++------ 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/go.mod b/go.mod index 45bc5ae03..389e3bfb3 100644 --- a/go.mod +++ b/go.mod @@ -3,12 +3,12 @@ module github.com/ava-labs/teleporter go 1.21.12 require ( - github.com/ava-labs/avalanchego v1.11.10-0.20240713194721-250daa5c9e99 + github.com/ava-labs/avalanchego v1.11.10-0.20240718133512-d9ddf0a774e1 github.com/supranational/blst v0.3.11 // indirect ) require ( - github.com/ava-labs/subnet-evm v0.6.6 + github.com/ava-labs/subnet-evm v0.6.8-status-removal.0.20240718135117-a3d13a0c9366 github.com/ethereum/go-ethereum v1.13.8 github.com/onsi/ginkgo/v2 v2.19.0 github.com/onsi/gomega v1.33.1 @@ -22,7 +22,7 @@ require ( github.com/DataDog/zstd v1.5.2 // indirect github.com/NYTimes/gziphandler v1.1.1 // indirect github.com/VictoriaMetrics/fastcache v1.12.1 // indirect - github.com/ava-labs/coreth v0.13.6-rc.1.0.20240702201359-ba2ce5367874 // indirect + github.com/ava-labs/coreth v0.13.6-rc.1.0.20240718130554-0110293d1f4b // indirect github.com/beorn7/perks v1.0.1 // indirect github.com/bits-and-blooms/bitset v1.10.0 // indirect github.com/btcsuite/btcd/btcec/v2 v2.3.2 // indirect diff --git a/go.sum b/go.sum index fc5942558..a0847c2e7 100644 --- a/go.sum +++ b/go.sum @@ -56,12 +56,12 @@ github.com/ajg/form v1.5.1/go.mod h1:uL1WgH+h2mgNtvBq0339dVnzXdBETtL2LeUXaIv25UY github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156 h1:eMwmnE/GDgah4HI848JfFxHt+iPb26b4zyfspmqY0/8= github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM= github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8= -github.com/ava-labs/avalanchego v1.11.10-0.20240713194721-250daa5c9e99 h1:xCDwMK05FcilIFXmh05c+eNTstLdduWHrS3kR74z2Oo= -github.com/ava-labs/avalanchego v1.11.10-0.20240713194721-250daa5c9e99/go.mod h1:NlSe4PE40EWD9rBLoNQrEvhABjcOyrV5McUpD3Q6h3Y= -github.com/ava-labs/coreth v0.13.6-rc.1.0.20240702201359-ba2ce5367874 h1:aTDg0jvO07EvUvBYebmLO25bffe1DAaZZPPL0ooGhIA= -github.com/ava-labs/coreth v0.13.6-rc.1.0.20240702201359-ba2ce5367874/go.mod h1:VhNDxZBsqZQQaUTmIkzdyY8UicIsoTDXlRmPaPL9lkA= -github.com/ava-labs/subnet-evm v0.6.6 h1:F2s40f2SE2Yt/e97ZA6jMVaqDW+/1PLewcqOiUWDFd0= -github.com/ava-labs/subnet-evm v0.6.6/go.mod h1:xq048mtkxCkNPl7Yb0wSkWzXX70aYkPnYQUvfCaBW3U= +github.com/ava-labs/avalanchego v1.11.10-0.20240718133512-d9ddf0a774e1 h1:RhyF0H8Rknz4sdYU3+Y8o6I4xodktqf/YzyfDZWKowg= +github.com/ava-labs/avalanchego v1.11.10-0.20240718133512-d9ddf0a774e1/go.mod h1:a+A78rkfjmTRU5k4BksGcAO8tleeyLEKjXOzBbwwAXU= +github.com/ava-labs/coreth v0.13.6-rc.1.0.20240718130554-0110293d1f4b h1:XUc8KVA76s08ZdN92j2IMlKr3g9OGVPf6FlAxea42wI= +github.com/ava-labs/coreth v0.13.6-rc.1.0.20240718130554-0110293d1f4b/go.mod h1:EXQ/+Uk64XTBdMvgmapzy56dZ8xEkbVSgNMpSLkTKos= +github.com/ava-labs/subnet-evm v0.6.8-status-removal.0.20240718135117-a3d13a0c9366 h1:gT10nA6BW7yOIA0RLMQeVOGP+IBCrqG0J/NnKB9mWS8= +github.com/ava-labs/subnet-evm v0.6.8-status-removal.0.20240718135117-a3d13a0c9366/go.mod h1:Dw/PykU2GR/FPl3Psoi9Pp6HL1qEl8Jm3QcBsBKobBQ= github.com/aymerick/raymond v2.0.3-0.20180322193309-b565731e1464+incompatible/go.mod h1:osfaiScAUVup+UC9Nfq76eWqDhXlp+4UYaA8uhTBO6g= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=