From 5f93ba8bf3fe7bb6c49b252cf9c4fd1f26eddc5c Mon Sep 17 00:00:00 2001 From: Iulian Pascalau Date: Tue, 4 Jun 2024 14:08:14 +0300 Subject: [PATCH 1/5] - integrated new libs --- go.mod | 38 +++++------ go.sum | 76 ++++++++++----------- integrationTests/proxyWithChainSimulator.go | 2 +- 3 files changed, 58 insertions(+), 58 deletions(-) diff --git a/go.mod b/go.mod index b063aecc..e6023fb3 100644 --- a/go.mod +++ b/go.mod @@ -8,13 +8,13 @@ require ( github.com/gin-contrib/cors v1.4.0 github.com/gin-contrib/pprof v1.4.0 github.com/gin-gonic/gin v1.9.1 - github.com/multiversx/mx-chain-communication-go v1.0.13-0.20240126121117-627adccf10ad - github.com/multiversx/mx-chain-core-go v1.2.19-0.20240129082057-a76d0c995cf2 - github.com/multiversx/mx-chain-crypto-go v1.2.10-0.20231206065052-38843c1f1479 - github.com/multiversx/mx-chain-go v1.7.3-0.20240229193314-26883ef1e91b - github.com/multiversx/mx-chain-logger-go v1.0.14-0.20240129144507-d00e967c890c - github.com/multiversx/mx-chain-simulator-go v1.7.2 - github.com/multiversx/mx-sdk-go v1.3.12-0.20240228130921-940b47b0f2be + github.com/multiversx/mx-chain-communication-go v1.0.14 + github.com/multiversx/mx-chain-core-go v1.2.20 + github.com/multiversx/mx-chain-crypto-go v1.2.11 + github.com/multiversx/mx-chain-go v1.7.12 + github.com/multiversx/mx-chain-logger-go v1.0.14 + github.com/multiversx/mx-chain-simulator-go v1.7.12 + github.com/multiversx/mx-sdk-go v1.4.1 github.com/pelletier/go-toml v1.9.3 github.com/stretchr/testify v1.8.4 github.com/urfave/cli v1.22.10 @@ -131,15 +131,15 @@ require ( github.com/multiformats/go-multistream v0.4.1 // indirect github.com/multiformats/go-varint v0.0.7 // indirect github.com/multiversx/concurrent-map v0.1.4 // indirect - github.com/multiversx/mx-chain-es-indexer-go v1.4.19-0.20240129150813-a772c480d33a // indirect - github.com/multiversx/mx-chain-proxy-go v1.1.41 // indirect - github.com/multiversx/mx-chain-scenario-go v1.4.3-0.20240212160120-cc32d1580157 // indirect - github.com/multiversx/mx-chain-storage-go v1.0.15-0.20240130081611-aeea9336e979 // indirect - github.com/multiversx/mx-chain-vm-common-go v1.5.12-0.20240227112124-bfd3f5676e5a // indirect - github.com/multiversx/mx-chain-vm-go v1.5.28-0.20240216071136-6d748b5d6a72 // indirect - github.com/multiversx/mx-chain-vm-v1_2-go v1.2.66-0.20240129145751-f814f5525edb // indirect - github.com/multiversx/mx-chain-vm-v1_3-go v1.3.67-0.20240129150004-536a22d9c618 // indirect - github.com/multiversx/mx-chain-vm-v1_4-go v1.4.96-0.20240216071525-f7d1b8ce8662 // indirect + github.com/multiversx/mx-chain-es-indexer-go v1.4.21 // indirect + github.com/multiversx/mx-chain-proxy-go v1.1.48 // indirect + github.com/multiversx/mx-chain-scenario-go v1.4.3 // indirect + github.com/multiversx/mx-chain-storage-go v1.0.15 // indirect + github.com/multiversx/mx-chain-vm-common-go v1.5.12 // indirect + github.com/multiversx/mx-chain-vm-go v1.5.29 // indirect + github.com/multiversx/mx-chain-vm-v1_2-go v1.2.67 // indirect + github.com/multiversx/mx-chain-vm-v1_3-go v1.3.68 // indirect + github.com/multiversx/mx-chain-vm-v1_4-go v1.4.97 // indirect github.com/multiversx/mx-components-big-int v1.0.0 // indirect github.com/onsi/ginkgo/v2 v2.11.0 // indirect github.com/opencontainers/runtime-spec v1.0.2 // indirect @@ -185,12 +185,12 @@ require ( go.uber.org/multierr v1.11.0 // indirect go.uber.org/zap v1.24.0 // indirect golang.org/x/arch v0.3.0 // indirect - golang.org/x/crypto v0.17.0 // indirect + golang.org/x/crypto v0.21.0 // indirect golang.org/x/exp v0.0.0-20231110203233-9a3e6036ecaa // indirect golang.org/x/mod v0.14.0 // indirect - golang.org/x/net v0.19.0 // indirect + golang.org/x/net v0.21.0 // indirect golang.org/x/sync v0.5.0 // indirect - golang.org/x/sys v0.15.0 // indirect + golang.org/x/sys v0.19.0 // indirect golang.org/x/text v0.14.0 // indirect golang.org/x/tools v0.15.0 // indirect gonum.org/v1/gonum v0.11.0 // indirect diff --git a/go.sum b/go.sum index 8f62ccb3..94911291 100644 --- a/go.sum +++ b/go.sum @@ -443,40 +443,40 @@ github.com/multiformats/go-varint v0.0.7 h1:sWSGR+f/eu5ABZA2ZpYKBILXTTs9JWpdEM/n github.com/multiformats/go-varint v0.0.7/go.mod h1:r8PUYw/fD/SjBCiKOoDlGF6QawOELpZAu9eioSos/OU= github.com/multiversx/concurrent-map v0.1.4 h1:hdnbM8VE4b0KYJaGY5yJS2aNIW9TFFsUYwbO0993uPI= github.com/multiversx/concurrent-map v0.1.4/go.mod h1:8cWFRJDOrWHOTNSqgYCUvwT7c7eFQ4U2vKMOp4A/9+o= -github.com/multiversx/mx-chain-communication-go v1.0.13-0.20240126121117-627adccf10ad h1:izxTyKCxvT7z2mhXCWAZibSxwRVgLmq/kDovs4Nx/6Y= -github.com/multiversx/mx-chain-communication-go v1.0.13-0.20240126121117-627adccf10ad/go.mod h1:n4E8BWIV0g3AcNGe1gf+vcjUC8A2QCJ4ARQSbiUDGrI= -github.com/multiversx/mx-chain-core-go v1.2.19-0.20240129082057-a76d0c995cf2 h1:pFh9bwOTRgW173aHqA8Bmax+jYzLnRyXqRvi5alF7V4= -github.com/multiversx/mx-chain-core-go v1.2.19-0.20240129082057-a76d0c995cf2/go.mod h1:B5zU4MFyJezmEzCsAHE9YNULmGCm2zbPHvl9hazNxmE= -github.com/multiversx/mx-chain-crypto-go v1.2.10-0.20231206065052-38843c1f1479 h1:beVIhs5ysylwNplQ/bZ0h5DoDlqKNWgpWE/NMHHNmAw= -github.com/multiversx/mx-chain-crypto-go v1.2.10-0.20231206065052-38843c1f1479/go.mod h1:Ap6p7QZFtwPlb++OvCG+85BfuZ+bLP/JtQp6EwjWJsI= -github.com/multiversx/mx-chain-es-indexer-go v1.4.19-0.20240129150813-a772c480d33a h1:mOMUhbsjTq7n5oAv4KkVnL67ngS0+wkqmkiv1XJfBIY= -github.com/multiversx/mx-chain-es-indexer-go v1.4.19-0.20240129150813-a772c480d33a/go.mod h1:3aSGRJNvfUuPQkZUGHWuF11rPPxphsKGuAuIB+eD3is= -github.com/multiversx/mx-chain-go v1.7.3-0.20240229193314-26883ef1e91b h1:sjDMICjTLQjPgeq8Vmz09hUOzdlOY+2adp5H7T5iZyk= -github.com/multiversx/mx-chain-go v1.7.3-0.20240229193314-26883ef1e91b/go.mod h1:woPMicov03+VrH2iPJ+oJXj4Kvj64kLgWg/5Z90qV8M= -github.com/multiversx/mx-chain-logger-go v1.0.14-0.20240129144507-d00e967c890c h1:QIUOn8FgNRa5cir4BCWHZi/Qcr6Gg0eGNhns4+jy6+k= -github.com/multiversx/mx-chain-logger-go v1.0.14-0.20240129144507-d00e967c890c/go.mod h1:fH/fR/GEBsDjPkBoZDVJMoYo2HhlA7++DP6QfITJ1N8= -github.com/multiversx/mx-chain-proxy-go v1.1.41 h1:u5LTek2keNvd25jrOmHLp0N4AFwYFImBnrs+GR7IGRY= -github.com/multiversx/mx-chain-proxy-go v1.1.41/go.mod h1:El07IztR9QuhbNPZkd2ew2H8KS2bUqG7/0eQ28BPPsY= -github.com/multiversx/mx-chain-scenario-go v1.4.3-0.20240212160120-cc32d1580157 h1:ydzN3f+Y7H0InXuxAcNUSyVc+omNYL8uYtLqVzqaaX4= -github.com/multiversx/mx-chain-scenario-go v1.4.3-0.20240212160120-cc32d1580157/go.mod h1:ndk45i9J9McuCJpTcgiaK4ocd0yhnBBCPrlFwO6GRcs= -github.com/multiversx/mx-chain-simulator-go v1.7.2 h1:j9OzconmlO5TUeBwB03WAnAa5hDOWQ5AthR81wLlxkM= -github.com/multiversx/mx-chain-simulator-go v1.7.2/go.mod h1:nwmIqpll6x+ivi9wgTyzyBYSg3wL0KyWUpKTnzGbTjU= -github.com/multiversx/mx-chain-storage-go v1.0.15-0.20240130081611-aeea9336e979 h1:HDNz4NZum1GCj7F91hO2lEx8Dv/Fm2L93F5wZJkgLLg= -github.com/multiversx/mx-chain-storage-go v1.0.15-0.20240130081611-aeea9336e979/go.mod h1:zl1A6teNe39T8yhdZlkX3ckm5aLYrMIJJZ6Ord1E71M= -github.com/multiversx/mx-chain-vm-common-go v1.5.12-0.20240227112124-bfd3f5676e5a h1:4Dlk5Hcxlt6az5qqJfklgSlAKEYiFLv+xkFavQJgSNY= -github.com/multiversx/mx-chain-vm-common-go v1.5.12-0.20240227112124-bfd3f5676e5a/go.mod h1:OUyhCFqZKqUk1uaPsenyPDwO1830SlHNDU7Q7b6CBVI= -github.com/multiversx/mx-chain-vm-go v1.5.28-0.20240216071136-6d748b5d6a72 h1:NMHNT4NcqOdnHttYsT3ydZHVapwOctp6t+WDGDy0UEQ= -github.com/multiversx/mx-chain-vm-go v1.5.28-0.20240216071136-6d748b5d6a72/go.mod h1:YCD2Q+kpzx86ydowe/BKw/ZdzYjfH/4IxWHS0NsyuD0= -github.com/multiversx/mx-chain-vm-v1_2-go v1.2.66-0.20240129145751-f814f5525edb h1:UtiY8X73llF9OLtGb2CM7Xewae1chvPjLc8B+ZmDLjw= -github.com/multiversx/mx-chain-vm-v1_2-go v1.2.66-0.20240129145751-f814f5525edb/go.mod h1:8uugq3HUeDiE6G4AS3F8/B3zA1Pabzbl7SSD6Cebwz8= -github.com/multiversx/mx-chain-vm-v1_3-go v1.3.67-0.20240129150004-536a22d9c618 h1:1uMlT5TjiHUlx81fEH/WQANWlY0PjF3opMlW+E3L3GI= -github.com/multiversx/mx-chain-vm-v1_3-go v1.3.67-0.20240129150004-536a22d9c618/go.mod h1:4uezxguZiX42kUaYMK/x46LLbgpYqn/iQXbcGM7zdM0= -github.com/multiversx/mx-chain-vm-v1_4-go v1.4.96-0.20240216071525-f7d1b8ce8662 h1:0y1k2+FjFfWgoPCMi0nkYkCYQJtPYJvph6bre4Elqxk= -github.com/multiversx/mx-chain-vm-v1_4-go v1.4.96-0.20240216071525-f7d1b8ce8662/go.mod h1:Nvanb5BZVhqnFFlWUtn7PQ/GIsl72zPVcMEw/ZvYiQA= +github.com/multiversx/mx-chain-communication-go v1.0.14 h1:YhAUDjBBpc5h5W0A7LHLXUMIMeCgwgGvkqfAPbFqsno= +github.com/multiversx/mx-chain-communication-go v1.0.14/go.mod h1:qYCqgk0h+YpcTA84jHIpCBy6UShRwmXzHSCcdfwNrkw= +github.com/multiversx/mx-chain-core-go v1.2.20 h1:jOQ10LxxUqECnuqUYeBBT6VoZcpJDdYgOvsSGtifDdI= +github.com/multiversx/mx-chain-core-go v1.2.20/go.mod h1:B5zU4MFyJezmEzCsAHE9YNULmGCm2zbPHvl9hazNxmE= +github.com/multiversx/mx-chain-crypto-go v1.2.11 h1:MNPJoiTJA5/tedYrI0N22OorbsKDESWG0SF8MCJwcJI= +github.com/multiversx/mx-chain-crypto-go v1.2.11/go.mod h1:pcZutPdfLiAFytzCU3LxU3s8cXkvpNqquyitFSfoF3o= +github.com/multiversx/mx-chain-es-indexer-go v1.4.21 h1:rzxXCkgOsqj67GRYtqzKuf9XgHwnZLTZhU90Ck3VbrE= +github.com/multiversx/mx-chain-es-indexer-go v1.4.21/go.mod h1:V9xxOBkfV7GjN4K5SODaOetoGVpQm4snibMVPCjL0Kk= +github.com/multiversx/mx-chain-go v1.7.12 h1:cQ3g5sFZEcQmIRwi/wt+K/3d5nIwCMQRC1ZnJDRuRY4= +github.com/multiversx/mx-chain-go v1.7.12/go.mod h1:HwklJGQfMpv/yyF4oLpxjwdKCawspv1JjdgezlWBpRQ= +github.com/multiversx/mx-chain-logger-go v1.0.14 h1:PRMpAvXE7Nec2d//QNmbYfKVHMomOKmcN4UXurQWX9o= +github.com/multiversx/mx-chain-logger-go v1.0.14/go.mod h1:bDfHSdwqIimn7Gp8w+SH5KlDuGzJ//nlyEANAaTSc3o= +github.com/multiversx/mx-chain-proxy-go v1.1.48 h1:gmunv+2oimIN8ejlVAN7eWP7mt38So1WvsyiR3+94SU= +github.com/multiversx/mx-chain-proxy-go v1.1.48/go.mod h1:Ax+80b1qynepkZSxrz8QB3AO00JAL3svaLasMTE6Lh0= +github.com/multiversx/mx-chain-scenario-go v1.4.3 h1:9xeVB8TOsolXS4YEr1CZ/VZr5Qk0X+nde8nRGnxJICo= +github.com/multiversx/mx-chain-scenario-go v1.4.3/go.mod h1:Bd7/Xs3mWM6pX/REHK5dfpf3MUfjMZ7li09cfCxg2ac= +github.com/multiversx/mx-chain-simulator-go v1.7.12 h1:TG44bozDboOeAu46kQyd7yXoA3IblHWTCsvv0DEQCL0= +github.com/multiversx/mx-chain-simulator-go v1.7.12/go.mod h1:7nFlDdm0uohZBKrw0YnH3N0iZB9GT+ynY40nqIIkSDA= +github.com/multiversx/mx-chain-storage-go v1.0.15 h1:PDyP1uouAVjR32dFgM+7iaQBdReD/tKBJj10JbxXvaE= +github.com/multiversx/mx-chain-storage-go v1.0.15/go.mod h1:GZUK3sqf5onsWS/0ZPWjDCBjAL22FigQPUh252PAVk0= +github.com/multiversx/mx-chain-vm-common-go v1.5.12 h1:Q8F6DE7XhgHtWgg2rozSv4Tv5fE3ENkJz6mjRoAfht8= +github.com/multiversx/mx-chain-vm-common-go v1.5.12/go.mod h1:Sv6iS1okB6gy3HAsW6KHYtAxShNAfepKLtu//AURI8c= +github.com/multiversx/mx-chain-vm-go v1.5.29 h1:Ovz5/WM9KbD3YKRafdKI4RwtsNN36AGeNw81LZAhE70= +github.com/multiversx/mx-chain-vm-go v1.5.29/go.mod h1:n0SbVEAhIflreAGi7BnfWg4p4VHh4G8ArbvYQZsZsKQ= +github.com/multiversx/mx-chain-vm-v1_2-go v1.2.67 h1:W0bwj5zXM2JEeOEqfKTZE1ecuSJwTuRZZrl9oircRc0= +github.com/multiversx/mx-chain-vm-v1_2-go v1.2.67/go.mod h1:lrDQWpv1yZHlX6ZgWJsTMxxOkeoVTKLQsl1+mr50Z24= +github.com/multiversx/mx-chain-vm-v1_3-go v1.3.68 h1:px2YHay6BSVheLxb3gdZQX0enlqKzu6frngWEZRtr6g= +github.com/multiversx/mx-chain-vm-v1_3-go v1.3.68/go.mod h1:sIXRCenIR6FJtr3X/gDc60N6+v99Ai4hDsn6R5TKGnk= +github.com/multiversx/mx-chain-vm-v1_4-go v1.4.97 h1:fbYYqollxbIArcrC161Z9Qh5yJGW0Ax60m83Gz8+H1w= +github.com/multiversx/mx-chain-vm-v1_4-go v1.4.97/go.mod h1:56WJQio8SzOt3vWibaNkuGpqLlmTOGUSJqs3wMK69zw= github.com/multiversx/mx-components-big-int v1.0.0 h1:Wkr8lSzK2nDqixOrrBa47VNuqdhV1m/aJhaP1EMaiS8= github.com/multiversx/mx-components-big-int v1.0.0/go.mod h1:maIEMgHlNE2u78JaDD0oLzri+ShgU4okHfzP3LWGdQM= -github.com/multiversx/mx-sdk-go v1.3.12-0.20240228130921-940b47b0f2be h1:zXFDP5oB+LKRESSDVF55SZeeAS5k6e9EUmXmBR7iUXQ= -github.com/multiversx/mx-sdk-go v1.3.12-0.20240228130921-940b47b0f2be/go.mod h1:AY65e3QDbdjJ5BzZ6OE0YvMze6x9JOXUeXMh04mdQiI= +github.com/multiversx/mx-sdk-go v1.4.1 h1:/zk7LDmnl1ovkmjkDejLRUtbjO7kmVQw8AlAyGNITBU= +github.com/multiversx/mx-sdk-go v1.4.1/go.mod h1:2kTQLFck47wtHpzdWrM3mrLlTypE5zn39JCbzN16cxs= github.com/neelance/astrewrite v0.0.0-20160511093645-99348263ae86/go.mod h1:kHJEU3ofeGjhHklVoIGuVj85JJwZ6kWPaJwCIxgnFmo= github.com/neelance/sourcemap v0.0.0-20151028013722-8c68805598ab/go.mod h1:Qr6/a/Q4r9LP1IltGz7tA7iOK1WonHEYhu1HRBA7ZiM= github.com/nxadm/tail v1.4.4/go.mod h1:kenIhsEOeOJmVchQTgglprH7qJGnHDVpk1VPCcaMI8A= @@ -703,8 +703,8 @@ golang.org/x/crypto v0.0.0-20210322153248-0c34fe9e7dc2/go.mod h1:T9bdIzuCu7OtxOm golang.org/x/crypto v0.0.0-20210711020723-a769d52b0f97/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.10.0/go.mod h1:o4eNf7Ede1fv+hwOwZsTHl9EsPFO6q6ZvYR8vYfY45I= -golang.org/x/crypto v0.17.0 h1:r8bRNjWL3GshPW3gkd+RpvzWrZAwPS49OmTGZ/uhM4k= -golang.org/x/crypto v0.17.0/go.mod h1:gCAAfMLgwOJRpTjQ2zCCt2OcSfYMTeZVSRtQlPC7Nq4= +golang.org/x/crypto v0.21.0 h1:X31++rzVUdKhX5sWmSOFZxx8UW/ldWx55cbf08iNAMA= +golang.org/x/crypto v0.21.0/go.mod h1:0BP7YvVV9gBbVKyeTG0Gyn+gZm94bibOW5BjDEYAOMs= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20231110203233-9a3e6036ecaa h1:FRnLl4eNAQl8hwxVVC17teOw8kdjVDVAiFMtgUdTSRQ= golang.org/x/exp v0.0.0-20231110203233-9a3e6036ecaa/go.mod h1:zk2irFbV9DP96SEBUUAy67IdHUaZuSnrz1n472HUCLE= @@ -750,8 +750,8 @@ golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= golang.org/x/net v0.11.0/go.mod h1:2L/ixqYpgIVXmeoSA/4Lu7BzTG4KIyPIryS4IsOd1oQ= -golang.org/x/net v0.19.0 h1:zTwKpTd2XuCqf8huc7Fo2iSy+4RHPd10s4KzeTnVr1c= -golang.org/x/net v0.19.0/go.mod h1:CfAk/cbD4CthTvqiEl8NpboMuiuOYsAr/7NOjZJtv1U= +golang.org/x/net v0.21.0 h1:AQyQV4dYCvJ7vGmJyKki9+PBdyvhkSd8EIx/qb0AYv4= +golang.org/x/net v0.21.0/go.mod h1:bIjVDfnllIU7BJ2DNgfnXvpSvtn8VRwhlsaeUTyUS44= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20181017192945-9dcd33a902f4/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20181203162652-d668ce993890/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= @@ -810,8 +810,8 @@ golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.9.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.10.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.15.0 h1:h48lPFYpsTvQJZF4EKyI4aLHaev3CxivZmv7yZig9pc= -golang.org/x/sys v0.15.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.19.0 h1:q5f1RH2jigJ1MoAWp2KTp3gm5zAGFUTarQZ5U386+4o= +golang.org/x/sys v0.19.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= diff --git a/integrationTests/proxyWithChainSimulator.go b/integrationTests/proxyWithChainSimulator.go index cce2bc47..abfd577e 100644 --- a/integrationTests/proxyWithChainSimulator.go +++ b/integrationTests/proxyWithChainSimulator.go @@ -114,7 +114,7 @@ func CreateProxyWithChainSimulator(args ArgProxyWithChainSimulator) (*proxyWithC PathToProxyConfig: args.ProxyConfigs, ServerPort: args.ServerPort, RestApiInterfaces: restApiInterfaces, - InitialWallets: simulator.GetInitialWalletKeys().ShardWallets, + InitialWallets: simulator.GetInitialWalletKeys().BalanceWallets, }) if err != nil { return nil, err From 49b41a23af2c62e7484d2f64efbd012f1e8dda06 Mon Sep 17 00:00:00 2001 From: Iulian Pascalau Date: Wed, 5 Jun 2024 10:37:56 +0300 Subject: [PATCH 2/5] - integrated new chain simulator through docker image - adapted chain simulator test to run without delays - added slow-tests workflow file --- .github/workflows/slow-tests.yml | 27 + Makefile | 5 + docker/docker-compose.yml | 11 + integrationTests/chainSimulatorWrapper.go | 335 +++++++ integrationTests/interface.go | 12 +- integrationTests/proxyWithChainSimulator.go | 387 ------- integrationTests/relayers/common.go | 64 ++ .../ethToMultiversXWithChainSimulator_test.go | 315 +++--- .../relayers/ethToMultiversX_test.go | 57 +- .../relayers/multiversXToEth_test.go | 11 +- .../testdata/config/nodeConfig/api.toml | 309 ------ .../testdata/config/nodeConfig/config.toml | 942 ------------------ .../testdata/config/nodeConfig/economics.toml | 50 - .../config/nodeConfig/enableEpochs.toml | 312 ------ .../config/nodeConfig/enableRounds.toml | 13 - .../testdata/config/nodeConfig/external.toml | 77 -- .../config/nodeConfig/fullArchiveP2P.toml | 87 -- .../gasSchedules/gasScheduleV1.toml | 827 --------------- .../gasSchedules/gasScheduleV2.toml | 827 --------------- .../gasSchedules/gasScheduleV3.toml | 827 --------------- .../gasSchedules/gasScheduleV4.toml | 827 --------------- .../gasSchedules/gasScheduleV5.toml | 827 --------------- .../gasSchedules/gasScheduleV6.toml | 827 --------------- .../gasSchedules/gasScheduleV7.toml | 828 --------------- .../testdata/config/nodeConfig/genesis.json | 497 --------- .../genesisContracts/delegation.wasm | Bin 57293 -> 0 bytes .../nodeConfig/genesisContracts/dns.wasm | Bin 9740 -> 0 bytes .../nodeConfig/genesisSmartContracts.json | 18 - .../config/nodeConfig/nodesSetup.json | 395 -------- .../testdata/config/nodeConfig/p2p.toml | 87 -- .../testdata/config/nodeConfig/prefs.toml | 82 -- .../testdata/config/nodeConfig/ratings.toml | 53 - .../systemSmartContractsConfig.toml | 41 - .../proxyConfig/apiConfig/credentials.toml | 11 - .../config/proxyConfig/apiConfig/v1_0.toml | 146 --- .../config/proxyConfig/apiConfig/v_next.toml | 146 --- .../testdata/config/proxyConfig/config.toml | 79 -- .../testdata/config/proxyConfig/external.toml | 4 - .../relayers/testdata/wallets/mvxReceiver.pem | 6 - .../relayers/testdata/wallets/owner.pem | 5 - 40 files changed, 615 insertions(+), 9759 deletions(-) create mode 100644 .github/workflows/slow-tests.yml create mode 100644 docker/docker-compose.yml create mode 100644 integrationTests/chainSimulatorWrapper.go delete mode 100644 integrationTests/proxyWithChainSimulator.go delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/api.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/config.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/economics.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/enableEpochs.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/enableRounds.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/external.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/fullArchiveP2P.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV1.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV2.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV3.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV4.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV5.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV6.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV7.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/genesis.json delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/genesisContracts/delegation.wasm delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/genesisContracts/dns.wasm delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/genesisSmartContracts.json delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/nodesSetup.json delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/p2p.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/prefs.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/ratings.toml delete mode 100644 integrationTests/relayers/testdata/config/nodeConfig/systemSmartContractsConfig.toml delete mode 100644 integrationTests/relayers/testdata/config/proxyConfig/apiConfig/credentials.toml delete mode 100644 integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v1_0.toml delete mode 100644 integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v_next.toml delete mode 100644 integrationTests/relayers/testdata/config/proxyConfig/config.toml delete mode 100644 integrationTests/relayers/testdata/config/proxyConfig/external.toml delete mode 100644 integrationTests/relayers/testdata/wallets/mvxReceiver.pem delete mode 100644 integrationTests/relayers/testdata/wallets/owner.pem diff --git a/.github/workflows/slow-tests.yml b/.github/workflows/slow-tests.yml new file mode 100644 index 00000000..c21ad938 --- /dev/null +++ b/.github/workflows/slow-tests.yml @@ -0,0 +1,27 @@ +name: Tests + +on: + push: + branches: [ main, feat/* ] + pull_request: + branches: [ main, feat/* ] + +jobs: + test: + name: Unit + runs-on: ubuntu-latest + steps: + - name: Set up Go 1.x + uses: actions/setup-go@v3 + with: + go-version: 1.20.7 + id: go + + - name: Check out code + uses: actions/checkout@v3 + + - name: Get dependencies + run: | + go get -v -t -d ./... + - name: Slow tests + run: make slow-tests diff --git a/Makefile b/Makefile index c0c94861..34a3c4e4 100644 --- a/Makefile +++ b/Makefile @@ -17,6 +17,11 @@ test-coverage: @echo "Running unit tests" CURRENT_DIRECTORY=$(CURRENT_DIRECTORY) go test -cover -coverprofile=coverage.txt -covermode=atomic -v ${TESTS_TO_RUN} +slow-tests: clean-test + @docker compose -f docker/docker-compose.yml build + @docker compose -f docker/docker-compose.yml up & go test ./integrationTests/... -v -tags slow + @docker compose -f docker/docker-compose.yml down -v + lint-install: ifeq (,$(wildcard test -f bin/golangci-lint)) @echo "Installing golint" diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml new file mode 100644 index 00000000..0f03f76b --- /dev/null +++ b/docker/docker-compose.yml @@ -0,0 +1,11 @@ +version: "3.9" + +services: + multiversx: + image: multiversx/chainsimulator:v1.7.12-fix1 + restart: unless-stopped + ports: + - 8085:8085 + volumes: + - "../scripts:/docker/scripts" + entrypoint: "./chainsimulator" \ No newline at end of file diff --git a/integrationTests/chainSimulatorWrapper.go b/integrationTests/chainSimulatorWrapper.go new file mode 100644 index 00000000..5dd42bbe --- /dev/null +++ b/integrationTests/chainSimulatorWrapper.go @@ -0,0 +1,335 @@ +package integrationTests + +import ( + "context" + "encoding/hex" + "encoding/json" + "fmt" + "net/http" + "strings" + "time" + + "github.com/multiversx/mx-bridge-eth-go/clients/multiversx" + "github.com/multiversx/mx-chain-core-go/core" + "github.com/multiversx/mx-chain-core-go/core/pubkeyConverter" + apiCore "github.com/multiversx/mx-chain-core-go/data/api" + "github.com/multiversx/mx-chain-core-go/data/transaction" + "github.com/multiversx/mx-chain-crypto-go/signing" + "github.com/multiversx/mx-chain-crypto-go/signing/ed25519" + "github.com/multiversx/mx-chain-crypto-go/signing/ed25519/singlesig" + "github.com/multiversx/mx-chain-go/integrationTests/vm/wasm" + "github.com/multiversx/mx-chain-go/node/chainSimulator/dtos" + logger "github.com/multiversx/mx-chain-logger-go" + "github.com/multiversx/mx-sdk-go/blockchain" + sdkCore "github.com/multiversx/mx-sdk-go/core" + sdkHttp "github.com/multiversx/mx-sdk-go/core/http" + "github.com/multiversx/mx-sdk-go/data" +) + +var log = logger.GetOrCreate("testscommon/chainsimulator") + +const ( + proxyURL = "http://127.0.0.1:8085" + thousandEgld = "1000000000000000000000" + maxAllowedTimeout = time.Second + setMultipleEndpoint = "simulator/set-state-overwrite" + generateBlocksEndpoint = "simulator/generate-blocks/%d" + generateBlocksUntilEpochReachedEndpoint = "simulator/generate-blocks-until-epoch-reached/%d" + numProbeRetries = 10 +) + +// ArgChainSimulatorWrapper is the DTO used to create a new instance of proxy that relies on a chain simulator +type ArgChainSimulatorWrapper struct { + ProxyCacherExpirationSeconds uint64 + ProxyMaxNoncesDelta int +} + +type chainSimulatorWrapper struct { + clientWrapper httpClientWrapper + proxyInstance multiversx.Proxy + pkConv core.PubkeyConverter +} + +// CreateChainSimulatorWrapper creates a new instance of the chain simulator wrapper +func CreateChainSimulatorWrapper(args ArgChainSimulatorWrapper) (*chainSimulatorWrapper, error) { + argsProxy := blockchain.ArgsProxy{ + ProxyURL: proxyURL, + SameScState: false, + ShouldBeSynced: false, + FinalityCheck: false, + AllowedDeltaToFinal: args.ProxyMaxNoncesDelta, + CacheExpirationTime: time.Second * time.Duration(args.ProxyCacherExpirationSeconds), + EntityType: sdkCore.Proxy, + } + proxyInstance, err := blockchain.NewProxy(argsProxy) + if err != nil { + return nil, err + } + + pubKeyConverter, err := pubkeyConverter.NewBech32PubkeyConverter(32, "erd") + if err != nil { + return nil, err + } + + instance := &chainSimulatorWrapper{ + clientWrapper: sdkHttp.NewHttpClientWrapper(nil, proxyURL), + proxyInstance: proxyInstance, + pkConv: pubKeyConverter, + } + + err = instance.probeURLWithRetries() + if err != nil { + return nil, err + } + + return instance, nil +} + +func (instance *chainSimulatorWrapper) probeURLWithRetries() error { + // at this point we should be able to get the network configs + + var err error + for i := 0; i < numProbeRetries; i++ { + log.Info("trying to probe the chain simulator", "url", proxyURL, "try", i) + + ctx, done := context.WithTimeout(context.Background(), maxAllowedTimeout) + _, err = instance.proxyInstance.GetNetworkConfig(ctx) + done() + + if err == nil { + log.Info("probe ok, chain simulator instance found", "url", proxyURL) + return nil + } + + time.Sleep(maxAllowedTimeout) + } + + return fmt.Errorf("%w while probing the network config. Please ensure that a chain simulator is running on %s", err, proxyURL) +} + +// Proxy returns the managed proxy instance +func (instance *chainSimulatorWrapper) Proxy() multiversx.Proxy { + return instance.proxyInstance +} + +// GetNetworkAddress returns the network address +func (instance *chainSimulatorWrapper) GetNetworkAddress() string { + return proxyURL +} + +// DeploySC will deploy the provided smart contract and return its address +func (instance *chainSimulatorWrapper) DeploySC(ctx context.Context, wasmFilePath string, ownerPK string, ownerSK []byte, parameters []string) (string, error) { + networkConfig, err := instance.proxyInstance.GetNetworkConfig(ctx) + if err != nil { + return "", err + } + + nonce, err := instance.getNonce(ctx, ownerPK) + if err != nil { + return "", err + } + + emptyAddress, err := instance.pkConv.Encode(make([]byte, 32)) + if err != nil { + return "", err + } + + scCode := wasm.GetSCCode(wasmFilePath) + params := []string{scCode, wasm.VMTypeHex, wasm.DummyCodeMetadataHex} + params = append(params, parameters...) + txData := strings.Join(params, "@") + + ftx := &transaction.FrontendTransaction{ + Nonce: nonce, + Value: "0", + Receiver: emptyAddress, + Sender: ownerPK, + GasPrice: networkConfig.MinGasPrice, + GasLimit: 600000000, + Data: []byte(txData), + ChainID: networkConfig.ChainID, + Version: 1, + } + + hash, err := instance.signAndSend(ctx, ownerSK, ftx) + if err != nil { + return "", err + } + + log.Info("contract deployed", "hash", hash) + + txResult, errGet := instance.GetTransactionResult(ctx, hash) + if errGet != nil { + return "", errGet + } + + return txResult.Logs.Events[0].Address, nil +} + +// GetTransactionResult tries to get a transaction result. It may wait a few blocks +func (instance *chainSimulatorWrapper) GetTransactionResult(ctx context.Context, hash string) (*data.TransactionOnNetwork, error) { + instance.GenerateBlocks(ctx, 10) + + return instance.getTxInfoWithResultsIfTxProcessingFinished(ctx, hash) +} + +// GenerateBlocks calls the chain simulator generate block endpoint +func (instance *chainSimulatorWrapper) GenerateBlocks(ctx context.Context, numBlocks int) { + _, status, err := instance.clientWrapper.PostHTTP(ctx, fmt.Sprintf(generateBlocksEndpoint, numBlocks), nil) + if err != nil || status != http.StatusOK { + log.Error("error in chainSimulatorWrapper.GenerateBlocks", "error", err, "status", status) + return + } +} + +// GenerateBlocksUntilEpochReached will generate blocks until the provided epoch is reached +func (instance *chainSimulatorWrapper) GenerateBlocksUntilEpochReached(ctx context.Context, epoch uint32) { + _, status, err := instance.clientWrapper.PostHTTP(ctx, fmt.Sprintf(generateBlocksUntilEpochReachedEndpoint, epoch), nil) + if err != nil || status != http.StatusOK { + log.Error("error in chainSimulatorWrapper.GenerateBlocksUntilEpochReached", "error", err, "status", status) + return + } +} + +func (instance *chainSimulatorWrapper) getTxInfoWithResultsIfTxProcessingFinished(ctx context.Context, hash string) (*data.TransactionOnNetwork, error) { + txStatus, err := instance.proxyInstance.ProcessTransactionStatus(ctx, hash) + if err != nil { + return nil, err + } + + if txStatus == transaction.TxStatusPending { + return nil, nil + } + + if txStatus != transaction.TxStatusSuccess { + log.Warn("something went wrong with the transaction", "hash", hash, "status", txStatus) + } + + txResult, errGet := instance.proxyInstance.GetTransactionInfoWithResults(ctx, hash) + if errGet != nil { + return nil, err + } + + return &txResult.Data.Transaction, nil + +} + +// ScCall will make the provided sc call +func (instance *chainSimulatorWrapper) ScCall(ctx context.Context, senderPK string, senderSK []byte, contract string, value string, function string, parameters []string) (string, error) { + params := []string{function} + params = append(params, parameters...) + txData := strings.Join(params, "@") + + return instance.SendTx(ctx, senderPK, senderSK, contract, value, []byte(txData)) +} + +// SendTx will build and send a transaction +func (instance *chainSimulatorWrapper) SendTx(ctx context.Context, senderPK string, senderSK []byte, receiver string, value string, dataField []byte) (string, error) { + networkConfig, err := instance.proxyInstance.GetNetworkConfig(ctx) + if err != nil { + return "", err + } + + nonce, err := instance.getNonce(ctx, senderPK) + if err != nil { + return "", err + } + + ftx := &transaction.FrontendTransaction{ + Nonce: nonce, + Value: value, + Receiver: receiver, + Sender: senderPK, + GasPrice: networkConfig.MinGasPrice, + GasLimit: 600000000, + Data: dataField, + ChainID: networkConfig.ChainID, + Version: 1, + } + + return instance.signAndSend(ctx, senderSK, ftx) +} + +// FundWallets sends funds to the provided addresses +func (instance *chainSimulatorWrapper) FundWallets(ctx context.Context, wallets []string) { + addressesState := make([]*dtos.AddressState, 0, len(wallets)) + for _, wallet := range wallets { + addressesState = append(addressesState, &dtos.AddressState{ + Address: wallet, + Nonce: new(uint64), + Balance: thousandEgld, + }) + } + + buff, err := json.Marshal(addressesState) + if err != nil { + log.Error("error in chainSimulatorWrapper.FundWallets", "error", err) + return + } + + _, status, err := instance.clientWrapper.PostHTTP(ctx, setMultipleEndpoint, buff) + if err != nil || status != http.StatusOK { + log.Error("error in chainSimulatorWrapper.FundWallets - PostHTTP", "error", err, "status", status) + return + } +} + +// GetESDTBalance returns the balance of the esdt token for the provided address +func (instance *chainSimulatorWrapper) GetESDTBalance(ctx context.Context, address sdkCore.AddressHandler, token string) (string, error) { + tokenData, err := instance.proxyInstance.GetESDTTokenData(ctx, address, token, apiCore.AccountQueryOptions{ + OnFinalBlock: true, + }) + if err != nil { + return "", err + } + + return tokenData.Balance, nil +} + +func (instance *chainSimulatorWrapper) getNonce(ctx context.Context, bech32Address string) (uint64, error) { + address, err := data.NewAddressFromBech32String(bech32Address) + if err != nil { + return 0, err + } + + account, err := instance.proxyInstance.GetAccount(ctx, address) + if err != nil { + return 0, err + } + + return account.Nonce, nil +} + +func (instance *chainSimulatorWrapper) signAndSend(ctx context.Context, senderSK []byte, ftx *transaction.FrontendTransaction) (string, error) { + sig, err := computeTransactionSignature(senderSK, ftx) + if err != nil { + return "", err + } + ftx.Signature = hex.EncodeToString(sig) + + hash, err := instance.proxyInstance.SendTransaction(ctx, ftx) + if err != nil { + return "", err + } + + instance.GenerateBlocks(ctx, 1) + + return hash, nil +} + +func computeTransactionSignature(senderSk []byte, tx *transaction.FrontendTransaction) ([]byte, error) { + signer := &singlesig.Ed25519Signer{} + keyGenerator := signing.NewKeyGenerator(ed25519.NewEd25519()) + + privateKey, err := keyGenerator.PrivateKeyFromByteArray(senderSk) + if err != nil { + return nil, err + } + + dataToSign, err := json.Marshal(tx) + if err != nil { + return nil, err + } + + return signer.Sign(privateKey, dataToSign) +} diff --git a/integrationTests/interface.go b/integrationTests/interface.go index 2d0727ba..9f14d5b6 100644 --- a/integrationTests/interface.go +++ b/integrationTests/interface.go @@ -1,13 +1,9 @@ package integrationTests -import ( - "github.com/multiversx/mx-chain-go/node/chainSimulator/dtos" - "github.com/multiversx/mx-chain-go/node/chainSimulator/process" -) +import "context" -// chainSimulatorHandler defines what a chain simulator should be able to do -type chainSimulatorHandler interface { - GetNodeHandler(shardID uint32) process.NodeHandler - SetStateMultiple(stateSlice []*dtos.AddressState) error +type httpClientWrapper interface { + GetHTTP(ctx context.Context, endpoint string) ([]byte, int, error) + PostHTTP(ctx context.Context, endpoint string, data []byte) ([]byte, int, error) IsInterfaceNil() bool } diff --git a/integrationTests/proxyWithChainSimulator.go b/integrationTests/proxyWithChainSimulator.go deleted file mode 100644 index abfd577e..00000000 --- a/integrationTests/proxyWithChainSimulator.go +++ /dev/null @@ -1,387 +0,0 @@ -package integrationTests - -import ( - "context" - "encoding/hex" - "encoding/json" - "errors" - "strings" - "time" - - "github.com/multiversx/mx-bridge-eth-go/clients/multiversx" - "github.com/multiversx/mx-chain-core-go/core" - "github.com/multiversx/mx-chain-core-go/core/pubkeyConverter" - apiCore "github.com/multiversx/mx-chain-core-go/data/api" - "github.com/multiversx/mx-chain-core-go/data/transaction" - "github.com/multiversx/mx-chain-crypto-go/signing" - "github.com/multiversx/mx-chain-crypto-go/signing/ed25519" - "github.com/multiversx/mx-chain-crypto-go/signing/ed25519/singlesig" - "github.com/multiversx/mx-chain-go/integrationTests/vm/wasm" - "github.com/multiversx/mx-chain-go/node/chainSimulator" - "github.com/multiversx/mx-chain-go/node/chainSimulator/components/api" - "github.com/multiversx/mx-chain-go/node/chainSimulator/dtos" - logger "github.com/multiversx/mx-chain-logger-go" - "github.com/multiversx/mx-chain-simulator-go/config" - "github.com/multiversx/mx-chain-simulator-go/pkg/factory" - "github.com/multiversx/mx-chain-simulator-go/pkg/process" - "github.com/multiversx/mx-chain-simulator-go/pkg/proxy" - "github.com/multiversx/mx-chain-simulator-go/pkg/proxy/configs" - "github.com/multiversx/mx-chain-simulator-go/pkg/proxy/creator" - "github.com/multiversx/mx-sdk-go/blockchain" - sdkCore "github.com/multiversx/mx-sdk-go/core" - "github.com/multiversx/mx-sdk-go/data" -) - -var log = logger.GetOrCreate("testscommon/chainsimulator") - -const ( - proxyURL = "http://127.0.0.1:8085" - thousandEgld = "1000000000000000000000" -) - -// ArgProxyWithChainSimulator is the dto used to create a new instance of proxy that relies on a chain simulator -type ArgProxyWithChainSimulator struct { - BypassTxsSignature bool - WorkingDir string - RoundDurationInMs uint64 - RoundsPerEpoch uint64 - NodeConfigs string - ProxyConfigs string - NumOfShards uint32 - BlockTimeInMs uint64 - ServerPort int - ProxyCacherExpirationSeconds uint64 - ProxyMaxNoncesDelta int -} - -type proxyWithChainSimulator struct { - simulatorProxyInstance proxy.ProxyHandler - blocksGenerator process.BlocksGenerator - proxyInstance multiversx.Proxy - simulator chainSimulatorHandler - pkConv core.PubkeyConverter - roundDuration time.Duration -} - -// CreateProxyWithChainSimulator creates a new instance of chain simulator with proxy -func CreateProxyWithChainSimulator(args ArgProxyWithChainSimulator) (*proxyWithChainSimulator, error) { - roundDurationInMillis := args.RoundDurationInMs - rounds := core.OptionalUint64{ - HasValue: true, - Value: args.RoundsPerEpoch, - } - - apiConfigurator := api.NewFreePortAPIConfigurator("localhost") - argsChainSimulator := chainSimulator.ArgsChainSimulator{ - BypassTxSignatureCheck: args.BypassTxsSignature, - TempDir: args.WorkingDir, - PathToInitialConfig: args.NodeConfigs, - NumOfShards: args.NumOfShards, - GenesisTimestamp: time.Now().Unix(), - RoundDurationInMillis: roundDurationInMillis, - RoundsPerEpoch: rounds, - ApiInterface: apiConfigurator, - MinNodesPerShard: 1, - MetaChainMinNodes: 1, - InitialRound: 0, - InitialNonce: 0, - InitialEpoch: 0, - } - simulator, err := chainSimulator.NewChainSimulator(argsChainSimulator) - if err != nil { - return nil, err - } - - log.Info("simulators were initialized") - - err = simulator.GenerateBlocks(1) - if err != nil { - return nil, err - } - - generator, err := factory.CreateBlocksGenerator(simulator, config.BlocksGeneratorConfig{ - AutoGenerateBlocks: true, - BlockTimeInMs: args.BlockTimeInMs, - }) - if err != nil { - return nil, err - } - - metaNode := simulator.GetNodeHandler(core.MetachainShardId) - restApiInterfaces := simulator.GetRestAPIInterfaces() - outputProxyConfigs, err := configs.CreateProxyConfigs(configs.ArgsProxyConfigs{ - TemDir: args.WorkingDir, - PathToProxyConfig: args.ProxyConfigs, - ServerPort: args.ServerPort, - RestApiInterfaces: restApiInterfaces, - InitialWallets: simulator.GetInitialWalletKeys().BalanceWallets, - }) - if err != nil { - return nil, err - } - - time.Sleep(time.Second) - - simulatorProxyInstance, err := creator.CreateProxy(creator.ArgsProxy{ - Config: outputProxyConfigs.Config, - NodeHandler: metaNode, - PathToConfig: outputProxyConfigs.PathToTempConfig, - PathToPemFile: outputProxyConfigs.PathToPemFile, - }) - if err != nil { - return nil, err - } - - simulatorProxyInstance.Start() - - log.Info("chain simulator proxy was started") - - argsProxy := blockchain.ArgsProxy{ - ProxyURL: proxyURL, - SameScState: false, - ShouldBeSynced: false, - FinalityCheck: false, - AllowedDeltaToFinal: args.ProxyMaxNoncesDelta, - CacheExpirationTime: time.Second * time.Duration(args.ProxyCacherExpirationSeconds), - EntityType: sdkCore.Proxy, - } - proxyInstance, err := blockchain.NewProxy(argsProxy) - if err != nil { - return nil, err - } - - pubKeyConverter, err := pubkeyConverter.NewBech32PubkeyConverter(32, "erd") - if err != nil { - return nil, err - } - - return &proxyWithChainSimulator{ - simulatorProxyInstance: simulatorProxyInstance, - blocksGenerator: generator, - proxyInstance: proxyInstance, - simulator: simulator, - pkConv: pubKeyConverter, - roundDuration: time.Duration(args.RoundDurationInMs) * time.Millisecond, - }, nil -} - -// Proxy returns the managed proxy instance -func (instance *proxyWithChainSimulator) Proxy() multiversx.Proxy { - return instance.proxyInstance -} - -// GetNetworkAddress returns the network address -func (instance *proxyWithChainSimulator) GetNetworkAddress() string { - return proxyURL -} - -// DeploySC will deploy the provided smart contract and return its address -func (instance *proxyWithChainSimulator) DeploySC(ctx context.Context, wasmFilePath string, ownerPK string, ownerSK []byte, parameters []string) (string, error) { - networkConfig, err := instance.proxyInstance.GetNetworkConfig(ctx) - if err != nil { - return "", err - } - - nonce, err := instance.getNonce(ctx, ownerPK) - if err != nil { - return "", err - } - - emptyAddress, err := instance.pkConv.Encode(make([]byte, 32)) - if err != nil { - return "", err - } - - scCode := wasm.GetSCCode(wasmFilePath) - params := []string{scCode, wasm.VMTypeHex, wasm.DummyCodeMetadataHex} - params = append(params, parameters...) - txData := strings.Join(params, "@") - - ftx := &transaction.FrontendTransaction{ - Nonce: nonce, - Value: "0", - Receiver: emptyAddress, - Sender: ownerPK, - GasPrice: networkConfig.MinGasPrice, - GasLimit: 600000000, - Data: []byte(txData), - ChainID: networkConfig.ChainID, - Version: 1, - } - - hash, err := instance.signAndSend(ctx, ownerSK, ftx) - if err != nil { - return "", err - } - - log.Info("contract deployed", "hash", hash) - - txResult, errGet := instance.GetTransactionResult(ctx, hash) - if errGet != nil { - return "", errGet - } - - return txResult.Logs.Events[0].Address, nil -} - -// GetTransactionResult tries to get a transaction result. It may wait a few blocks -func (instance *proxyWithChainSimulator) GetTransactionResult(ctx context.Context, hash string) (data.TransactionOnNetwork, error) { - txResult, err := instance.getTxInfoWithResultsIfTxProcessingFinished(ctx, hash) - if err == nil && txResult != nil { - return *txResult, nil - } - - // wait for tx to be done, in order to get the contract address - timeoutTimer := time.NewTimer(instance.roundDuration * 20) - for { - select { - case <-time.After(instance.roundDuration): - txResult, err = instance.getTxInfoWithResultsIfTxProcessingFinished(ctx, hash) - if err == nil && txResult != nil { - return *txResult, nil - } - if err != nil { - return data.TransactionOnNetwork{}, err - } - case <-timeoutTimer.C: - return data.TransactionOnNetwork{}, errors.New("timeout") - } - } -} - -func (instance *proxyWithChainSimulator) getTxInfoWithResultsIfTxProcessingFinished(ctx context.Context, hash string) (*data.TransactionOnNetwork, error) { - txStatus, err := instance.proxyInstance.ProcessTransactionStatus(ctx, hash) - if err != nil { - return nil, err - } - - if txStatus == transaction.TxStatusPending { - return nil, nil - } - - if txStatus != transaction.TxStatusSuccess { - log.Warn("something went wrong with the transaction", "hash", hash, "status", txStatus) - } - - txResult, errGet := instance.proxyInstance.GetTransactionInfoWithResults(ctx, hash) - if errGet != nil { - return nil, err - } - - return &txResult.Data.Transaction, nil - -} - -// ScCall will make the provided sc call -func (instance *proxyWithChainSimulator) ScCall(ctx context.Context, senderPK string, senderSK []byte, contract string, value string, function string, parameters []string) (string, error) { - params := []string{function} - params = append(params, parameters...) - txData := strings.Join(params, "@") - - return instance.SendTx(ctx, senderPK, senderSK, contract, value, []byte(txData)) -} - -// SendTx will build and send a transaction -func (instance *proxyWithChainSimulator) SendTx(ctx context.Context, senderPK string, senderSK []byte, receiver string, value string, dataField []byte) (string, error) { - networkConfig, err := instance.proxyInstance.GetNetworkConfig(ctx) - if err != nil { - return "", err - } - - nonce, err := instance.getNonce(ctx, senderPK) - if err != nil { - return "", err - } - - ftx := &transaction.FrontendTransaction{ - Nonce: nonce, - Value: value, - Receiver: receiver, - Sender: senderPK, - GasPrice: networkConfig.MinGasPrice, - GasLimit: 600000000, - Data: dataField, - ChainID: networkConfig.ChainID, - Version: 1, - } - - return instance.signAndSend(ctx, senderSK, ftx) -} - -// FundWallets sends funds to the provided addresses -func (instance *proxyWithChainSimulator) FundWallets(wallets []string) { - addressesState := make([]*dtos.AddressState, 0, len(wallets)) - for _, wallet := range wallets { - addressesState = append(addressesState, &dtos.AddressState{ - Address: wallet, - Nonce: new(uint64), - Balance: thousandEgld, - }) - } - err := instance.simulator.SetStateMultiple(addressesState) - log.LogIfError(err) -} - -// GetESDTBalance returns the balance of the esdt token for the provided address -func (instance *proxyWithChainSimulator) GetESDTBalance(ctx context.Context, address sdkCore.AddressHandler, token string) (string, error) { - tokenData, err := instance.proxyInstance.GetESDTTokenData(ctx, address, token, apiCore.AccountQueryOptions{ - OnFinalBlock: true, - }) - if err != nil { - return "", err - } - - return tokenData.Balance, nil -} - -func (instance *proxyWithChainSimulator) getNonce(ctx context.Context, bech32Address string) (uint64, error) { - address, err := data.NewAddressFromBech32String(bech32Address) - if err != nil { - return 0, err - } - - account, err := instance.proxyInstance.GetAccount(ctx, address) - if err != nil { - return 0, err - } - - return account.Nonce, nil -} - -func (instance *proxyWithChainSimulator) signAndSend(ctx context.Context, senderSK []byte, ftx *transaction.FrontendTransaction) (string, error) { - sig, err := computeTransactionSignature(senderSK, ftx) - if err != nil { - return "", err - } - ftx.Signature = hex.EncodeToString(sig) - - return instance.proxyInstance.SendTransaction(ctx, ftx) -} - -func computeTransactionSignature(senderSk []byte, tx *transaction.FrontendTransaction) ([]byte, error) { - signer := &singlesig.Ed25519Signer{} - keyGenerator := signing.NewKeyGenerator(ed25519.NewEd25519()) - - senderSk, err := hex.DecodeString(string(senderSk)) - if err != nil { - return nil, err - } - - privateKey, err := keyGenerator.PrivateKeyFromByteArray(senderSk) - if err != nil { - return nil, err - } - - dataToSign, err := json.Marshal(tx) - if err != nil { - return nil, err - } - - return signer.Sign(privateKey, dataToSign) -} - -// Close closes the internal components -func (instance *proxyWithChainSimulator) Close() { - instance.blocksGenerator.Close() - instance.simulatorProxyInstance.Close() -} diff --git a/integrationTests/relayers/common.go b/integrationTests/relayers/common.go index a2143093..1637000c 100644 --- a/integrationTests/relayers/common.go +++ b/integrationTests/relayers/common.go @@ -4,11 +4,19 @@ import ( "context" "fmt" "math/big" + "path" "github.com/ethereum/go-ethereum/common" + "github.com/multiversx/mx-bridge-eth-go/clients/chain" + "github.com/multiversx/mx-bridge-eth-go/config" + "github.com/multiversx/mx-bridge-eth-go/testsCommon" bridgeTests "github.com/multiversx/mx-bridge-eth-go/testsCommon/bridge" + chainConfig "github.com/multiversx/mx-chain-go/config" + logger "github.com/multiversx/mx-chain-logger-go" ) +var log = logger.GetOrCreate("integrationTests/relayers") + func createMockErc20ContractsHolder(tokens []common.Address, safeContractEthAddress common.Address, availableBalances []*big.Int) *bridgeTests.ERC20ContractsHolderStub { return &bridgeTests.ERC20ContractsHolderStub{ BalanceOfCalled: func(ctx context.Context, erc20Address common.Address, address common.Address) (*big.Int, error) { @@ -40,3 +48,59 @@ func availableTokensMapToSlices(erc20Map map[common.Address]*big.Int) ([]common. return tokens, availableBalances } + +func closeRelayers(relayers []bridgeComponents) { + for _, r := range relayers { + _ = r.Close() + } +} + +func createBridgeComponentsConfig(index int, workingDir string) config.Config { + stateMachineConfig := config.ConfigStateMachine{ + StepDurationInMillis: 1000, + IntervalForLeaderInSeconds: 60, + } + + return config.Config{ + Eth: config.EthereumConfig{ + Chain: chain.Ethereum, + NetworkAddress: "mock", + MultisigContractAddress: "3009d97FfeD62E57d444e552A9eDF9Ee6Bc8644c", + PrivateKeyFile: fmt.Sprintf("testdata/ethereum%d.sk", index), + IntervalToResendTxsInSeconds: 10, + GasLimitBase: 200000, + GasLimitForEach: 30000, + GasStation: config.GasStationConfig{ + Enabled: false, + }, + MaxRetriesOnQuorumReached: 1, + IntervalToWaitForTransferInSeconds: 1, + MaxBlocksDelta: 5, + }, + MultiversX: config.MultiversXConfig{ + NetworkAddress: "mock", + MultisigContractAddress: "erd1qqqqqqqqqqqqqpgqzyuaqg3dl7rqlkudrsnm5ek0j3a97qevd8sszj0glf", + SafeContractAddress: "erd1qqqqqqqqqqqqqpgqtvnswnzxxz8susupesys0hvg7q2z5nawrcjq06qdus", + PrivateKeyFile: path.Join(workingDir, fmt.Sprintf("multiversx%d.pem", index)), + IntervalToResendTxsInSeconds: 10, + GasMap: testsCommon.CreateTestMultiversXGasMap(), + MaxRetriesOnQuorumReached: 1, + MaxRetriesOnWasTransferProposed: 3, + ProxyMaxNoncesDelta: 5, + }, + P2P: config.ConfigP2P{}, + StateMachine: map[string]config.ConfigStateMachine{ + "EthereumToMultiversX": stateMachineConfig, + "MultiversXToEthereum": stateMachineConfig, + }, + Relayer: config.ConfigRelayer{ + Marshalizer: chainConfig.MarshalizerConfig{ + Type: "json", + SizeCheckDelta: 10, + }, + RoleProvider: config.RoleProviderConfig{ + PollingIntervalInMillis: 1000, + }, + }, + } +} diff --git a/integrationTests/relayers/ethToMultiversXWithChainSimulator_test.go b/integrationTests/relayers/ethToMultiversXWithChainSimulator_test.go index 27052de1..201d8c9c 100644 --- a/integrationTests/relayers/ethToMultiversXWithChainSimulator_test.go +++ b/integrationTests/relayers/ethToMultiversXWithChainSimulator_test.go @@ -1,8 +1,15 @@ +//go:build slow + +// To run these slow tests, simply add the slow tag on the go test command. Also, provide a chain simulator instance on the 8085 port +// example: go test -tags slow + package relayers import ( + "bytes" "context" "encoding/hex" + "encoding/pem" "fmt" "math/big" "os" @@ -25,32 +32,28 @@ import ( "github.com/multiversx/mx-bridge-eth-go/status" "github.com/multiversx/mx-bridge-eth-go/testsCommon" "github.com/multiversx/mx-bridge-eth-go/testsCommon/bridge" - "github.com/multiversx/mx-chain-core-go/core" + "github.com/multiversx/mx-chain-core-go/core/pubkeyConverter" + "github.com/multiversx/mx-chain-crypto-go/signing" + "github.com/multiversx/mx-chain-crypto-go/signing/ed25519" "github.com/multiversx/mx-chain-go/testscommon/statusHandler" sdkCore "github.com/multiversx/mx-sdk-go/core" "github.com/multiversx/mx-sdk-go/data" "github.com/stretchr/testify/require" ) +var addressPubkeyConverter, _ = pubkeyConverter.NewBech32PubkeyConverter(32, "erd") + const ( - ownerPem = "testdata/wallets/owner.pem" - mvxReceiverPem = "testdata/wallets/mvxReceiver.pem" safeContract = "testdata/contracts/esdt-safe.wasm" multisigContract = "testdata/contracts/multisig.wasm" multiTransferContract = "testdata/contracts/multi-transfer-esdt.wasm" bridgeProxyContract = "testdata/contracts/bridge-proxy.wasm" aggregatorContract = "testdata/contracts/aggregator.wasm" wrapperContract = "testdata/contracts/bridged-tokens-wrapper.wasm" - nodeConfig = "testdata/config/nodeConfig" - proxyConfig = "testdata/config/proxyConfig" minRelayerStake = "10000000000000000000" // 10egld slashAmount = "00" quorum = "03" - relayerPemPathFormat = "testdata/multiversx%d.pem" - roundDurationInMs = 1000 - roundsPerEpoch = 20 - numOfShards = 3 - serverPort = 8085 + relayerPemPathFormat = "multiversx%d.pem" proxyCacherExpirationSeconds = 600 proxyMaxNoncesDelta = 7 zeroValue = "0" @@ -94,16 +97,17 @@ const ( setPairDecimals = "setPairDecimals" ) -type proxyWithChainSimulator interface { +type chainSimulatorWrapper interface { Proxy() multiversx.Proxy GetNetworkAddress() string DeploySC(ctx context.Context, path string, ownerPK string, ownerSK []byte, extraParams []string) (string, error) ScCall(ctx context.Context, senderPK string, senderSK []byte, contract string, value string, function string, parameters []string) (string, error) SendTx(ctx context.Context, senderPK string, senderSK []byte, receiver string, value string, dataField []byte) (string, error) - GetTransactionResult(ctx context.Context, hash string) (data.TransactionOnNetwork, error) - FundWallets(wallets []string) + GetTransactionResult(ctx context.Context, hash string) (*data.TransactionOnNetwork, error) + FundWallets(ctx context.Context, wallets []string) + GenerateBlocksUntilEpochReached(ctx context.Context, epoch uint32) + GenerateBlocks(ctx context.Context, numBlocks int) GetESDTBalance(ctx context.Context, address sdkCore.AddressHandler, token string) (string, error) - Close() } type keysHolder struct { @@ -112,21 +116,14 @@ type keysHolder struct { } func TestRelayersShouldExecuteTransfersFromEthToMultiversXWithChainSimulator(t *testing.T) { - t.Skip("this is a long test") - safeContractEthAddress := testsCommon.CreateRandomEthereumAddress() token1Erc20 := testsCommon.CreateRandomEthereumAddress() value1 := big.NewInt(200000000) - // read the receiver keys - receiverSK, receiverPK, err := core.LoadSkPkFromPemFile(mvxReceiverPem, 0) - require.NoError(t, err) - receiverKeys := keysHolder{ - pk: receiverPK, - sk: receiverSK, - } + receiverKeys := generateMvxPrivatePublicKey(t) + log.Info("receiver is", "address", receiverKeys.pk) - receiverAddress, err := data.NewAddressFromBech32String(receiverPK) + receiverAddress, err := data.NewAddressFromBech32String(receiverKeys.pk) require.NoError(t, err) depositor := testsCommon.CreateRandomEthereumAddress() @@ -168,63 +165,60 @@ func TestRelayersShouldExecuteTransfersFromEthToMultiversXWithChainSimulator(t * return expectedStatuses } + tempDir := t.TempDir() relayersKeys := make([]keysHolder, 0, numRelayers) for i := 0; i < numRelayers; i++ { - relayerSK, relayerPK, err := core.LoadSkPkFromPemFile(fmt.Sprintf(relayerPemPathFormat, i), 0) - require.Nil(t, err) - - relayersKeys = append(relayersKeys, keysHolder{ - pk: relayerPK, - sk: relayerSK, - }) + relayerKeys := generateMvxPrivatePublicKey(t) + log.Info("generated relayer", "index", i, "address", relayerKeys.pk) + relayersKeys = append(relayersKeys, relayerKeys) + saveRelayerKey(t, tempDir, i, relayerKeys) } - multiversXProxyWithChainSimulator := startProxyWithChainSimulator(t) - defer multiversXProxyWithChainSimulator.Close() + mvxChainSimulatorWrapper := startChainSimulatorWrapper(t) // create a test context ctx, cancel := context.WithCancel(context.Background()) defer cancel() - // read the owner keys - ownerSK, ownerPK, err := core.LoadSkPkFromPemFile(ownerPem, 0) - require.NoError(t, err) - ownerKeys := keysHolder{ - pk: ownerPK, - sk: ownerSK, - } + ownerKeys := generateMvxPrivatePublicKey(t) + log.Info("owner is", "address", receiverKeys.pk) + + // we need to wait until epoch 1 is reached so SC deployment will work + mvxChainSimulatorWrapper.GenerateBlocksUntilEpochReached(ctx, 1) // deploy all contracts and execute all txs needed - safeAddress, multisigAddress, wrapperAddress, aggregatorAddress := executeContractsTxs(t, ctx, multiversXProxyWithChainSimulator, relayersKeys, ownerKeys, receiverKeys) + safeAddress, multisigAddress, wrapperAddress, aggregatorAddress := executeContractsTxs(t, ctx, mvxChainSimulatorWrapper, relayersKeys, ownerKeys, receiverKeys) // issue and whitelist token - newUniversalToken, newChainSpecificToken := issueAndWhitelistToken(t, ctx, multiversXProxyWithChainSimulator, ownerKeys, wrapperAddress, safeAddress, multisigAddress, aggregatorAddress, hex.EncodeToString(token1Erc20.Bytes())) + newUniversalToken, newChainSpecificToken := issueAndWhitelistToken(t, ctx, mvxChainSimulatorWrapper, ownerKeys, wrapperAddress, safeAddress, multisigAddress, aggregatorAddress, hex.EncodeToString(token1Erc20.Bytes())) // start relayers - relayers := startRelayers(t, numRelayers, multiversXProxyWithChainSimulator, ethereumChainMock, safeContractEthAddress, erc20ContractsHolder, safeAddress, multisigAddress) + relayers := startRelayers(t, tempDir, numRelayers, mvxChainSimulatorWrapper, ethereumChainMock, safeContractEthAddress, erc20ContractsHolder, safeAddress, multisigAddress) defer closeRelayers(relayers) - checkESDTBalance(t, ctx, multiversXProxyWithChainSimulator, receiverAddress, newUniversalToken, "0", true) + checkESDTBalance(t, ctx, mvxChainSimulatorWrapper, receiverAddress, newUniversalToken, "0", true) - // wait for signal interrupt or time out - roundDuration := time.Duration(roundDurationInMs) * time.Millisecond - timerBetweenBalanceChecks := time.NewTimer(roundDuration) interrupt := make(chan os.Signal, 1) signal.Notify(interrupt, syscall.SIGINT, syscall.SIGTERM) ethToMVXDone := false mvxToETHDone := false for { - timerBetweenBalanceChecks.Reset(roundDuration) select { - case <-timerBetweenBalanceChecks.C: - isTransferDoneFromETH := checkESDTBalance(t, ctx, multiversXProxyWithChainSimulator, receiverAddress, newUniversalToken, value1.String(), false) + case <-interrupt: + require.Fail(t, "signal interrupted") + return + case <-time.After(time.Minute * 15): + require.Fail(t, "time out") + return + default: + isTransferDoneFromETH := checkESDTBalance(t, ctx, mvxChainSimulatorWrapper, receiverAddress, newUniversalToken, value1.String(), false) if !ethToMVXDone && isTransferDoneFromETH { ethToMVXDone = true log.Info("ETH->MVX transfer finished, now sending back to ETH...") // send half of the amount back to ETH value := big.NewInt(0).Div(value1, big.NewInt(2)) - sendMVXToEthTransaction(t, ctx, multiversXProxyWithChainSimulator, value.Bytes(), newUniversalToken, newChainSpecificToken, receiverKeys, safeAddress, wrapperAddress, depositor.Bytes()) + sendMVXToEthTransaction(t, ctx, mvxChainSimulatorWrapper, value.Bytes(), newUniversalToken, newChainSpecificToken, receiverKeys, safeAddress, wrapperAddress, depositor.Bytes()) } isTransferDoneFromMVX := checkETHStatus(ethereumChainMock, depositor, token1Erc20) @@ -237,46 +231,66 @@ func TestRelayersShouldExecuteTransfersFromEthToMultiversXWithChainSimulator(t * return } - case <-interrupt: - require.Fail(t, "signal interrupted") - return - case <-time.After(time.Minute * 15): - require.Fail(t, "time out") - return + mvxChainSimulatorWrapper.GenerateBlocks(ctx, 1) } } } -func startProxyWithChainSimulator(t *testing.T) proxyWithChainSimulator { +func generateMvxPrivatePublicKey(t *testing.T) keysHolder { + keyGenerator := signing.NewKeyGenerator(ed25519.NewEd25519()) + sk, pk := keyGenerator.GeneratePair() + + skBytes, err := sk.ToByteArray() + require.Nil(t, err) + + pkBytes, err := pk.ToByteArray() + require.Nil(t, err) + + address, err := addressPubkeyConverter.Encode(pkBytes) + require.Nil(t, err) + + return keysHolder{ + pk: address, + sk: skBytes, + } +} + +func saveRelayerKey(t *testing.T, tempDir string, index int, key keysHolder) { + blk := pem.Block{ + Type: "PRIVATE KEY for " + key.pk, + Bytes: []byte(hex.EncodeToString(key.sk)), + } + + buff := bytes.NewBuffer(make([]byte, 0)) + err := pem.Encode(buff, &blk) + require.Nil(t, err) + + err = os.WriteFile(path.Join(tempDir, fmt.Sprintf(relayerPemPathFormat, index)), buff.Bytes(), os.ModePerm) + require.Nil(t, err) +} + +func startChainSimulatorWrapper(t *testing.T) chainSimulatorWrapper { // create a new working directory tmpDir := path.Join(t.TempDir(), "test") err := os.MkdirAll(tmpDir, os.ModePerm) require.NoError(t, err) // start the chain simulator - args := integrationTests.ArgProxyWithChainSimulator{ - BypassTxsSignature: true, - WorkingDir: tmpDir, - RoundDurationInMs: roundDurationInMs, - RoundsPerEpoch: roundsPerEpoch, - NodeConfigs: nodeConfig, - ProxyConfigs: proxyConfig, - NumOfShards: numOfShards, - BlockTimeInMs: roundDurationInMs, - ServerPort: serverPort, + args := integrationTests.ArgChainSimulatorWrapper{ ProxyCacherExpirationSeconds: proxyCacherExpirationSeconds, ProxyMaxNoncesDelta: proxyMaxNoncesDelta, } - multiversXProxyWithChainSimulator, err := integrationTests.CreateProxyWithChainSimulator(args) + mvxChainSimulatorWrapper, err := integrationTests.CreateChainSimulatorWrapper(args) require.NoError(t, err) - return multiversXProxyWithChainSimulator + return mvxChainSimulatorWrapper } func startRelayers( t *testing.T, + workingDir string, numRelayers int, - multiversXProxyWithChainSimulator proxyWithChainSimulator, + mvxChainSimulator chainSimulatorWrapper, ethereumChainMock *mock.EthereumChainMock, safeContractEthAddress common.Address, erc20ContractsHolder *bridge.ERC20ContractsHolderStub, @@ -288,7 +302,7 @@ func startRelayers( messengers := integrationTests.CreateLinkedMessengers(numRelayers) for i := 0; i < numRelayers; i++ { - generalConfigs := createBridgeComponentsConfig(i) + generalConfigs := createBridgeComponentsConfig(i, workingDir) argsBridgeComponents := factory.ArgsEthereumToMultiversXBridge{ Configs: config.Configs{ GeneralConfig: generalConfigs, @@ -297,7 +311,7 @@ func startRelayers( RestApiInterface: bridgeCore.WebServerOffString, }, }, - Proxy: multiversXProxyWithChainSimulator.Proxy(), + Proxy: mvxChainSimulator.Proxy(), ClientWrapper: ethereumChainMock, Messenger: messengers[i], StatusStorer: testsCommon.NewStorerMock(), @@ -309,7 +323,7 @@ func startRelayers( } argsBridgeComponents.Configs.GeneralConfig.Eth.SafeContractAddress = safeContractEthAddress.Hex() argsBridgeComponents.Erc20ContractsHolder = erc20ContractsHolder - argsBridgeComponents.Configs.GeneralConfig.MultiversX.NetworkAddress = multiversXProxyWithChainSimulator.GetNetworkAddress() + argsBridgeComponents.Configs.GeneralConfig.MultiversX.NetworkAddress = mvxChainSimulator.GetNetworkAddress() argsBridgeComponents.Configs.GeneralConfig.MultiversX.SafeContractAddress = safeAddress argsBridgeComponents.Configs.GeneralConfig.MultiversX.MultisigContractAddress = multisigAddress argsBridgeComponents.Configs.GeneralConfig.MultiversX.GasMap = config.MultiversXGasMapConfig{ @@ -343,7 +357,7 @@ func startRelayers( func executeContractsTxs( t *testing.T, ctx context.Context, - multiversXProxyWithChainSimulator proxyWithChainSimulator, + mvxChainSimulator chainSimulatorWrapper, relayersKeys []keysHolder, ownerKeys keysHolder, receiver keysHolder, @@ -355,10 +369,9 @@ func executeContractsTxs( } walletsToFund = append(walletsToFund, ownerKeys.pk) walletsToFund = append(walletsToFund, receiver.pk) - multiversXProxyWithChainSimulator.FundWallets(walletsToFund) + mvxChainSimulator.FundWallets(ctx, walletsToFund) - // wait for epoch 1 before sc deploys - time.Sleep(time.Duration(roundDurationInMs*(roundsPerEpoch+2)) * time.Millisecond) + mvxChainSimulator.GenerateBlocks(ctx, 1) // deploy aggregator stakeValue, _ := big.NewInt(0).SetString(minRelayerStake, 10) @@ -371,7 +384,7 @@ func executeContractsTxs( getHexAddress(t, ownerKeys.pk), } - aggregatorAddress, err := multiversXProxyWithChainSimulator.DeploySC( + aggregatorAddress, err := mvxChainSimulator.DeploySC( ctx, aggregatorContract, ownerKeys.pk, @@ -384,7 +397,7 @@ func executeContractsTxs( log.Info("aggregator contract deployed", "address", aggregatorAddress) // deploy wrapper - wrapperAddress, err := multiversXProxyWithChainSimulator.DeploySC( + wrapperAddress, err := mvxChainSimulator.DeploySC( ctx, wrapperContract, ownerKeys.pk, @@ -397,7 +410,7 @@ func executeContractsTxs( log.Info("wrapper contract deployed", "address", wrapperAddress) // deploy safe - safeAddress, err := multiversXProxyWithChainSimulator.DeploySC( + safeAddress, err := mvxChainSimulator.DeploySC( ctx, safeContract, ownerKeys.pk, @@ -410,7 +423,7 @@ func executeContractsTxs( log.Info("safe contract deployed", "address", safeAddress) // deploy multi-transfer - multiTransferAddress, err := multiversXProxyWithChainSimulator.DeploySC( + multiTransferAddress, err := mvxChainSimulator.DeploySC( ctx, multiTransferContract, ownerKeys.pk, @@ -429,7 +442,7 @@ func executeContractsTxs( for _, relayerKeys := range relayersKeys { params = append(params, getHexAddress(t, relayerKeys.pk)) } - multisigAddress, err := multiversXProxyWithChainSimulator.DeploySC( + multisigAddress, err := mvxChainSimulator.DeploySC( ctx, multisigContract, ownerKeys.pk, @@ -442,7 +455,7 @@ func executeContractsTxs( log.Info("multisig contract deployed", "address", multisigAddress) // deploy bridge proxy - bridgeProxyAddress, err := multiversXProxyWithChainSimulator.DeploySC( + bridgeProxyAddress, err := mvxChainSimulator.DeploySC( ctx, bridgeProxyContract, ownerKeys.pk, @@ -455,7 +468,7 @@ func executeContractsTxs( log.Info("bridge proxy contract deployed", "address", bridgeProxyAddress) // setBridgeProxyContractAddress - hash, err := multiversXProxyWithChainSimulator.ScCall( + hash, err := mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -465,13 +478,13 @@ func executeContractsTxs( []string{getHexAddress(t, bridgeProxyAddress)}, ) require.NoError(t, err) - txResult, err := multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err := mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("setBridgeProxyContractAddress tx executed", "hash", hash, "status", txResult.Status) // setWrappingContractAddress - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -481,13 +494,13 @@ func executeContractsTxs( []string{getHexAddress(t, wrapperAddress)}, ) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("setWrappingContractAddress tx executed", "hash", hash, "status", txResult.Status) // ChangeOwnerAddress for safe - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -497,13 +510,13 @@ func executeContractsTxs( []string{getHexAddress(t, multisigAddress)}, ) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("ChangeOwnerAddress for safe tx executed", "hash", hash, "status", txResult.Status) // ChangeOwnerAddress for multi-transfer - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -513,13 +526,13 @@ func executeContractsTxs( []string{getHexAddress(t, multisigAddress)}, ) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("ChangeOwnerAddress for multi-transfer tx executed", "hash", hash, "status", txResult.Status) // ChangeOwnerAddress for bridge proxy - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -529,13 +542,13 @@ func executeContractsTxs( []string{getHexAddress(t, multisigAddress)}, ) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("ChangeOwnerAddress for bridge proxy tx executed", "hash", hash, "status", txResult.Status) // setMultiTransferOnEsdtSafe - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -545,13 +558,13 @@ func executeContractsTxs( []string{}, ) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("setMultiTransferOnEsdtSafe tx executed", "hash", hash, "status", txResult.Status) // setEsdtSafeOnMultiTransfer - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -561,13 +574,13 @@ func executeContractsTxs( []string{}, ) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("setEsdtSafeOnMultiTransfer tx executed", "hash", hash, "status", txResult.Status) // setPairDecimals on aggregator - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -576,57 +589,57 @@ func executeContractsTxs( setPairDecimals, []string{hex.EncodeToString([]byte(gwei)), hex.EncodeToString([]byte(chainSpecificTokenTicker)), numOfDecimalsChainSpecific}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("setPairDecimals tx executed", "hash", hash, "status", txResult.Status) // stake relayers on multisig - stakeAddressesOnContract(t, ctx, multiversXProxyWithChainSimulator, multisigAddress, relayersKeys) + stakeAddressesOnContract(t, ctx, mvxChainSimulator, multisigAddress, relayersKeys) // stake relayers on price aggregator - stakeAddressesOnContract(t, ctx, multiversXProxyWithChainSimulator, aggregatorAddress, []keysHolder{ownerKeys}) + stakeAddressesOnContract(t, ctx, mvxChainSimulator, aggregatorAddress, []keysHolder{ownerKeys}) // unpause multisig - hash = unpauseContract(t, ctx, multiversXProxyWithChainSimulator, ownerKeys, multisigAddress, []byte(unpause)) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + hash = unpauseContract(t, ctx, mvxChainSimulator, ownerKeys, multisigAddress, []byte(unpause)) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("unpaused multisig executed", "hash", hash, "status", txResult.Status) // unpause safe - hash = unpauseContract(t, ctx, multiversXProxyWithChainSimulator, ownerKeys, multisigAddress, []byte(unpauseEsdtSafe)) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + hash = unpauseContract(t, ctx, mvxChainSimulator, ownerKeys, multisigAddress, []byte(unpauseEsdtSafe)) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("unpaused safe executed", "hash", hash, "status", txResult.Status) // unpause aggregator - hash = unpauseContract(t, ctx, multiversXProxyWithChainSimulator, ownerKeys, aggregatorAddress, []byte(unpause)) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + hash = unpauseContract(t, ctx, mvxChainSimulator, ownerKeys, aggregatorAddress, []byte(unpause)) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("unpaused aggregator executed", "hash", hash, "status", txResult.Status) // unpause wrapper - hash = unpauseContract(t, ctx, multiversXProxyWithChainSimulator, ownerKeys, wrapperAddress, []byte(unpause)) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + hash = unpauseContract(t, ctx, mvxChainSimulator, ownerKeys, wrapperAddress, []byte(unpause)) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("unpaused wrapper executed", "hash", hash, "status", txResult.Status) return safeAddress, multisigAddress, wrapperAddress, aggregatorAddress } -func stakeAddressesOnContract(t *testing.T, ctx context.Context, multiversXProxyWithChainSimulator proxyWithChainSimulator, contract string, allKeys []keysHolder) { +func stakeAddressesOnContract(t *testing.T, ctx context.Context, mvxChainSimulator chainSimulatorWrapper, contract string, allKeys []keysHolder) { for _, keys := range allKeys { - hash, err := multiversXProxyWithChainSimulator.SendTx(ctx, keys.pk, keys.sk, contract, minRelayerStake, []byte("stake")) + hash, err := mvxChainSimulator.SendTx(ctx, keys.pk, keys.sk, contract, minRelayerStake, []byte("stake")) require.NoError(t, err) - txResult, err := multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err := mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info(fmt.Sprintf("address %s staked on contract %s with hash %s, status %s", keys.pk, contract, hash, txResult.Status)) } } -func unpauseContract(t *testing.T, ctx context.Context, multiversXProxyWithChainSimulator proxyWithChainSimulator, ownerKeys keysHolder, contract string, dataField []byte) string { - hash, err := multiversXProxyWithChainSimulator.SendTx(ctx, ownerKeys.pk, ownerKeys.sk, contract, zeroValue, dataField) +func unpauseContract(t *testing.T, ctx context.Context, mvxChainSimulator chainSimulatorWrapper, ownerKeys keysHolder, contract string, dataField []byte) string { + hash, err := mvxChainSimulator.SendTx(ctx, ownerKeys.pk, ownerKeys.sk, contract, zeroValue, dataField) require.NoError(t, err) return hash @@ -635,7 +648,7 @@ func unpauseContract(t *testing.T, ctx context.Context, multiversXProxyWithChain func issueAndWhitelistToken( t *testing.T, ctx context.Context, - multiversXProxyWithChainSimulator proxyWithChainSimulator, + mvxChainSimulator chainSimulatorWrapper, ownerKeys keysHolder, wrapperAddress string, safeAddress string, @@ -644,7 +657,7 @@ func issueAndWhitelistToken( erc20Token string, ) (string, string) { // issue universal token - hash, err := multiversXProxyWithChainSimulator.ScCall( + hash, err := mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -653,15 +666,15 @@ func issueAndWhitelistToken( issue, []string{hex.EncodeToString([]byte(universalTokenDisplayName)), hex.EncodeToString([]byte(universalTokenTicker)), "00", numOfDecimalsUniversal, hex.EncodeToString([]byte(canAddSpecialRoles)), hex.EncodeToString([]byte(trueStr))}) require.NoError(t, err) - txResult, err := multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err := mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) - newUniversalToken := getTokenNameFromResult(t, txResult) + newUniversalToken := getTokenNameFromResult(t, *txResult) log.Info("issue universal token tx executed", "hash", hash, "status", txResult.Status, "token", newUniversalToken) // issue chain specific token valueToMintInt, _ := big.NewInt(0).SetString(valueToMint, 10) - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -670,14 +683,14 @@ func issueAndWhitelistToken( issue, []string{hex.EncodeToString([]byte(chainSpecificTokenDisplayName)), hex.EncodeToString([]byte(chainSpecificTokenTicker)), hex.EncodeToString(valueToMintInt.Bytes()), numOfDecimalsChainSpecific, hex.EncodeToString([]byte(canAddSpecialRoles)), hex.EncodeToString([]byte(trueStr))}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) - newChainSpecificToken := getTokenNameFromResult(t, txResult) + newChainSpecificToken := getTokenNameFromResult(t, *txResult) log.Info("issue chain specific token tx executed", "hash", hash, "status", txResult.Status, "token", newChainSpecificToken) // set local roles bridged tokens wrapper - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -686,13 +699,13 @@ func issueAndWhitelistToken( setSpecialRole, []string{hex.EncodeToString([]byte(newUniversalToken)), getHexAddress(t, wrapperAddress), hex.EncodeToString([]byte(esdtRoleLocalMint)), hex.EncodeToString([]byte(esdtRoleLocalBurn))}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("set local roles bridged tokens wrapper tx executed", "hash", hash, "status", txResult.Status) // transfer to sc - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -701,13 +714,13 @@ func issueAndWhitelistToken( esdtTransfer, []string{hex.EncodeToString([]byte(newChainSpecificToken)), hex.EncodeToString(valueToMintInt.Bytes()), hex.EncodeToString([]byte(depositLiquidity))}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("transfer to sc tx executed", "hash", hash, "status", txResult.Status) // add wrapped token - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -716,13 +729,13 @@ func issueAndWhitelistToken( addWrappedToken, []string{hex.EncodeToString([]byte(newUniversalToken)), numOfDecimalsUniversal}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("add wrapped token tx executed", "hash", hash, "status", txResult.Status) // wrapper whitelist token - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -731,13 +744,13 @@ func issueAndWhitelistToken( whitelistToken, []string{hex.EncodeToString([]byte(newChainSpecificToken)), numOfDecimalsChainSpecific, hex.EncodeToString([]byte(newUniversalToken))}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("wrapper whitelist token tx executed", "hash", hash, "status", txResult.Status) // set local roles esdt safe - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -746,13 +759,13 @@ func issueAndWhitelistToken( setSpecialRole, []string{hex.EncodeToString([]byte(newChainSpecificToken)), getHexAddress(t, safeAddress), hex.EncodeToString([]byte(esdtRoleLocalMint)), hex.EncodeToString([]byte(esdtRoleLocalBurn))}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("set local roles esdt safe tx executed", "hash", hash, "status", txResult.Status) // add mapping - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -761,13 +774,13 @@ func issueAndWhitelistToken( addMapping, []string{erc20Token, hex.EncodeToString([]byte(newChainSpecificToken))}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("add mapping tx executed", "hash", hash, "status", txResult.Status) // whitelist token - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -776,17 +789,17 @@ func issueAndWhitelistToken( esdtSafeAddTokenToWhitelist, []string{hex.EncodeToString([]byte(newChainSpecificToken)), hex.EncodeToString([]byte(chainSpecificTokenTicker)), "01", "01"}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("whitelist token tx executed", "hash", hash, "status", txResult.Status) // submit aggregator batch - submitAggregatorBatch(t, ctx, multiversXProxyWithChainSimulator, aggregatorAddress, ownerKeys) + submitAggregatorBatch(t, ctx, mvxChainSimulator, aggregatorAddress, ownerKeys) // safe set max bridge amount for token maxBridgedAmountForTokenInt, _ := big.NewInt(0).SetString(maxBridgedAmountForToken, 10) - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -795,13 +808,13 @@ func issueAndWhitelistToken( esdtSafeSetMaxBridgedAmountForToken, []string{hex.EncodeToString([]byte(newChainSpecificToken)), hex.EncodeToString(maxBridgedAmountForTokenInt.Bytes())}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("safe set max bridge amount for token tx executed", "hash", hash, "status", txResult.Status) // multi-transfer set max bridge amount for token - hash, err = multiversXProxyWithChainSimulator.ScCall( + hash, err = mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -810,7 +823,7 @@ func issueAndWhitelistToken( multiTransferEsdtSetMaxBridgedAmountForToken, []string{hex.EncodeToString([]byte(newChainSpecificToken)), hex.EncodeToString(maxBridgedAmountForTokenInt.Bytes())}) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("multi-transfer set max bridge amount for token tx executed", "hash", hash, "status", txResult.Status) @@ -841,13 +854,13 @@ func getHexAddress(t *testing.T, bech32Address string) string { func checkESDTBalance( t *testing.T, ctx context.Context, - multiversXProxyWithChainSimulator proxyWithChainSimulator, + mvxChainSimulator chainSimulatorWrapper, address sdkCore.AddressHandler, token string, expectedBalance string, checkResult bool, ) bool { - balance, err := multiversXProxyWithChainSimulator.GetESDTBalance(ctx, address, token) + balance, err := mvxChainSimulator.GetESDTBalance(ctx, address, token) require.NoError(t, err) if checkResult { @@ -869,7 +882,7 @@ func checkETHStatus(ethereumChainMock *mock.EthereumChainMock, receiver common.A func sendMVXToEthTransaction( t *testing.T, ctx context.Context, - multiversXProxyWithChainSimulator proxyWithChainSimulator, + mvxChainSimulator chainSimulatorWrapper, value []byte, universalToken string, chainSpecificToken string, @@ -886,9 +899,9 @@ func sendMVXToEthTransaction( hex.EncodeToString([]byte(chainSpecificToken)), } - hash, err := multiversXProxyWithChainSimulator.ScCall(ctx, senderKeys.pk, senderKeys.sk, wrapperAddress, zeroValue, esdtTransfer, paramsUnwrap) + hash, err := mvxChainSimulator.ScCall(ctx, senderKeys.pk, senderKeys.sk, wrapperAddress, zeroValue, esdtTransfer, paramsUnwrap) require.NoError(t, err) - txResult, err := multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err := mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("unwrap transaction sent", "hash", hash, "token", universalToken, "status", txResult.Status) @@ -901,10 +914,10 @@ func sendMVXToEthTransaction( hex.EncodeToString(receiver), } - hash, err = multiversXProxyWithChainSimulator.ScCall(ctx, senderKeys.pk, senderKeys.sk, safeAddress, zeroValue, esdtTransfer, params) + hash, err = mvxChainSimulator.ScCall(ctx, senderKeys.pk, senderKeys.sk, safeAddress, zeroValue, esdtTransfer, params) require.NoError(t, err) - txResult, err = multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err = mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("MVX->ETH transaction sent", "hash", hash, "status", txResult.Status) @@ -912,10 +925,10 @@ func sendMVXToEthTransaction( return hash } -func submitAggregatorBatch(t *testing.T, ctx context.Context, multiversXProxyWithChainSimulator proxyWithChainSimulator, aggregatorAddress string, ownerKeys keysHolder) { +func submitAggregatorBatch(t *testing.T, ctx context.Context, mvxChainSimulator chainSimulatorWrapper, aggregatorAddress string, ownerKeys keysHolder) { feeInt, _ := big.NewInt(0).SetString(fee, 10) timestamp := big.NewInt(time.Now().Unix()) - hash, err := multiversXProxyWithChainSimulator.ScCall( + hash, err := mvxChainSimulator.ScCall( ctx, ownerKeys.pk, ownerKeys.sk, @@ -924,7 +937,7 @@ func submitAggregatorBatch(t *testing.T, ctx context.Context, multiversXProxyWit submitBatch, []string{hex.EncodeToString([]byte(gwei)), hex.EncodeToString([]byte(chainSpecificTokenTicker)), hex.EncodeToString(timestamp.Bytes()), hex.EncodeToString(feeInt.Bytes()), numOfDecimalsChainSpecific}) require.NoError(t, err) - txResult, err := multiversXProxyWithChainSimulator.GetTransactionResult(ctx, hash) + txResult, err := mvxChainSimulator.GetTransactionResult(ctx, hash) require.NoError(t, err) log.Info("submit aggregator batch tx executed", "hash", hash, "submitter", ownerKeys.pk, "status", txResult.Status) diff --git a/integrationTests/relayers/ethToMultiversX_test.go b/integrationTests/relayers/ethToMultiversX_test.go index b3204a43..fcd27238 100644 --- a/integrationTests/relayers/ethToMultiversX_test.go +++ b/integrationTests/relayers/ethToMultiversX_test.go @@ -1,9 +1,10 @@ +//go:build !slow + package relayers import ( "context" "encoding/hex" - "fmt" "math/big" "testing" "time" @@ -13,7 +14,6 @@ import ( "github.com/ethereum/go-ethereum/core/types" ethmultiversx "github.com/multiversx/mx-bridge-eth-go/bridges/ethMultiversX" "github.com/multiversx/mx-bridge-eth-go/clients" - "github.com/multiversx/mx-bridge-eth-go/clients/chain" "github.com/multiversx/mx-bridge-eth-go/clients/ethereum/contract" "github.com/multiversx/mx-bridge-eth-go/config" "github.com/multiversx/mx-bridge-eth-go/core" @@ -23,7 +23,6 @@ import ( "github.com/multiversx/mx-bridge-eth-go/status" "github.com/multiversx/mx-bridge-eth-go/testsCommon" "github.com/multiversx/mx-bridge-eth-go/testsCommon/bridge" - chainConfig "github.com/multiversx/mx-chain-go/config" "github.com/multiversx/mx-chain-go/p2p" "github.com/multiversx/mx-chain-go/testscommon/statusHandler" "github.com/stretchr/testify/assert" @@ -374,7 +373,7 @@ func createMockBridgeComponentsArgs( ethereumChainMock *mock.EthereumChainMock, ) factory.ArgsEthereumToMultiversXBridge { - generalConfigs := createBridgeComponentsConfig(index) + generalConfigs := createBridgeComponentsConfig(index, "testdata") return factory.ArgsEthereumToMultiversXBridge{ Configs: config.Configs{ GeneralConfig: generalConfigs, @@ -394,53 +393,3 @@ func createMockBridgeComponentsArgs( MultiversXClientStatusHandler: &testsCommon.StatusHandlerStub{}, } } - -func createBridgeComponentsConfig(index int) config.Config { - stateMachineConfig := config.ConfigStateMachine{ - StepDurationInMillis: 1000, - IntervalForLeaderInSeconds: 60, - } - - return config.Config{ - Eth: config.EthereumConfig{ - Chain: chain.Ethereum, - NetworkAddress: "mock", - MultisigContractAddress: "3009d97FfeD62E57d444e552A9eDF9Ee6Bc8644c", - PrivateKeyFile: fmt.Sprintf("testdata/ethereum%d.sk", index), - IntervalToResendTxsInSeconds: 10, - GasLimitBase: 200000, - GasLimitForEach: 30000, - GasStation: config.GasStationConfig{ - Enabled: false, - }, - MaxRetriesOnQuorumReached: 1, - IntervalToWaitForTransferInSeconds: 1, - MaxBlocksDelta: 5, - }, - MultiversX: config.MultiversXConfig{ - NetworkAddress: "mock", - MultisigContractAddress: "erd1qqqqqqqqqqqqqpgqzyuaqg3dl7rqlkudrsnm5ek0j3a97qevd8sszj0glf", - SafeContractAddress: "erd1qqqqqqqqqqqqqpgqtvnswnzxxz8susupesys0hvg7q2z5nawrcjq06qdus", - PrivateKeyFile: fmt.Sprintf("testdata/multiversx%d.pem", index), - IntervalToResendTxsInSeconds: 10, - GasMap: testsCommon.CreateTestMultiversXGasMap(), - MaxRetriesOnQuorumReached: 1, - MaxRetriesOnWasTransferProposed: 3, - ProxyMaxNoncesDelta: 5, - }, - P2P: config.ConfigP2P{}, - StateMachine: map[string]config.ConfigStateMachine{ - "EthereumToMultiversX": stateMachineConfig, - "MultiversXToEthereum": stateMachineConfig, - }, - Relayer: config.ConfigRelayer{ - Marshalizer: chainConfig.MarshalizerConfig{ - Type: "json", - SizeCheckDelta: 10, - }, - RoleProvider: config.RoleProviderConfig{ - PollingIntervalInMillis: 1000, - }, - }, - } -} diff --git a/integrationTests/relayers/multiversXToEth_test.go b/integrationTests/relayers/multiversXToEth_test.go index 9f326742..a7fa525d 100644 --- a/integrationTests/relayers/multiversXToEth_test.go +++ b/integrationTests/relayers/multiversXToEth_test.go @@ -1,3 +1,5 @@ +//go:build !slow + package relayers import ( @@ -13,13 +15,10 @@ import ( "github.com/multiversx/mx-bridge-eth-go/integrationTests" "github.com/multiversx/mx-bridge-eth-go/integrationTests/mock" "github.com/multiversx/mx-bridge-eth-go/testsCommon" - logger "github.com/multiversx/mx-chain-logger-go" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" ) -var log = logger.GetOrCreate("integrationTests/relayers") - func asyncCancelCall(cancelHandler func(), delay time.Duration) { go func() { time.Sleep(delay) @@ -219,12 +218,6 @@ func createTransaction(index int) (mock.MultiversXDeposit, common.Address) { }, tokenAddress } -func closeRelayers(relayers []bridgeComponents) { - for _, r := range relayers { - _ = r.Close() - } -} - func checkTestStatus( t *testing.T, multiversXChainMock *mock.MultiversXChainMock, diff --git a/integrationTests/relayers/testdata/config/nodeConfig/api.toml b/integrationTests/relayers/testdata/config/nodeConfig/api.toml deleted file mode 100644 index 04afa90b..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/api.toml +++ /dev/null @@ -1,309 +0,0 @@ -# Logging holds settings related to api requests logging -[Logging] - # LoggingEnabled - if this flag is set to true, then if a requests exceeds a threshold or it is unsuccessful, then - # a log will be printed - LoggingEnabled = false - - # ThresholdInMicroSeconds represents the maximum duration to consider a request as normal. Above this, if the LoggingEnabled - # flag is set to true, then a log will be printed - ThresholdInMicroSeconds = 1000 - -# API routes configuration -[APIPackages] - -[APIPackages.node] - Routes = [ - # /node/status will return all metrics stored inside a node - { Name = "/status", Open = true }, - - # /node/metrics will return all metrics stored inside a node in the format that Prometheus expects them - { Name = "/metrics", Open = true }, - - # /node/heartbeatstatus will return all heartbeats messages from the nodes in the network - { Name = "/heartbeatstatus", Open = true }, - - # /node/p2pstatus will return the metrics related to p2p - { Name = "/p2pstatus", Open = true }, - - # /node/debug will return the debug information after the query has been interpreted - { Name = "/debug", Open = true }, - - # /node/peerinfo will return the p2p peer info of the provided pid - { Name = "/peerinfo", Open = true }, - - # /node/epoch-start/:epoch will return the epoch start data for a given epoch - { Name = "/epoch-start/:epoch", Open = true }, - - # /node/bootstrapstatus will return all metrics available during bootstrap - { Name = "/bootstrapstatus", Open = true }, - - # /node/connected-peers-ratings will return the peers ratings - { Name = "/connected-peers-ratings", Open = true }, - - # /node/managed-keys will return the keys managed by the node - { Name = "/managed-keys", Open = true }, - - # /node/loaded-keys will return the keys loaded by the node - { Name = "/loaded-keys", Open = true }, - - # /node/managed-keys/count will return the number of keys managed by the node - { Name = "/managed-keys/count", Open = true }, - - # /node/managed-keys/eligible will return the eligible keys managed by the node on the current epoch - { Name = "/managed-keys/eligible", Open = true }, - - # /node/managed-keys/waiting will return the waiting keys managed by the node on the current epoch - { Name = "/managed-keys/waiting", Open = true }, - - # /waiting-epochs-left/:key will return the number of epochs left in waiting state for the provided key - { Name = "/waiting-epochs-left/:key", Open = true } - ] - -[APIPackages.address] - Routes = [ - # /address/:address will return data about a given account - { Name = "/:address", Open = true }, - - # /address/bulk will return the state of the accounts provided in the bulk - { Name = "/bulk", Open = true }, - - # /address/:address/balance will return the balance of a given account - { Name = "/:address/balance", Open = true }, - - # /address/:address/username will return the username of a given account - { Name = "/:address/username", Open = true }, - - # /address/:address/code-hash will return the code hash of a given account - { Name = "/:address/code-hash", Open = true }, - - # /address/:address/keys will return all the key-value pairs of a given account - { Name = "/:address/keys", Open = true }, - - # /address/:address/key/:key will return the value of a key for a given account - { Name = "/:address/key/:key", Open = true }, - - # /:address/guardian-data will return the guardian data for the given account - { Name = "/:address/guardian-data", Open = true}, - - # /address/:address/esdt will return the list of esdt tokens for a given account - { Name = "/:address/esdt", Open = true }, - - # /:address/esdts/roles will return the list of esdt tokens and roles for a given account - { Name = "/:address/esdts/roles", Open = true }, - - # /address/:address/esdt/:tokenIdentifier will return the balance for a given account and esdt tokenID - { Name = "/:address/esdt/:tokenIdentifier", Open = true }, - - # /address/:address/nft/:tokenIdentifier/nonce/:nonce will return data of an nft esdt token for a given account, tokenID and nonce - { Name = "/:address/nft/:tokenIdentifier/nonce/:nonce", Open = true }, - - # /address/:address/esdts-with-role/:role will return the token identifiers with the given role for an address - { Name = "/:address/esdts-with-role/:role", Open = true }, - - # /address/:address/registered-nfts will return the token identifiers of the tokens registered by the address - { Name = "/:address/registered-nfts", Open = true }, - - # /address/:address/is-data-trie-migrated will return the status of the data trie migration for the given address - { Name = "/:address/is-data-trie-migrated", Open = true } - ] - -[APIPackages.hardfork] - Routes = [ - # /hardfork/trigger will receive a trigger request from the client and propagate it for processing - { Name = "/trigger", Open = true } - ] - -[APIPackages.network] - Routes = [ - # /network/status will return metrics related to current status of the chain (epoch, nonce, round) - { Name = "/status", Open = true }, - - # /network/economics will return all economics related metrics - { Name = "/economics", Open = true }, - - # /network/config will return metrics related to current configuration of the network (number of shards, - # consensus group size and so on) - { Name = "/config", Open = true }, - - # /network/enable-epochs will return metrics related to activation epochs - { Name = "/enable-epochs", Open = true }, - - # /network/esdts will return all the issued esdts on the protocol - { Name = "/esdts", Open = true }, - - # /network/fungible-tokens will return all the issued fungible tokens on the protocol - { Name = "/esdt/fungible-tokens", Open = true }, - - # /network/semi-fungible-tokens will return all the issued semi fungible tokens on the protocol - { Name = "/esdt/semi-fungible-tokens", Open = true }, - - # /network/non-fungible-tokens will return all the issued non fungible tokens on the protocol - { Name = "/esdt/non-fungible-tokens", Open = true }, - - # /network/esdt/supply/:token will return the supply for a given token - { Name = "/esdt/supply/:token", Open = true }, - - # /network/direct-staked-info will return a list containing direct staked list of addresses - # and their staked values - { Name = "/direct-staked-info", Open = true}, - - # /network/delegated-info will return a list containing delegated list of addresses - # and their staked values on the system delegation smart contracts - { Name = "/delegated-info", Open = true}, - - # /network/ratings will return metrics related to ratings config - { Name = "/ratings", Open = true }, - - # /network/genesis-nodes will return the genesis nodes public keys - { Name = "/genesis-nodes", Open = true }, - - # /network/genesis-balances will return the balances minted at genesis - { Name = "/genesis-balances", Open = true }, - - # /network/gas-configs will return currently scheduled gas configs - { Name = "/gas-configs", Open = true } - ] - -[APIPackages.log] - Routes = [ - # /log will handle sending the log information - { Name = "/log", Open = true } - ] - -[APIPackages.validator] - Routes = [ - # /validator/statistics will return a list of validators statistics for all validators - { Name = "/statistics", Open = true } - ] - -[APIPackages.vm-values] - Routes = [ - # /vm-values/hex will return the data as bytes in hex format - { Name = "/hex", Open = true }, - - # /vm-values/string will return the data in string format - { Name = "/string", Open = true }, - - # /vm-values/int will return the data as big int - { Name = "/int", Open = true }, - - # /vm-values/query will return the data in string format - { Name = "/query", Open = true } - ] - -[APIPackages.transaction] - Routes = [ - # /transaction/send will receive a single transaction in JSON format and will propagate it through the network - # if it's fields are valid. It will return the hash of the transaction - { Name = "/send", Open = true }, - - # /transaction/simulate will receive a single transaction in JSON format and will simulate it's execution - # in order to check that it will be successfully executed when sending it for propagation - { Name = "/simulate", Open = true }, - - # /transaction/send-multiple will receive an array of transactions in JSON format and will propagate through - # the network those whose fields are valid. It will return the number of valid transactions propagated - { Name = "/send-multiple", Open = true }, - - # /transaction/cost will receive a single transaction in JSON format and will return the estimated cost of it - { Name = "/cost", Open = true }, - - # /transaction/pool will return the hashes of the transactions that are currently in the pool - # /transaction/pool?fields=sender,receiver,gaslimit,gasprice will return hashes and all the optional fields mentioned that are currently in the pool - # /transaction/pool?by-sender=erd1... will return the hashes of the transactions that are currently in the pool for the sender - # /transaction/pool?by-sender=erd1...&fields=sender,receiver,gaslimit,gasprice will return the hashes and all the optional fields mentioned of the transactions that are currently in the pool for the sender - # /transaction/pool?by-sender=erd1...&last-nonce=true will return the last nonce for the sender from the pool - # /transaction/pool?by-sender=erd1...&nonce-gaps=true will return all nonce gaps for the sender from the pool, if applicable - { Name = "/pool", Open = true }, - - # /transaction/:txhash will return the transaction in JSON format based on its hash - { Name = "/:txhash", Open = true }, - ] - -[APIPackages.block] - Routes = [ - # /block/by-nonce/:nonce will return the block in JSON format based on its nonce - { Name = "/by-nonce/:nonce", Open = true }, - - # /block/by-hash/:hash will return the block in JSON format based on its hash - { Name = "/by-hash/:hash", Open = true }, - - # /block/by-round/:round will return the block in JSON format based on round - { Name = "/by-round/:round", Open = true }, - - # /altered-accounts/by-nonce/:nonce will return the altered accounts of a block with the provided nonce - { Name = "/altered-accounts/by-nonce/:nonce", Open = true }, - - # /altered-accounts/by-hash/:hash will return the altered accounts of a block with the provided hash - { Name = "/altered-accounts/by-hash/:hash", Open = true } - ] - -[APIPackages.internal] - Routes = [ - # /internal/raw/metablock/by-nonce/:nonce will return the meta block in raw format based on its nonce - { Name = "/raw/metablock/by-nonce/:nonce", Open = true }, - - # /internal/raw/metablock/by-hash/:hash will return the meta block in raw format based on its hash - { Name = "/raw/metablock/by-hash/:hash", Open = true }, - - # /internal/raw/metablock/by-round/:round will return the meta block in raw format based on round - { Name = "/raw/metablock/by-round/:round", Open = true }, - - # /internal/raw/startofepoch/metablock/by-epoch/:epoch will return the start of epoch meta block in raw format based on epoch - { Name = "/raw/startofepoch/metablock/by-epoch/:epoch", Open = true }, - - # /internal/raw/shardblock/by-nonce/:nonce will return the shard block in raw format based on its nonce - { Name = "/raw/shardblock/by-nonce/:nonce", Open = true }, - - # /internal/raw/shardblock/by-hash/:hash will return the shard block in raw format based on its hash - { Name = "/raw/shardblock/by-hash/:hash", Open = true }, - - # /internal/raw/shardblock/by-round/:round will return the shard block in raw format based on round - { Name = "/raw/shardblock/by-round/:round", Open = true }, - - # /internal/json/metablock/by-round/:nonce will return the meta block in JSON format based on nonce - { Name = "/json/metablock/by-nonce/:nonce", Open = true }, - - # /internal/json/metablock/by-round/:hash will return the meta block in JSON format based on hash - { Name = "/json/metablock/by-hash/:hash", Open = true }, - - # /internal/json/metablock/by-round/:round will return the meta block in JSON format based on roud - { Name = "/json/metablock/by-round/:round", Open = true }, - - # /internal/json/startofepoch/metablock/by-epoch/:epoch will return the start of epoch meta block in json format based on epoch - { Name = "/json/startofepoch/metablock/by-epoch/:epoch", Open = true }, - - # /internal/json/shardblock/by-round/:nonce will return the shard block in JSON format based on nonce - { Name = "/json/shardblock/by-nonce/:nonce", Open = true }, - - # /internal/json/shardblock/by-round/:hash will return the shard block in JSON format based on hash - { Name = "/json/shardblock/by-hash/:hash", Open = true }, - - # /internal/json/shardblock/by-round/:round will return the shard block in JSON format based on round - { Name = "/json/shardblock/by-round/:round", Open = true }, - - # /internal/raw/miniblock/by-hash/:hash will return the miniblock in raw format based on hash for a specified epoch - { Name = "/raw/miniblock/by-hash/:hash/epoch/:epoch", Open = true }, - - # /internal/json/miniblock/by-hash/:hash will return the miniblock in JSON format based on hash for a specified epoch - { Name = "/json/miniblock/by-hash/:hash/epoch/:epoch", Open = true }, - - # /internal/raw/startofepoch/validators/by-epoch/:epoch will return the start of epoch validators info in json format based on epoch - { Name = "/json/startofepoch/validators/by-epoch/:epoch", Open = true } - - ] - -[APIPackages.proof] - Routes = [ - # /proof/root-hash/:roothash/address/:address will compute and return the proof in JSON format - { Name = "/root-hash/:roothash/address/:address", Open = true }, - - # /proof/root-hash/:roothash/address/:address/key/:key will compute and return the proof in JSON format - { Name = "/root-hash/:roothash/address/:address/key/:key", Open = true }, - - # /proof/address/:address will compute and return the proof and root hash in JSON format - { Name = "/address/:address", Open = true }, - - # /proof/verify will return the response from Merkle proof verification in JSON format - { Name = "/verify", Open = true }, - ] diff --git a/integrationTests/relayers/testdata/config/nodeConfig/config.toml b/integrationTests/relayers/testdata/config/nodeConfig/config.toml deleted file mode 100644 index b6c11452..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/config.toml +++ /dev/null @@ -1,942 +0,0 @@ -# GeneralSettings section of the node -[GeneralSettings] - # StatusPollingIntervalSec represents the no of seconds between multiple polling for the status for AppStatusHandler - StatusPollingIntervalSec = 2 - - # MaxComputableRounds represents the max number of rounds computable in a round - # by the validator statistics processor - MaxComputableRounds = 100 - - # StartInEpochEnabled represents that the fast bootstrap mechanism from the network is enabled if data is not - # available in local disk - StartInEpochEnabled = true - - # ChainID represents the chain identifier - # The currently supported constants are: - # "1" for Mainnet - # "D" for Devnet - # "T" for Testnet - ChainID = "undefined" - - # MinTransactionVersion represents the minimum transaction version accepted - MinTransactionVersion = 1 - - # GenesisString represents the encoded string for the genesis block - GenesisString = "67656E65736973" - - # GenesisMaxNumberOfShards represents the maximum number of shards to be created at genesis (excluding metaChain shard) - GenesisMaxNumberOfShards = 3 - - # MaxConsecutiveRoundsOfRatingDecrease represents the max number of consecutive rounds in which a block is not proposed - # on a shard and the validators' rating could be decreased. If, for instance, a shard gets stuck for more rounds - # than this value, then the validators rating decrease should stop so they won't get jailed - MaxConsecutiveRoundsOfRatingDecrease = 600 - - # SyncProcessTimeInMillis is the value in milliseconds used when processing blocks while synchronizing blocks - SyncProcessTimeInMillis = 12000 - - # SetGuardianEpochsDelay represents the delay in epochs between the execution time of the SetGuardian transaction and - # the activation of the configured guardian. - # Make sure that this is greater than the unbonding period! - SetGuardianEpochsDelay = 2 # TODO: for mainnet should be 20, 2 is just for testing - -[HardwareRequirements] - CPUFlags = ["SSE4", "SSE42"] - -[Versions] - DefaultVersion = "default" - VersionsByEpochs = [ - { StartEpoch = 0, Version = "*" }, - # The value of StartEpoch parameter for version 2 should be the same with the ScheduledMiniBlocksEnableEpoch flag from enableEpoch.toml file - { StartEpoch = 1, Version = "2" }, - ] - [Versions.Cache] - Name = "VersionsCache" - Capacity = 100 - Type = "LRU" - -[StoragePruning] - # If the Enabled flag is set to false, then the storers won't divide epochs into separate dbs - Enabled = true - - # If this flag is set to false, the node won't delete any database between epochs - # Applicable only for validators - ValidatorCleanOldEpochsData = true - - # If this flag is set to false, the node won't delete any database between epochs - # Applicable only for observers - ObserverCleanOldEpochsData = false - - # If this flag is set to false, the node won't delete the AccountsTrie database for old epochs - # Applicable for both observers and validators - # WARNING! Setting this to false will increase each epoch's directory size with the trie snapshot, - # which might easily cause the node to run out of disk space. - AccountsTrieCleanOldEpochsData = true - - # AccountsTrieSkipRemovalCustomPattern represents the custom pattern that determines when AccountsTrie database - # doesn't have to be cleaned - # Format: %x,%y - if an epoch is divisible by x or by y, then the AccountsTrie database won't be removed - # If empty, then all databases will be removed - # If invalid format, then an error will be returned - # Applicable only if AccountsTrieCleanOldEpochsData is set to true - AccountsTrieSkipRemovalCustomPattern = "%50" - - # NumEpochsToKeep - if the flag above is set to true, this will set the number of epochs to keep in the storage. - # Epochs older that (current epoch - NumOfEpochsToKeep) will be removed - NumEpochsToKeep = 4 - - # NumActivePersisters - this will set the number of persisters to keep active at a moment. This works even if - # the node removes old epochs data or not. In case of a node which removes old epochs data, this value has to be - # smaller or equal to the NumOfEpochsToKeep flag - NumActivePersisters = 3 - - # FullArchiveNumActivePersisters represents the number of persisters to be kept in cache as to allow better response - # to inquiring peers. This value will get multiplied by the number of persisters required by the node to function so - # it is a good idea to increase the maximum number of opened files allowed by the operating system - FullArchiveNumActivePersisters = 10 - -[MiniBlocksStorage] - [MiniBlocksStorage.Cache] - Name = "MiniBlocksStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 104857600 #100MB - [MiniBlocksStorage.DB] - FilePath = "MiniBlocks" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[ReceiptsStorage] - [ReceiptsStorage.Cache] - Name = "ReceiptsStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 10485760 #10MB - [ReceiptsStorage.DB] - FilePath = "Receipts" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[ScheduledSCRsStorage] - [ScheduledSCRsStorage.Cache] - Name = "ScheduledSCRsStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 10485760 #10MB - [ScheduledSCRsStorage.DB] - FilePath = "ScheduledSCRs" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[PeerBlockBodyStorage] - [PeerBlockBodyStorage.Cache] - Name = "PeerBlockBodyStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 104857600 #100MB - [PeerBlockBodyStorage.DB] - FilePath = "PeerBlocks" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[BlockHeaderStorage] - [BlockHeaderStorage.Cache] - Name = "BlockHeaderStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 3145728 #3MB - [BlockHeaderStorage.DB] - FilePath = "BlockHeaders" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[BootstrapStorage] - [BootstrapStorage.Cache] - Name = "BootstrapStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 104857600 #100MB - [BootstrapStorage.DB] - FilePath = "BootstrapData" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[MetaBlockStorage] - [MetaBlockStorage.Cache] - Name = "MetaBlockStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 20971520 #20MB - [MetaBlockStorage.DB] - FilePath = "MetaBlock" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[TxStorage] - [TxStorage.Cache] - Name = "TxStorage" - Capacity = 500000 - Type = "SizeLRU" - SizeInBytes = 209715200 #200MB - [TxStorage.DB] - FilePath = "Transactions" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 30000 - MaxOpenFiles = 10 - -[UnsignedTransactionStorage] - [UnsignedTransactionStorage.Cache] - Name = "UnsignedTransactionStorage" - Capacity = 250000 - Type = "SizeLRU" - SizeInBytes = 104857600 #100MB - [UnsignedTransactionStorage.DB] - FilePath = "UnsignedTransactions" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - -[RewardTxStorage] - [RewardTxStorage.Cache] - Name = "RewardTxStorage" - Capacity = 75000 - Type = "SizeLRU" - SizeInBytes = 52428800 #50MB - [RewardTxStorage.DB] - FilePath = "RewardTransactions" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - -[SmartContractsStorage] - [SmartContractsStorage.Cache] - Name = "SmartContractsStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 52428800 #50MB - [SmartContractsStorage.DB] - FilePath = "SmartContractsStorage" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[SmartContractsStorageSimulate] - [SmartContractsStorageSimulate.Cache] - Name = "SmartContractsStorageSimulate" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 52428800 #50MB - [SmartContractsStorageSimulate.DB] - FilePath = "SmartContractsStorageSimulate" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[SmartContractsStorageForSCQuery] - [SmartContractsStorageForSCQuery.Cache] - Name = "SmartContractsStorageForSCQuery" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 52428800 #50MB - [SmartContractsStorageForSCQuery.DB] - FilePath = "SmartContractsStorageForSCQuery" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[StatusMetricsStorage] - [StatusMetricsStorage.Cache] - Name = "StatusMetricsStorage" - Capacity = 1000 - Type = "LRU" - [StatusMetricsStorage.DB] - FilePath = "StatusMetricsStorageDB" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[TrieEpochRootHashStorage] - [TrieEpochRootHashStorage.Cache] - Name = "TrieEpochRootHashCache" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 314572800 #300MB - [TrieEpochRootHashStorage.DB] - FilePath = "TrieEpochRootHashStorageDB" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 500 - MaxOpenFiles = 10 - -[ShardHdrNonceHashStorage] - [ShardHdrNonceHashStorage.Cache] - Name = "ShardHdrNonceHashStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 3145728 #3MB - [ShardHdrNonceHashStorage.DB] - FilePath = "ShardHdrHashNonce" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[MetaHdrNonceHashStorage] - [MetaHdrNonceHashStorage.Cache] - Name = "MetaHdrNonceHashStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 3145728 #3MB - [MetaHdrNonceHashStorage.DB] - FilePath = "MetaHdrHashNonce" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[AccountsTrieStorage] - [AccountsTrieStorage.Cache] - Name = "AccountsTrieStorage" - Capacity = 500000 - Type = "SizeLRU" - SizeInBytes = 314572800 #300MB - [AccountsTrieStorage.DB] - FilePath = "AccountsTrie" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 45000 - MaxOpenFiles = 10 - ShardIDProviderType = "BinarySplit" - NumShards = 4 - -[PeerAccountsTrieStorage] - [PeerAccountsTrieStorage.Cache] - Name = "PeerAccountsTrieStorage" - Capacity = 5000 - Type = "SizeLRU" - SizeInBytes = 104857600 #100MB - [PeerAccountsTrieStorage.DB] - FilePath = "PeerAccountsTrie" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 1000 - MaxOpenFiles = 10 - ShardIDProviderType = "BinarySplit" - NumShards = 4 - -[EvictionWaitingList] - #total max size ~ 2 * [(RoothashesSize * 32) + (HashesSize * 32)] - RootHashesSize = 10000 - HashesSize = 100000 - [EvictionWaitingList.DB] - FilePath = "EvictionWaitingList" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[TrieStorageManagerConfig] - PruningBufferLen = 100000 - SnapshotsBufferLen = 1000000 - SnapshotsGoroutineNum = 200 - -[HeadersPoolConfig] - MaxHeadersPerShard = 1000 - NumElementsToRemoveOnEviction = 200 - -[BadBlocksCache] - Name = "BadBlocksCache" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 3145728 #3MB - -[TxBlockBodyDataPool] - Name = "TxBlockBodyDataPool" - Capacity = 100000 - Type = "SizeLRU" - SizeInBytes = 314572800 #300MB - -[PeerBlockBodyDataPool] - Name = "PeerBlockBodyDataPool" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 314572800 #300MB - -[TxDataPool] - Name = "TxDataPool" - Capacity = 600000 - SizePerSender = 20000 - SizeInBytes = 419430400 #400MB - SizeInBytesPerSender = 12288000 - Type = "TxCache" - Shards = 16 - -[TrieNodesChunksDataPool] - Name = "TrieNodesDataPool" - Capacity = 400 - Type = "SizeLRU" - SizeInBytes = 104857600 #100MB - -[SmartContractDataPool] - Name = "SmartContractDataPool" - Capacity = 900000 - Type = "SizeLRU" - SizeInBytes = 209715200 #200MB - -[WhiteListPool] - Name = "WhiteListPool" - Capacity = 100000 - Type = "FIFOSharded" - Shards = 10 - -[WhiteListerVerifiedTxs] - Name = "WhiteListerVerifiedTxs" - Capacity = 50000 - Type = "FIFOSharded" - Shards = 50 - -[UnsignedTransactionDataPool] - Name = "UnsignedTransactionDataPool" - Capacity = 75000 # per each pair (sourceShard, destinationShard) - SizeInBytes = 31457280 # 30MB per each pair (sourceShard, destinationShard) - Shards = 4 - -[RewardTransactionDataPool] - Name = "RewardTransactionDataPool" - Capacity = 75000 # per each pair (metachain, destinationShard) - SizeInBytes = 26214400 # 25MB per each pair (metachain, destinationShard) - Shards = 4 - -[ValidatorInfoPool] - Name = "ValidatorInfoPool" - Capacity = 10000 - SizeInBytes = 31457280 #30MB - Shards = 4 - -#PublicKeyPeerId represents the main cache used to map MultiversX block signing public keys to their associated peer id's. -[PublicKeyPeerId] - Name = "PublicKeyPeerId" - Capacity = 30000 - Type = "LRU" - -#PublicKeyShardId is the fallback cache used to map public keys to the shard they belong. -[PublicKeyShardId] - Name = "PublicKeyShardId" - Capacity = 30000 - Type = "LRU" - -#PublicKeyPIDSignature is the cache that is used to map a public key to a peerId-signature pair. -[PublicKeyPIDSignature] - Name = "PublicKeyPIDSignature" - Capacity = 3000 - Type = "LRU" - -#PeerIdShardId is the fallback cache used in network sharding to allow direct connection between peer id and shard. -# Used mainly for observers. -[PeerIdShardId] - Name = "PeerIdShardId" - Capacity = 30000 - Type = "LRU" - -[PeerHonesty] - Name = "PeerHonesty" - Capacity = 5000 - Type = "LRU" - -[VMOutputCacher] - Name = "VMOutputCacher" - Capacity = 10000 - Type = "LRU" - -[PeersRatingConfig] - TopRatedCacheCapacity = 5000 - BadRatedCacheCapacity = 5000 - -[PoolsCleanersConfig] - MaxRoundsToKeepUnprocessedMiniBlocks = 300 # max number of rounds unprocessed miniblocks are kept in pool - MaxRoundsToKeepUnprocessedTransactions = 300 # max number of rounds unprocessed transactions are kept in pool - -[TrieSyncStorage] - Capacity = 300000 - SizeInBytes = 104857600 #100MB - EnableDB = false - [TrieSyncStorage.DB] - FilePath = "TrieSyncStorageDB" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 45000 - MaxOpenFiles = 10 - UseTmpAsFilePath = true - -[Antiflood] - Enabled = true - NumConcurrentResolverJobs = 50 - NumConcurrentResolvingTrieNodesJobs = 3 - [Antiflood.FastReacting] - IntervalInSeconds = 1 - ReservedPercent = 20.0 - [Antiflood.FastReacting.PeerMaxInput] - BaseMessagesPerInterval = 140 - TotalSizePerInterval = 4194304 #4MB/s - [Antiflood.FastReacting.PeerMaxInput.IncreaseFactor] - Threshold = 10 #if consensus size will exceed this value, then - Factor = 1.0 #increase the base value with [factor*consensus size] - [Antiflood.FastReacting.BlackList] - ThresholdNumMessagesPerInterval = 1000 - ThresholdSizePerInterval = 8388608 #8MB/s - NumFloodingRounds = 10 - PeerBanDurationInSeconds = 300 - - [Antiflood.SlowReacting] - IntervalInSeconds = 30 - ReservedPercent = 20.0 - [Antiflood.SlowReacting.PeerMaxInput] - BaseMessagesPerInterval = 6000 - TotalSizePerInterval = 18874368 # 18MB/interval - [Antiflood.SlowReacting.PeerMaxInput.IncreaseFactor] - Threshold = 10 #if consensus size will exceed this value, then - Factor = 0.0 #increase the base value with [factor*consensus size] - [Antiflood.SlowReacting.BlackList] - ThresholdNumMessagesPerInterval = 10000 - ThresholdSizePerInterval = 37748736 # 36MB/interval - NumFloodingRounds = 2 - PeerBanDurationInSeconds = 3600 - - [Antiflood.OutOfSpecs] - IntervalInSeconds = 1 - ReservedPercent = 0.0 - [Antiflood.OutOfSpecs.PeerMaxInput] - BaseMessagesPerInterval = 2000 - TotalSizePerInterval = 10485760 # 10MB/interval - [Antiflood.OutOfSpecs.PeerMaxInput.IncreaseFactor] - Threshold = 0 #if consensus size will exceed this value, then - Factor = 0.0 #increase the base value with [factor*consensus size] - [Antiflood.OutOfSpecs.BlackList] - ThresholdNumMessagesPerInterval = 3600 - ThresholdSizePerInterval = 12582912 # 12MB/interval - NumFloodingRounds = 2 - PeerBanDurationInSeconds = 3600 - - [Antiflood.PeerMaxOutput] - BaseMessagesPerInterval = 75 - TotalSizePerInterval = 2097152 #2MB/s - - [Antiflood.Cache] - Name = "Antiflood" - Capacity = 7000 - Type = "LRU" - [Antiflood.Topic] - DefaultMaxMessagesPerSec = 15000 - MaxMessages = [{ Topic = "shardBlocks*", NumMessagesPerSec = 30 }, - { Topic = "metachainBlocks", NumMessagesPerSec = 30 }] - - [Antiflood.TxAccumulator] - # MaxAllowedTimeInMilliseconds is used as a time frame in which the node gathers transactions. - # After this period, collected transactions will be sent on the p2p topics - MaxAllowedTimeInMilliseconds = 250 - # MaxDeviationTimeInMilliseconds represents the time in miliseconds that will cause the effectual time frame be - # less than the specified max value. This is used to create desynchronizations between senders as to not - # clutter the network exactly in the same moment - MaxDeviationTimeInMilliseconds = 25 - -[WebServerAntiflood] - WebServerAntifloodEnabled = true - # SimultaneousRequests represents the number of concurrent requests accepted by the web server - # this is a global throttler that acts on all http connections regardless of the originating source - SimultaneousRequests = 100 - # SameSourceRequests defines how many requests are allowed from the same source in the specified - # time frame (SameSourceResetIntervalInSec) - SameSourceRequests = 10000 - # SameSourceResetIntervalInSec time frame between counter reset, in seconds - SameSourceResetIntervalInSec = 1 - # TrieOperationsDeadlineMilliseconds represents the maximum duration that an API call targeting a trie operation - # can take. - TrieOperationsDeadlineMilliseconds = 10000 - # GetAddressesBulkMaxSize represents the maximum number of addresses to be fetched in a bulk per API request. 0 means unlimited - GetAddressesBulkMaxSize = 100 - # VmQueryDelayAfterStartInSec represents the number of seconds to wait when starting node before accepting vm query requests - VmQueryDelayAfterStartInSec = 120 - # EndpointsThrottlers represents a map for maximum simultaneous go routines for an endpoint - EndpointsThrottlers = [{ Endpoint = "/transaction/:hash", MaxNumGoRoutines = 10 }, - { Endpoint = "/transaction/send", MaxNumGoRoutines = 2 }, - { Endpoint = "/transaction/simulate", MaxNumGoRoutines = 1 }, - { Endpoint = "/transaction/send-multiple", MaxNumGoRoutines = 2 }] - -[AddressPubkeyConverter] - Length = 32 - Type = "bech32" - SignatureLength = 64 - Hrp = "erd" - -[ValidatorPubkeyConverter] - Length = 96 - Type = "hex" - SignatureLength = 48 - -[Hasher] - Type = "blake2b" - -[MultisigHasher] - Type = "blake2b" - -[TxSignHasher] - Type = "keccak" - -# The main marshalizer, used in internodes communication -# Type identifies the marshalizer -# SizeCheckDelta the maximum allow drift between the input data buffer and -# the reencoded version (in percents). -# 0 disables the feature. -[Marshalizer] - Type = "gogo protobuf" - SizeCheckDelta = 10 - -# The marshalizer used for smartcontracts data exchange -[VmMarshalizer] - Type = "json" - -# The marshalizer used in transaction signing -[TxSignMarshalizer] - Type = "json" - -[EpochStartConfig] - GenesisEpoch = 0 - MinRoundsBetweenEpochs = 20 - RoundsPerEpoch = 200 - # Min and Max ShuffledOutRestartThreshold represents the minimum and maximum duration of an epoch (in percentage) after a node which - # has been shuffled out has to restart its process in order to start in a new shard - MinShuffledOutRestartThreshold = 0.05 - MaxShuffledOutRestartThreshold = 0.25 - - MinNumConnectedPeersToStart = 2 - MinNumOfPeersToConsiderBlockValid = 2 - ExtraDelayForRequestBlockInfoInMilliseconds = 3000 - -# ResourceStats, if enabled, will output in a folder called "stats" -# resource statistics. For example: number of active go routines, memory allocation, number of GC sweeps, etc. -# RefreshIntervalInSec will tell how often a new line containing stats should be added in stats file -[ResourceStats] - Enabled = true - RefreshIntervalInSec = 30 - -[ValidatorStatistics] - CacheRefreshIntervalInSec = 60 - -# Consensus type which will be used (the current implementation can manage "bn" and "bls") -# When consensus type is "bls" the multisig hasher type should be "blake2b" -[Consensus] - Type = "bls" - -[NTPConfig] - Hosts = ["time.google.com", "time.cloudflare.com", "time.apple.com"] - Port = 123 - TimeoutMilliseconds = 100 - SyncPeriodSeconds = 3600 - Version = 0 # Setting 0 means 'use default value' - -[StateTriesConfig] - SnapshotsEnabled = true - AccountsStatePruningEnabled = false - PeerStatePruningEnabled = true - MaxStateTrieLevelInMemory = 5 - MaxPeerTrieLevelInMemory = 5 - StateStatisticsEnabled = false - -[BlockSizeThrottleConfig] - MinSizeInBytes = 104857 # 104857 is 10% from 1MB - MaxSizeInBytes = 943718 # 943718 is 90% from 1MB - -[VirtualMachine] - [VirtualMachine.Execution] - TimeOutForSCExecutionInMilliseconds = 10000 # 10 seconds = 10000 milliseconds - WasmerSIGSEGVPassthrough = false # must be false for release - WasmVMVersions = [ - { StartEpoch = 0, Version = "v1.4" }, - { StartEpoch = 1, Version = "v1.5" }, # TODO: set also the RoundActivations.DisableAsyncCallV1 accordingly - ] - - [VirtualMachine.Querying] - NumConcurrentVMs = 1 - TimeOutForSCExecutionInMilliseconds = 10000 # 10 seconds = 10000 milliseconds - WasmerSIGSEGVPassthrough = false # must be false for release - WasmVMVersions = [ - { StartEpoch = 0, Version = "v1.4" }, - { StartEpoch = 1, Version = "v1.5" }, # TODO: set also the RoundActivations.DisableAsyncCallV1 accordingly - ] - - [VirtualMachine.GasConfig] - # The following values define the maximum amount of gas to be allocated for VM Queries coming from API - # If set to 0, then MaxUInt64 will be used - ShardMaxGasPerVmQuery = 1500000000 #1.5b - MetaMaxGasPerVmQuery = 0 #unlimited - -[BuiltInFunctions] - AutomaticCrawlerAddresses =[ - "erd1he8wwxn4az3j82p7wwqsdk794dm7hcrwny6f8dfegkfla34udx7qrf7xje", #shard 0 - "erd1fpkcgel4gcmh8zqqdt043yfcn5tyx8373kg6q2qmkxzu4dqamc0swts65c", #shard 1 - "erd1najnxxweyw6plhg8efql330nttrj6l5cf87wqsuym85s9ha0hmdqnqgenp", #shard 2 - ] - MaxNumAddressesInTransferRole = 100 - DNSV2Addresses =[ - "erd1qqqqqqqqqqqqqpgqr46jrxr6r2unaqh75ugd308dwx5vgnhwh47qtvepe3", - ] - -[Hardfork] - EnableTrigger = true - EnableTriggerFromP2P = true - PublicKeyToListenFrom = "153dae6cb3963260f309959bf285537b77ae16d82e9933147be7827f7394de8dc97d9d9af41e970bc72aecb44b77e819621081658c37f7000d21e2d0e8963df83233407bde9f46369ba4fcd03b57f40b80b06c191a428cfb5c447ec510e79307" - CloseAfterExportInMinutes = 10000 - AfterHardFork = false - ImportFolder = "export" - StartRound = 10000 - StartNonce = 10000 - StartEpoch = 100 - GenesisTime = 0 - ValidatorGracePeriodInEpochs = 1 #defines how long is the rating computation disabled after hardfork - [Hardfork.ExportStateStorageConfig] - [Hardfork.ExportStateStorageConfig.Cache] - Name = "HardFork.ExportStateStorageConfig" - Capacity = 5000 - Type = "LRU" - [Hardfork.ExportStateStorageConfig.DB] - FilePath = "ExportStateStorage/MainDB" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 1000 - MaxOpenFiles = 10 - [Hardfork.ExportKeysStorageConfig] - [Hardfork.ExportKeysStorageConfig.Cache] - Name = "HardFork.ExportKeysStorageConfig" - Capacity = 5000 - Type = "LRU" - [Hardfork.ExportKeysStorageConfig.DB] - FilePath = "ExportKeysStorageConfig/MainDB" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 1000 - MaxOpenFiles = 10 - [Hardfork.ExportTriesStorageConfig] - [Hardfork.ExportTriesStorageConfig.Cache] - Name = "HardFork.ExportTriesStorageConfig" - Capacity = 5000 - Type = "LRU" - [Hardfork.ExportTriesStorageConfig.DB] - FilePath = "ExportTrieStorage/MainTrie" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 1000 - MaxOpenFiles = 10 - [Hardfork.ImportStateStorageConfig] - [Hardfork.ImportStateStorageConfig.Cache] - Name = "HardFork.ImportStateStorageConfig" - Capacity = 5000 - Type = "LRU" - [Hardfork.ImportStateStorageConfig.DB] - FilePath = "ExportStateStorage/MainDB" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 1000 - MaxOpenFiles = 10 - [Hardfork.ImportKeysStorageConfig] - [Hardfork.ImportKeysStorageConfig.Cache] - Name = "HardFork.ImportKeysStorageConfig" - Capacity = 5000 - Type = "LRU" - [Hardfork.ImportKeysStorageConfig.DB] - FilePath = "ExportKeysStorageConfig/MainDB" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 1000 - MaxOpenFiles = 10 - -[Debug] - [Debug.InterceptorResolver] - Enabled = true - CacheSize = 10000 - EnablePrint = true - IntervalAutoPrintInSeconds = 20 - NumRequestsThreshold = 9 - NumResolveFailureThreshold = 3 - DebugLineExpiration = 10 #Will remove the debug line after a `DebugLineExpiration` number of prints - [Debug.Antiflood] - Enabled = true - CacheSize = 10000 - IntervalAutoPrintInSeconds = 20 - [Debug.ShuffleOut] - CallGCWhenShuffleOut = true - ExtraPrintsOnShuffleOut = true - DoProfileOnShuffleOut = true - [Debug.EpochStart] - GoRoutineAnalyserEnabled = true - ProcessDataTrieOnCommitEpoch = true - [Debug.Process] - Enabled = true - DebuggingLogLevel = "*:DEBUG,p2p:TRACE,debug:DEBUG,process:TRACE,intercept:TRACE" - GoRoutinesDump = true - PollingTimeInSeconds = 240 # 4 minutes - # setting this to 0 disables the automatic revert of the log level - RevertLogLevelTimeInSeconds = 600 # 10 minutes - -[Health] - IntervalVerifyMemoryInSeconds = 30 - IntervalDiagnoseComponentsInSeconds = 30 - IntervalDiagnoseComponentsDeeplyInSeconds = 120 - MemoryUsageToCreateProfiles = 3221225472 # 3 GB - NumMemoryUsageRecordsToKeep = 100 - FolderPath = "health-records" - -[SoftwareVersionConfig] - StableTagLocation = "https://api.github.com/repos/multiversx/mx-chain-go/releases/latest" - PollingIntervalInMinutes = 65 - -[GatewayMetricsConfig] - # TODO: set this to gateway URL based on testnet/devnet/mainnet env - URL = "" - -[LogsAndEvents] - SaveInStorageEnabled = false - [LogsAndEvents.TxLogsStorage.Cache] - Name = "TxLogsStorage" - Capacity = 1000 - Type = "SizeLRU" - SizeInBytes = 20971520 #20MB - [LogsAndEvents.TxLogsStorage.DB] - FilePath = "Logs" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 100 - MaxOpenFiles = 10 - -[DbLookupExtensions] - Enabled = false - DbLookupMaxActivePersisters = 10 - [DbLookupExtensions.MiniblocksMetadataStorageConfig.Cache] - Name = "DbLookupExtensions.MiniblocksMetadataStorage" - Capacity = 20000 - Type = "LRU" - [DbLookupExtensions.MiniblocksMetadataStorageConfig.DB] - FilePath = "DbLookupExtensions/MiniblocksMetadata" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - [DbLookupExtensions.MiniblockHashByTxHashStorageConfig.Cache] - Name = "DbLookupExtensions.MiniblockHashByTxHashStorage" - Capacity = 20000 - Type = "LRU" - [DbLookupExtensions.MiniblockHashByTxHashStorageConfig.DB] - FilePath = "DbLookupExtensions_MiniblockHashByTxHash" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - [DbLookupExtensions.EpochByHashStorageConfig.Cache] - Name = "DbLookupExtensions.EpochByHashStorage" - Capacity = 20000 - Type = "LRU" - [DbLookupExtensions.EpochByHashStorageConfig.DB] - FilePath = "DbLookupExtensions_EpochByHash" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - [DbLookupExtensions.ResultsHashesByTxHashStorageConfig.Cache] - Name = "DbLookupExtensions.ResultsHashesByTxHashStorage" - Capacity = 20000 - Type = "LRU" - [DbLookupExtensions.ResultsHashesByTxHashStorageConfig.DB] - FilePath = "DbLookupExtensions_ResultsHashesByTx" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - [DbLookupExtensions.ESDTSuppliesStorageConfig.Cache] - Name = "DbLookupExtensions.ESDTSuppliesStorage" - Capacity = 20000 - Type = "LRU" - [DbLookupExtensions.ESDTSuppliesStorageConfig.DB] - FilePath = "DbLookupExtensions_ESDTSupplies" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - [DbLookupExtensions.RoundHashStorageConfig.Cache] - Name = "DbLookupExtensions.RoundHashStorage" - Capacity = 20000 - Type = "LRU" - [DbLookupExtensions.RoundHashStorageConfig.DB] - FilePath = "DbLookupExtensions_RoundHash" - Type = "LvlDBSerial" - BatchDelaySeconds = 2 - MaxBatchSize = 20000 - MaxOpenFiles = 10 - -[Logs] - LogFileLifeSpanInMB = 1024 # 1GB - LogFileLifeSpanInSec = 86400 # 1 day - -[TrieSync] - NumConcurrentTrieSyncers = 200 - MaxHardCapForMissingNodes = 5000 - #available versions: 1, 2 and 3. 1 is the initial version, 2 is updated, more efficient version employing 2 lists - #the 3-rd one uses depth-first algorithm which keeps the memory consumption low - TrieSyncerVersion = 3 - CheckNodesOnDisk = false - -[Requesters] - NumCrossShardPeers = 2 - NumTotalPeers = 3 # NumCrossShardPeers + num intra shard - NumFullHistoryPeers = 3 - -[HeartbeatV2] - PeerAuthenticationTimeBetweenSendsInSec = 600 # 10min TODO: change this for mainnet/devnet/testnet - PeerAuthenticationTimeBetweenSendsWhenErrorInSec = 60 # 1min - PeerAuthenticationTimeThresholdBetweenSends = 0.1 # 10% # max random threshold between messages, representing a percent of PeerAuthenticationTimeBetweenSendsInSec - HeartbeatTimeBetweenSendsInSec = 60 # 1min - HeartbeatTimeBetweenSendsDuringBootstrapInSec = 60 # 1min - HeartbeatTimeBetweenSendsWhenErrorInSec = 60 # 1min - HeartbeatTimeThresholdBetweenSends = 0.1 # 10% # max random threshold between messages, representing a percent of HeartbeatTimeBetweenSendsInSec - HeartbeatExpiryTimespanInSec = 3600 # 1h # heartbeat message max age allowed - MinPeersThreshold = 0.8 # 80% # min threshold of peers to consider enough peer auths received - DelayBetweenPeerAuthenticationRequestsInSec = 5 # 5sec # delay between requests - PeerAuthenticationMaxTimeoutForRequestsInSec = 7200 # 2h # max timeout allowed to receive peer auth messages from peers - PeerShardTimeBetweenSendsInSec = 7200 # 2h - PeerShardTimeThresholdBetweenSends = 0.1 # 10% # max random threshold between messages, representing a percent of PeerShardTimeBetweenSendsInSec - MaxMissingKeysInRequest = 500 # max number of missing keys allowed in a request - MaxDurationPeerUnresponsiveInSec = 900 # 15min # max duration after which a peer is considered inactive - HideInactiveValidatorIntervalInSec = 3600 # 1h # time that an inactive validator is returned through api - HardforkTimeBetweenSendsInSec = 60 # 1min # time between hardfork messages - TimeBetweenConnectionsMetricsUpdateInSec = 30 # 30sec # time between consecutive connections metrics updates - TimeToReadDirectConnectionsInSec = 15 # 15sec # time between consecutive peer shard mapper updates with direct connections - PeerAuthenticationTimeBetweenChecksInSec = 6 # 6sec - [HeartbeatV2.HeartbeatPool] - Name = "HeartbeatPool" - Capacity = 50000 - Type = "SizeLRU" - SizeInBytes = 314572800 #300MB - -[Redundancy] - # MaxRoundsOfInactivityAccepted defines the number of rounds missed by a main or higher level backup machine before - # the current machine will take over and propose/sign blocks. Used in both single-key and multi-key modes. - MaxRoundsOfInactivityAccepted = 3 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/economics.toml b/integrationTests/relayers/testdata/config/nodeConfig/economics.toml deleted file mode 100644 index f0bac97a..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/economics.toml +++ /dev/null @@ -1,50 +0,0 @@ -#Economics config of the node -[GlobalSettings] - GenesisTotalSupply = "20000000000000000000000000" #20MIL eGLD - MinimumInflation = 0.0 - YearSettings = [ - {Year = 1, MaximumInflation = 0.10845130}, - {Year = 2, MaximumInflation = 0.09703538}, - {Year = 3, MaximumInflation = 0.08561945}, - {Year = 4, MaximumInflation = 0.07420352}, - {Year = 5, MaximumInflation = 0.06278760}, - {Year = 6, MaximumInflation = 0.05137167}, - {Year = 7, MaximumInflation = 0.03995574}, - {Year = 8, MaximumInflation = 0.02853982}, - {Year = 9, MaximumInflation = 0.01712389}, - {Year = 10, MaximumInflation = 0.00570796}, - {Year = 11, MaximumInflation = 0.0}, - ] - Denomination = 18 # represents the smallest eGLD subdivision (10^-X eGLD for a denomination of X) - GenesisMintingSenderAddress = "erd17rc0pu8s7rc0pu8s7rc0pu8s7rc0pu8s7rc0pu8s7rc0pu8s7rcqqkhty3" - -[RewardsSettings] - [[RewardsSettings.RewardsConfigByEpoch]] - EpochEnable = 0 - LeaderPercentage = 0.1 #fraction of value 0.1 - 10% - DeveloperPercentage = 0.3 #fraction of value 0.3 - 30% - ProtocolSustainabilityPercentage = 0.1 #fraction of value 0.1 - 10% - ProtocolSustainabilityAddress = "erd1j25xk97yf820rgdp3mj5scavhjkn6tjyn0t63pmv5qyjj7wxlcfqqe2rw5" - TopUpGradientPoint = "3000000000000000000000000" # 3MIL eGLD (eligible topUp) - TopUpFactor = 0.25 # fraction of value 0.25 - 25% - - [[RewardsSettings.RewardsConfigByEpoch]] - EpochEnable = 1 - LeaderPercentage = 0.1 #fraction of value 0.1 - 10% - DeveloperPercentage = 0.3 #fraction of value 0.3 - 30% - ProtocolSustainabilityPercentage = 0.1 #fraction of value 0.1 - 10% - ProtocolSustainabilityAddress = "erd1j25xk97yf820rgdp3mj5scavhjkn6tjyn0t63pmv5qyjj7wxlcfqqe2rw5" - TopUpGradientPoint = "2000000000000000000000000" # 2MIL eGLD (eligible topUp) - TopUpFactor = 0.5 # fraction of value 0.5 - 50% - -[FeeSettings] - GasLimitSettings = [ - {EnableEpoch = 0, MaxGasLimitPerBlock = "1500000000", MaxGasLimitPerMiniBlock = "1500000000", MaxGasLimitPerMetaBlock = "15000000000", MaxGasLimitPerMetaMiniBlock = "15000000000", MaxGasLimitPerTx = "1500000000", MinGasLimit = "50000", ExtraGasLimitGuardedTx = "50000"}, - {EnableEpoch = 1, MaxGasLimitPerBlock = "1500000000", MaxGasLimitPerMiniBlock = "250000000", MaxGasLimitPerMetaBlock = "15000000000", MaxGasLimitPerMetaMiniBlock = "250000000", MaxGasLimitPerTx = "600000000", MinGasLimit = "50000", ExtraGasLimitGuardedTx = "50000"}, - {EnableEpoch = 2, MaxGasLimitPerBlock = "1500000000", MaxGasLimitPerMiniBlock = "250000000", MaxGasLimitPerMetaBlock = "15000000000", MaxGasLimitPerMetaMiniBlock = "250000000", MaxGasLimitPerTx = "600000000", MinGasLimit = "50000", ExtraGasLimitGuardedTx = "50000"}, - ] - MinGasPrice = "1000000000" #will yield min tx fee of 0.00005 eGLD - GasPriceModifier = 0.01 - GasPerDataByte = "1500" - DataLimitForBaseCalc = "10000" - MaxGasPriceSetGuardian = "2000000000" diff --git a/integrationTests/relayers/testdata/config/nodeConfig/enableEpochs.toml b/integrationTests/relayers/testdata/config/nodeConfig/enableEpochs.toml deleted file mode 100644 index 7c850955..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/enableEpochs.toml +++ /dev/null @@ -1,312 +0,0 @@ -[EnableEpochs] - # SCDeployEnableEpoch represents the epoch when the deployment of smart contracts will be enabled - SCDeployEnableEpoch = 1 - - # BuiltInFunctionsEnableEpoch represents the epoch when the built in functions will be enabled - BuiltInFunctionsEnableEpoch = 1 - - # RelayedTransactionsEnableEpoch represents the epoch when the relayed transactions will be enabled - RelayedTransactionsEnableEpoch = 1 - - # PenalizedTooMuchGasEnableEpoch represents the epoch when the penalization for using too much gas will be enabled - PenalizedTooMuchGasEnableEpoch = 0 - - # SwitchJailWaitingEnableEpoch represents the epoch when the system smart contract processing at end of epoch is enabled - SwitchJailWaitingEnableEpoch = 0 - - # BelowSignedThresholdEnableEpoch represents the epoch when the change for computing rating for validators below signed rating is enabled - BelowSignedThresholdEnableEpoch = 0 - - # SwitchHysteresisForMinNodesEnableEpoch represents the epoch when the system smart contract changes its config to consider - # also (minimum) hysteresis nodes for the minimum number of nodes - SwitchHysteresisForMinNodesEnableEpoch = 1 - - # TransactionSignedWithTxHashEnableEpoch represents the epoch when the node will also accept transactions that are - # signed with the hash of transaction - TransactionSignedWithTxHashEnableEpoch = 1 - - # MetaProtectionEnableEpoch represents the epoch when the transactions to the metachain are checked to have enough gas - MetaProtectionEnableEpoch = 1 - - # AheadOfTimeGasUsageEnableEpoch represents the epoch when the cost of smart contract prepare changes from compiler per byte to ahead of time prepare per byte - AheadOfTimeGasUsageEnableEpoch = 1 - - # GasPriceModifierEnableEpoch represents the epoch when the gas price modifier in fee computation is enabled - GasPriceModifierEnableEpoch = 1 - - # RepairCallbackEnableEpoch represents the epoch when the callback repair is activated for scrs - RepairCallbackEnableEpoch = 1 - - # BlockGasAndFeesReCheckEnableEpoch represents the epoch when gas and fees used in each created or processed block are re-checked - BlockGasAndFeesReCheckEnableEpoch = 1 - - # BalanceWaitingListsEnableEpoch represents the epoch when the shard waiting lists are balanced at the start of an epoch - BalanceWaitingListsEnableEpoch = 1 - - # ReturnDataToLastTransferEnableEpoch represents the epoch when returned data is added to last output transfer for callbacks - ReturnDataToLastTransferEnableEpoch = 1 - - # SenderInOutTransferEnableEpoch represents the epoch when the feature of having different senders in output transfer is enabled - SenderInOutTransferEnableEpoch = 1 - - # StakeEnableEpoch represents the epoch when staking is enabled - StakeEnableEpoch = 0 - - # StakingV2EnableEpoch represents the epoch when staking v2 is enabled - StakingV2EnableEpoch = 1 - - # DoubleKeyProtectionEnableEpoch represents the epoch when the double key protection will be enabled - DoubleKeyProtectionEnableEpoch = 1 - - # ESDTEnableEpoch represents the epoch when ESDT is enabled - ESDTEnableEpoch = 1 - - # GovernanceEnableEpoch represents the epoch when governance is enabled - GovernanceEnableEpoch = 1 - - # DelegationManagerEnableEpoch represents the epoch when the delegation manager is enabled - # epoch should not be 0 - DelegationManagerEnableEpoch = 1 - - # DelegationSmartContractEnableEpoch represents the epoch when delegation smart contract is enabled - # epoch should not be 0 - DelegationSmartContractEnableEpoch = 1 - - # CorrectLastUnjailedEnableEpoch represents the epoch when the fix regaring the last unjailed node should apply - CorrectLastUnjailedEnableEpoch = 1 - - # RelayedTransactionsV2EnableEpoch represents the epoch when the relayed transactions V2 will be enabled - RelayedTransactionsV2EnableEpoch = 1 - - # UnbondTokensV2EnableEpoch represents the epoch when the new implementation of the unbond tokens function is available - UnbondTokensV2EnableEpoch = 1 - - # SaveJailedAlwaysEnableEpoch represents the epoch when saving jailed status at end of epoch will happen in all cases - SaveJailedAlwaysEnableEpoch = 1 - - # ReDelegateBelowMinCheckEnableEpoch represents the epoch when the check for the re-delegated value will be enabled - ReDelegateBelowMinCheckEnableEpoch = 1 - - # ValidatorToDelegationEnableEpoch represents the epoch when the validator-to-delegation feature will be enabled - ValidatorToDelegationEnableEpoch = 1 - - # WaitingListFixEnableEpoch represents the epoch when the 6 epoch waiting list fix is enabled - WaitingListFixEnableEpoch = 1000000 - - # IncrementSCRNonceInMultiTransferEnableEpoch represents the epoch when the fix for preventing the generation of the same SCRs - # is enabled. The fix is done by adding an extra increment. - IncrementSCRNonceInMultiTransferEnableEpoch = 1 - - # ESDTMultiTransferEnableEpoch represents the epoch when esdt multitransfer built in function is enabled - ESDTMultiTransferEnableEpoch = 1 - - # GlobalMintBurnDisableEpoch represents the epoch when the global mint and burn functions are disabled - GlobalMintBurnDisableEpoch = 1 - - # ESDTTransferRoleEnableEpoch represents the epoch when esdt transfer role set is enabled - ESDTTransferRoleEnableEpoch = 1 - - # BuiltInFunctionOnMetaEnableEpoch represents the epoch when built in function processing on metachain is enabled - BuiltInFunctionOnMetaEnableEpoch = 1000000 - - # ComputeRewardCheckpointEnableEpoch represents the epoch when compute rewards checkpoint epoch is enabled - ComputeRewardCheckpointEnableEpoch = 1 - - # SCRSizeInvariantCheckEnableEpoch represents the epoch when the scr size invariant check is enabled - SCRSizeInvariantCheckEnableEpoch = 1 - - # BackwardCompSaveKeyValueEnableEpoch represents the epoch when the backward compatibility for save key value error is enabled - BackwardCompSaveKeyValueEnableEpoch = 1 - - # ESDTNFTCreateOnMultiShardEnableEpoch represents the epoch when esdt nft creation is enabled on multiple shards - ESDTNFTCreateOnMultiShardEnableEpoch = 1 - - # MetaESDTSetEnableEpoch represents the epoch when the backward compatibility for save key value error is enabled - MetaESDTSetEnableEpoch = 1 - - # AddTokensToDelegationEnableEpoch represents the epoch when adding tokens to delegation is enabled for whitelisted address - AddTokensToDelegationEnableEpoch = 1 - - # MultiESDTTransferFixOnCallBackOnEnableEpoch represents the epoch when multi esdt transfer on callback fix is enabled - MultiESDTTransferFixOnCallBackOnEnableEpoch = 1 - - # OptimizeGasUsedInCrossMiniBlocksEnableEpoch represents the epoch when gas used in cross shard mini blocks will be optimized - OptimizeGasUsedInCrossMiniBlocksEnableEpoch = 1 - - # CorrectFirstQueuedEpoch represents the epoch when the backward compatibility for setting the first queued node is enabled - CorrectFirstQueuedEpoch = 1 - - # DeleteDelegatorAfterClaimRewardsEnableEpoch represents the epoch when the delegators data is deleted for delegators that have to claim rewards after they withdraw all funds - DeleteDelegatorAfterClaimRewardsEnableEpoch = 1 - - # FixOOGReturnCodeEnableEpoch represents the epoch when the backward compatibility returning out of gas error is enabled - FixOOGReturnCodeEnableEpoch = 1 - - # RemoveNonUpdatedStorageEnableEpoch represents the epoch when the backward compatibility for removing non updated storage is enabled - RemoveNonUpdatedStorageEnableEpoch = 1 - - # OptimizeNFTStoreEnableEpoch represents the epoch when optimizations on NFT metadata store and send are enabled - OptimizeNFTStoreEnableEpoch = 1 - - # CreateNFTThroughExecByCallerEnableEpoch represents the epoch when nft creation through execution on destination by caller is enabled - CreateNFTThroughExecByCallerEnableEpoch = 1 - - # StopDecreasingValidatorRatingWhenStuckEnableEpoch represents the epoch when we should stop decreasing validator's rating if, for instance, a shard gets stuck - StopDecreasingValidatorRatingWhenStuckEnableEpoch = 1 - - # FrontRunningProtectionEnableEpoch represents the epoch when the first version of protection against front running is enabled - FrontRunningProtectionEnableEpoch = 1 - - # IsPayableBySCEnableEpoch represents the epoch when a new flag isPayable by SC is enabled - IsPayableBySCEnableEpoch = 1 - - # CleanUpInformativeSCRsEnableEpoch represents the epoch when the informative-only scrs are cleaned from miniblocks and logs are created from them - CleanUpInformativeSCRsEnableEpoch = 1 - - # StorageAPICostOptimizationEnableEpoch represents the epoch when new storage helper functions are enabled and cost is reduced in Wasm VM - StorageAPICostOptimizationEnableEpoch = 1 - - # TransformToMultiShardCreateEnableEpoch represents the epoch when the new function on esdt system sc is enabled to transfer create role into multishard - TransformToMultiShardCreateEnableEpoch = 1 - - # ESDTRegisterAndSetAllRolesEnableEpoch represents the epoch when new function to register tickerID and set all roles is enabled - ESDTRegisterAndSetAllRolesEnableEpoch = 1 - - # ScheduledMiniBlocksEnableEpoch represents the epoch when scheduled mini blocks would be created if needed - ScheduledMiniBlocksEnableEpoch = 1 - - # CorrectJailedNotUnstakedEpoch represents the epoch when the jailed validators will also be unstaked if the queue is empty - CorrectJailedNotUnstakedEmptyQueueEpoch = 1 - - # DoNotReturnOldBlockInBlockchainHookEnableEpoch represents the epoch when the fetch old block operation is - # disabled in the blockchain hook component - DoNotReturnOldBlockInBlockchainHookEnableEpoch = 1 - - # AddFailedRelayedTxToInvalidMBsDisableEpoch represents the epoch when adding the failed relayed txs to invalid miniblocks is disabled - AddFailedRelayedTxToInvalidMBsDisableEpoch = 1 - - # SCRSizeInvariantOnBuiltInResultEnableEpoch represents the epoch when scr size invariant on built in result is enabled - SCRSizeInvariantOnBuiltInResultEnableEpoch = 1 - - # CheckCorrectTokenIDForTransferRoleEnableEpoch represents the epoch when the correct token ID check is applied for transfer role verification - CheckCorrectTokenIDForTransferRoleEnableEpoch = 1 - - # DisableExecByCallerEnableEpoch represents the epoch when the check on value is disabled on exec by caller - DisableExecByCallerEnableEpoch = 1 - - # RefactorContextEnableEpoch represents the epoch when refactoring/simplifying is enabled in contexts - RefactorContextEnableEpoch = 1 - - # FailExecutionOnEveryAPIErrorEnableEpoch represent the epoch when new protection in VM is enabled to fail all wrong API calls - FailExecutionOnEveryAPIErrorEnableEpoch = 1 - - # ManagedCryptoAPIsEnableEpoch represents the epoch when new managed crypto APIs are enabled in the wasm VM - ManagedCryptoAPIsEnableEpoch = 1 - - # CheckFunctionArgumentEnableEpoch represents the epoch when the extra argument check is enabled in vm-common - CheckFunctionArgumentEnableEpoch = 1 - - # CheckExecuteOnReadOnlyEnableEpoch represents the epoch when the extra checks are enabled for execution on read only - CheckExecuteOnReadOnlyEnableEpoch = 1 - - # ESDTMetadataContinuousCleanupEnableEpoch represents the epoch when esdt metadata is automatically deleted according to inshard liquidity - ESDTMetadataContinuousCleanupEnableEpoch = 1 - - # MiniBlockPartialExecutionEnableEpoch represents the epoch when mini block partial execution will be enabled - MiniBlockPartialExecutionEnableEpoch = 1 - - # FixAsyncCallBackArgsListEnableEpoch represents the epoch when the async callback arguments lists fix will be enabled - FixAsyncCallBackArgsListEnableEpoch = 1 - - # FixOldTokenLiquidityEnableEpoch represents the epoch when the fix for old token liquidity is enabled - FixOldTokenLiquidityEnableEpoch = 1 - - # RuntimeMemStoreLimitEnableEpoch represents the epoch when the condition for Runtime MemStore is enabled - RuntimeMemStoreLimitEnableEpoch = 1 - - # SetSenderInEeiOutputTransferEnableEpoch represents the epoch when setting the sender in eei output transfers will be enabled - SetSenderInEeiOutputTransferEnableEpoch = 1 - - # RefactorPeersMiniBlocksEnableEpoch represents the epoch when refactor of the peers mini blocks will be enabled - RefactorPeersMiniBlocksEnableEpoch = 1 - - # MaxBlockchainHookCountersEnableEpoch represents the epoch when the max blockchainhook counters are enabled - MaxBlockchainHookCountersEnableEpoch = 1 - - # WipeSingleNFTLiquidityDecreaseEnableEpoch represents the epoch when the system account liquidity is decreased for wipeSingleNFT as well - WipeSingleNFTLiquidityDecreaseEnableEpoch = 1 - - # AlwaysSaveTokenMetaDataEnableEpoch represents the epoch when the token metadata is always saved - AlwaysSaveTokenMetaDataEnableEpoch = 1 - - # RuntimeCodeSizeFixEnableEpoch represents the epoch when the code size fix in the VM is enabled - RuntimeCodeSizeFixEnableEpoch = 1 - - # RelayedNonceFixEnableEpoch represents the epoch when the nonce fix for relayed txs is enabled - RelayedNonceFixEnableEpoch = 1 - - # SetGuardianEnableEpoch represents the epoch when the guard account feature is enabled in the protocol - SetGuardianEnableEpoch = 1 - - # DeterministicSortOnValidatorsInfoEnableEpoch represents the epoch when the deterministic sorting on validators info is enabled - DeterministicSortOnValidatorsInfoEnableEpoch = 1 - - # SCProcessorV2EnableEpoch represents the epoch when SC processor V2 will be used - SCProcessorV2EnableEpoch = 1 - - # AutoBalanceDataTriesEnableEpoch represents the epoch when the data tries are automatically balanced by inserting at the hashed key instead of the normal key - AutoBalanceDataTriesEnableEpoch = 1 - - # MigrateDataTrieEnableEpoch represents the epoch when the data tries migration is enabled - MigrateDataTrieEnableEpoch = 1 - - # KeepExecOrderOnCreatedSCRsEnableEpoch represents the epoch when the execution order of created SCRs is ensured - KeepExecOrderOnCreatedSCRsEnableEpoch = 1 - - # MultiClaimOnDelegationEnableEpoch represents the epoch when the multi claim on delegation is enabled - MultiClaimOnDelegationEnableEpoch = 1 - - # ChangeUsernameEnableEpoch represents the epoch when changing username is enabled - ChangeUsernameEnableEpoch = 4 - - # ConsistentTokensValuesLengthCheckEnableEpoch represents the epoch when the consistent tokens values length check is enabled - ConsistentTokensValuesLengthCheckEnableEpoch = 1 - - # FixDelegationChangeOwnerOnAccountEnableEpoch represents the epoch when the fix for the delegation system smart contract is enabled - FixDelegationChangeOwnerOnAccountEnableEpoch = 1 - - # DynamicGasCostForDataTrieStorageLoadEnableEpoch represents the epoch when dynamic gas cost for data trie storage load will be enabled - DynamicGasCostForDataTrieStorageLoadEnableEpoch = 1 - - # ScToScLogEventEnableEpoch represents the epoch when the sc to sc log event feature is enabled - ScToScLogEventEnableEpoch = 1 - - # NFTStopCreateEnableEpoch represents the epoch when NFT stop create feature is enabled - NFTStopCreateEnableEpoch = 1 - - # ChangeOwnerAddressCrossShardThroughSCEnableEpoch represents the epoch when the change owner address built in function will work also through a smart contract call cross shard - ChangeOwnerAddressCrossShardThroughSCEnableEpoch = 1 - - # FixGasRemainingForSaveKeyValueBuiltinFunctionEnableEpoch represents the epoch when the fix for the remaining gas in the SaveKeyValue builtin function is enabled - FixGasRemainingForSaveKeyValueBuiltinFunctionEnableEpoch = 1 - - # CurrentRandomnessOnSortingEnableEpoch represents the epoch when the current randomness on sorting is enabled - CurrentRandomnessOnSortingEnableEpoch = 4 - - # BLSMultiSignerEnableEpoch represents the activation epoch for different types of BLS multi-signers - BLSMultiSignerEnableEpoch = [ - { EnableEpoch = 0, Type = "no-KOSK" }, - { EnableEpoch = 1, Type = "KOSK" } - ] - - # MaxNodesChangeEnableEpoch holds configuration for changing the maximum number of nodes and the enabling epoch - MaxNodesChangeEnableEpoch = [ - { EpochEnable = 0, MaxNumNodes = 48, NodesToShufflePerShard = 4 }, # 4 shuffled out keys / shard will not be reached normally - { EpochEnable = 1, MaxNumNodes = 64, NodesToShufflePerShard = 2 } - ] - -[GasSchedule] - # GasScheduleByEpochs holds the configuration for the gas schedule that will be applied from specific epochs - GasScheduleByEpochs = [ - { StartEpoch = 0, FileName = "gasScheduleV7.toml" }, - ] diff --git a/integrationTests/relayers/testdata/config/nodeConfig/enableRounds.toml b/integrationTests/relayers/testdata/config/nodeConfig/enableRounds.toml deleted file mode 100644 index d7be75bb..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/enableRounds.toml +++ /dev/null @@ -1,13 +0,0 @@ -# All activation rounds need to be declared as strings containing valid uint64 numbers. All values will be checked in the -# enableRoundsHandler for correctness. The toml parser library can not correctly parse uint64, currently. - -# Each activation round definition contains an optional slice of strings. These are useful, for example, when we have -# some exceptions to process in a different manner at a special round (say a block, a transaction, a smart contract result and such) - -# The Options field for each activation round can have some custom array of strings (for using them in exceptions or other use cases) -# Example: Options = ["test string1", "test string 2"] - -[RoundActivations] - [RoundActivations.DisableAsyncCallV1] - Options = [] - Round = "100" diff --git a/integrationTests/relayers/testdata/config/nodeConfig/external.toml b/integrationTests/relayers/testdata/config/nodeConfig/external.toml deleted file mode 100644 index 1058e0c3..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/external.toml +++ /dev/null @@ -1,77 +0,0 @@ -# ElasticSearchConnector defines settings related to ElasticSearch such as login information or URL -[ElasticSearchConnector] - ## We do not recommend to activate this indexer on a validator node since - #the node might loose rating (even facing penalties) due to the fact that - #the indexer is called synchronously and might block due to external causes. - #Strongly suggested to activate this on a regular observer node. - Enabled = false - IndexerCacheSize = 0 - BulkRequestMaxSizeInBytes = 4194304 # 4MB - URL = "http://localhost:9200" - UseKibana = false - Username = "" - Password = "" - # EnabledIndexes represents a slice of indexes that will be enabled for indexing. Full list is: - # ["rating", "transactions", "blocks", "validators", "miniblocks", "rounds", "accounts", "accountshistory", "receipts", "scresults", "accountsesdt", "accountsesdthistory", "epochinfo", "scdeploys", "tokens", "tags", "logs", "delegators", "operations", "esdts"] - EnabledIndexes = ["rating", "transactions", "blocks", "validators", "miniblocks", "rounds", "accounts", "accountshistory", "receipts", "scresults", "accountsesdt", "accountsesdthistory", "epochinfo", "scdeploys", "tokens", "tags", "logs", "delegators", "operations", "esdts"] - -# EventNotifierConnector defines settings needed to configure and launch the event notifier component -# HTTP event notifier connector integration will be DEPRECATED in the following iterations -[EventNotifierConnector] - # Enabled will turn on or off the event notifier connector - Enabled = false - - # UseAuthorization signals the proxy to use authorization - # Never run a production setup without authorization - UseAuthorization = false - - # ProxyUrl is used to communicate with the subscriptions hub - # The indexer instance will broadcast data using ProxyUrl - ProxyUrl = "http://localhost:5000" - - # Username and Password need to be specified if UseAuthorization is set to true - Username = "" - - # Password is used to authorize an observer to push event data - Password = "" - - # RequestTimeoutSec defines the timeout in seconds for the http client - RequestTimeoutSec = 60 - - # MarshallerType is used to define the marshaller type to be used for inner - # marshalled structures in block events data - MarshallerType = "json" - -[[HostDriversConfig]] - # This flag shall only be used for observer nodes - Enabled = false - - # This flag will start the WebSocket connector as server or client (can be "client" or "server") - Mode = "client" - - # URL for the WebSocket client/server connection - # This value represents the IP address and port number that the WebSocket client or server will use to establish a connection. - URL = "127.0.0.1:22111" - - # After a message will be sent it will wait for an ack message if this flag is enabled - WithAcknowledge = true - - # The duration in seconds to wait for an acknowledgment message, after this time passes an error will be returned - AcknowledgeTimeoutInSec = 60 - - # This flag defines the marshaller type. Currently supported: "json", "gogo protobuf" - MarshallerType = "json" - - # The number of seconds when the client will try again to send the data - RetryDurationInSec = 5 - - # Sets if, in case of data payload processing error, we should block or not the advancement to the next processing event. Set this to true if you wish the node to stop processing blocks if the client/server encounters errors while processing requests. - BlockingAckOnError = true - - # Set to true to drop messages if there is no active WebSocket connection to send to. - DropMessagesIfNoConnection = false - - # Defines the payload version. Version will be changed when there are breaking - # changes on payload data. The receiver/consumer will have to know how to handle different - # versions. The version will be sent as metadata in the websocket message. - Version = 1 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/fullArchiveP2P.toml b/integrationTests/relayers/testdata/config/nodeConfig/fullArchiveP2P.toml deleted file mode 100644 index 6e9010a4..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/fullArchiveP2P.toml +++ /dev/null @@ -1,87 +0,0 @@ -# FullArchiveP2P config file - -# NodeConfig holds the P2P settings -[Node] - # Port is the port that will be opened by the node on all interfaces so other peers can connect to it - # If the port = 0, the node will search for a free port on the machine and use it - Port = "37373-38383" - - # ThresholdMinConnectedPeers represents the minimum number of connections a node should have before it can start - # the sync and consensus mechanisms - ThresholdMinConnectedPeers = 3 - - # MinNumPeersToWaitForOnBootstrap is the minimum number of peers to wait on bootstrap or the node will wait the default - # time which is now set to ~20 seconds (the const defined in the common package named TimeToWaitForP2PBootstrap) - MinNumPeersToWaitForOnBootstrap = 10 - - # available transports. All defined addresses contains a single '%d' markup that is mandatory and will - # be replaced at runtime with the actual port value - [Node.Transports] - QUICAddress = "" # optional QUIC address. If this transport should be activated, should be in this format: /ip4/0.0.0.0/udp/%d/quic-v1 - WebSocketAddress = "" # optional WebSocket address. If this transport should be activated, should be in this format: /ip4/0.0.0.0/tcp/%d/ws - WebTransportAddress = "" # optional WebTransport address. If this transport should be activated, should be in this format: /ip4/0.0.0.0/udp/%d/quic-v1/webtransport - [Node.Transports.TCP] - ListenAddress = "/ip4/0.0.0.0/tcp/%d" # TCP listen address - PreventPortReuse = false - - [Node.ResourceLimiter] - Type = "default autoscale" #available options "default autoscale", "infinite", "default with manual scale". - ManualSystemMemoryInMB = 0 # not taken into account if the type is not "default with manual scale" - ManualMaximumFD = 0 # not taken into account if the type is not "default with manual scale" - -# P2P peer discovery section - -# The following sections correspond to the way new peers will be discovered -# If all config types are disabled then the peer will run in single mode (will not try to find other peers) -# If more than one peer discovery mechanism is enabled, the application will output an error and will not start - -[KadDhtPeerDiscovery] - # Enabled: true/false to enable/disable this discovery mechanism - Enabled = true - - # Type represents the kad-dht glue code implementation. - # "legacy" will define the first implementation. - # "optimized" represents the new variant able to connect to multiple seeders at once. This implementation also has - # a built-in timer that will try to automatically reconnect to the seeders (in case the seeders recover after a - # premature shutdown) - Type = "optimized" - - # RefreshIntervalInSec represents the time in seconds between querying for new peers - RefreshIntervalInSec = 10 - - # ProtocolID represents the protocol that this node will advertize to other peers - # To connect to other nodes, those nodes should have the same ProtocolID string - ProtocolID = "/erd/kad/1.0.0" - - # InitialPeerList represents the list of strings of some known nodes that will bootstrap this node - # The address will be in a self-describing addressing format. - # More can be found here: https://github.com/libp2p/specs/blob/master/3-requirements.md#34-transport-agnostic - # Example: - # /ip6/fe80::8823:6dff:fee7:f172/tcp/4001/p2p/QmYJyUMAcXEw1b5bFfbBbzYu5wyyjLMRHXGUkCXpag74Fu - # /ip4/162.246.145.218/udp/4001/utp/ipfs/QmYJyUMAcXEw1b5bFfbBbzYu5wyyjLMRHXGUkCXpag74Fu - # - # If the initial peers list is left empty, the node will not try to connect to other peers during initial bootstrap - # phase but will accept connections and will do the network discovery if another peer connects to it - InitialPeerList = ["/ip4/127.0.0.1/tcp/9999/p2p/16Uiu2HAkw5SNNtSvH1zJiQ6Gc3WoGNSxiyNueRKe6fuAuh57G3Bk"] - - # kademlia's routing table bucket size - BucketSize = 100 - - # RoutingTableRefreshIntervalInSec defines how many seconds should pass between 2 kad routing table auto refresh calls - RoutingTableRefreshIntervalInSec = 300 - -[Sharding] - # The targeted number of peer connections - TargetPeerCount = 41 - MaxIntraShardValidators = 7 - MaxCrossShardValidators = 15 - MaxIntraShardObservers = 7 - MaxCrossShardObservers = 3 - MaxSeeders = 2 - - # available options: - # `ListsSharder` will split the peers based on the shard membership (intra, cross or unknown) - # `OneListSharder` will do just the connection triming (upto TargetPeerCount value) not taking into account - # the shard membership of the connected peers - # `NilListSharder` will disable conection trimming (sharder is off) - Type = "ListsSharder" diff --git a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV1.toml b/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV1.toml deleted file mode 100644 index 52175a22..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV1.toml +++ /dev/null @@ -1,827 +0,0 @@ -[BuiltInCost] - ChangeOwnerAddress = 5000000 - ClaimDeveloperRewards = 5000000 - SaveUserName = 5000000 - SaveKeyValue = 250000 - ESDTTransfer = 250000 - ESDTBurn = 250000 - ESDTLocalMint = 250000 - ESDTLocalBurn = 250000 - ESDTNFTCreate = 500000 - ESDTNFTAddQuantity = 500000 - ESDTNFTBurn = 500000 - ESDTNFTTransfer = 500000 - ESDTNFTChangeCreateOwner = 1000000 - ESDTNFTAddUri = 500000 - ESDTNFTUpdateAttributes = 500000 - ESDTNFTMultiTransfer = 1000000 - SetGuardian = 250000 - GuardAccount = 250000 - UnGuardAccount = 250000 - TrieLoadPerNode = 100000 - TrieStorePerNode = 50000 - -[MetaChainSystemSCsCost] - Stake = 5000000 - UnStake = 5000000 - UnBond = 5000000 - Claim = 5000000 - Get = 5000000 - ChangeRewardAddress = 5000000 - ChangeValidatorKeys = 5000000 - UnJail = 5000000 - ESDTIssue = 50000000 - ESDTOperations = 50000000 - Proposal = 5000000 - Vote = 500000 - DelegateVote = 1000000 - RevokeVote = 500000 - CloseProposal = 1000000 - DelegationOps = 1000000 - UnstakeTokens = 5000000 - UnbondTokens = 5000000 - DelegationMgrOps = 50000000 - GetActiveFund = 50000 - ValidatorToDelegation = 500000000 - GetAllNodeStates = 100000000 - FixWaitingListSize = 500000000 - -[BaseOperationCost] - StorePerByte = 50000 - ReleasePerByte = 10000 - DataCopyPerByte = 1000 - PersistPerByte = 10000 - CompilePerByte = 300 - AoTPreparePerByte = 50 - GetCode = 100000 - -[BaseOpsAPICost] - GetSCAddress = 100 - GetOwnerAddress = 100 - IsSmartContract = 100 - GetShardOfAddress = 100 - GetExternalBalance = 7000 - GetBlockHash = 1000 - TransferValue = 150000 - GetArgument = 100 - GetFunction = 100 - GetNumArguments = 100 - StorageStore = 250000 - StorageLoad = 100000 - CachedStorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - Log = 3750 - Finish = 1 - SignalError = 1 - GetBlockTimeStamp = 1000 - GetGasLeft = 100 - Int64GetArgument = 100 - Int64StorageStore = 250000 - Int64StorageLoad = 100000 - Int64Finish = 100 - GetStateRootHash = 1000 - GetBlockNonce = 1000 - GetBlockEpoch = 1000 - GetBlockRound = 1000 - GetBlockRandomSeed = 1000 - ExecuteOnSameContext = 160000 - ExecuteOnDestContext = 160000 - DelegateExecution = 160000 - AsyncCallStep = 200000 - AsyncCallbackGasLock = 20000000 - ExecuteReadOnly = 160000 - CreateContract = 300000 - GetReturnData = 100 - GetNumReturnData = 100 - GetReturnDataSize = 100 - CleanReturnData = 100 - DeleteFromReturnData = 100 - GetOriginalTxHash = 10000 - GetPrevTxHash = 10000 - GetCurrentTxHash = 10000 - CreateAsyncCall = 200000 - SetAsyncCallback = 100000 - SetAsyncGroupCallback = 100000 - SetAsyncContextCallback = 100000 - GetCallbackClosure = 10000 - GetCodeMetadata = 10000 - IsBuiltinFunction = 10000 - -[EthAPICost] - UseGas = 100 - GetAddress = 100 - GetExternalBalance = 7000 - GetBlockHash = 1000 - Call = 160000 - CallDataCopy = 200 - GetCallDataSize = 100 - CallCode = 160000 - CallDelegate = 160000 - CallStatic = 160000 - StorageStore = 250000 - StorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - CodeCopy = 1000 - GetCodeSize = 100 - GetBlockCoinbase = 100 - Create = 320000 - GetBlockDifficulty = 100 - ExternalCodeCopy = 3000 - GetExternalCodeSize = 2500 - GetGasLeft = 100 - GetBlockGasLimit = 100 - GetTxGasPrice = 100 - Log = 3750 - GetBlockNumber = 1000 - GetTxOrigin = 100 - Finish = 1 - Revert = 1 - GetReturnDataSize = 200 - ReturnDataCopy = 500 - SelfDestruct = 500000 - GetBlockTimeStamp = 1000 - -[BigIntAPICost] - BigIntNew = 100 - BigIntByteLength = 100 - BigIntUnsignedByteLength = 100 - BigIntSignedByteLength = 100 - BigIntGetBytes = 100 - BigIntGetUnsignedBytes = 100 - BigIntGetSignedBytes = 100 - BigIntSetBytes = 100 - BigIntSetUnsignedBytes = 100 - BigIntSetSignedBytes = 100 - BigIntIsInt64 = 100 - BigIntGetInt64 = 100 - BigIntSetInt64 = 100 - BigIntAdd = 100 - BigIntSub = 100 - BigIntMul = 600 - BigIntSqrt = 6000 - BigIntPow = 6000 - BigIntLog = 6000 - BigIntTDiv = 100 - BigIntTMod = 100 - BigIntEDiv = 100 - BigIntEMod = 100 - BigIntAbs = 100 - BigIntNeg = 100 - BigIntSign = 100 - BigIntCmp = 100 - BigIntNot = 100 - BigIntAnd = 100 - BigIntOr = 100 - BigIntXor = 100 - BigIntShr = 100 - BigIntShl = 100 - BigIntFinishUnsigned = 100 - BigIntFinishSigned = 100 - BigIntStorageLoadUnsigned = 100000 - BigIntStorageStoreUnsigned = 250000 - BigIntGetArgument = 100 - BigIntGetUnsignedArgument = 100 - BigIntGetSignedArgument = 100 - BigIntGetCallValue = 100 - BigIntGetExternalBalance = 500 - CopyPerByteForTooBig = 1000 - -[CryptoAPICost] - SHA256 = 600 - Keccak256 = 600 - Ripemd160 = 600 - VerifyBLS = 1000 - VerifyEd25519 = 1000 - VerifySecp256k1 = 1000 - EllipticCurveNew = 10000 - AddECC = 75000 - DoubleECC = 65000 - IsOnCurveECC = 10000 - ScalarMultECC = 400000 - MarshalECC = 13000 - MarshalCompressedECC = 15000 - UnmarshalECC = 20000 - UnmarshalCompressedECC = 270000 - GenerateKeyECC = 7000000 - EncodeDERSig = 10000000 - -[ManagedBufferAPICost] - MBufferNew = 2000 - MBufferNewFromBytes = 4000 - MBufferSetBytes = 2000 - MBufferGetLength = 2000 - MBufferGetBytes = 2000 - MBufferGetByteSlice = 2000 - MBufferCopyByteSlice = 2000 - MBufferAppend = 2000 - MBufferAppendBytes = 2000 - MBufferToBigIntUnsigned = 4000 - MBufferToBigIntSigned = 10000 - MBufferFromBigIntUnsigned = 4000 - MBufferFromBigIntSigned = 10000 - MBufferStorageStore = 250000 - MBufferStorageLoad = 100000 - MBufferGetArgument = 1000 - MBufferFinish = 1000 - MBufferSetRandom = 6000 - MBufferToBigFloat = 2000 - MBufferFromBigFloat = 2000 - -[BigFloatAPICost] - BigFloatNewFromParts = 3000 - BigFloatAdd = 7000 - BigFloatSub = 7000 - BigFloatMul = 7000 - BigFloatDiv = 7000 - BigFloatTruncate = 5000 - BigFloatNeg = 5000 - BigFloatClone = 5000 - BigFloatCmp = 4000 - BigFloatAbs = 5000 - BigFloatSqrt = 7000 - BigFloatPow = 10000 - BigFloatFloor = 5000 - BigFloatCeil = 5000 - BigFloatIsInt = 3000 - BigFloatSetBigInt = 3000 - BigFloatSetInt64 = 1000 - BigFloatGetConst = 1000 - -[WASMOpcodeCost] - Unreachable = 1 - Nop = 1 - Block = 1 - Loop = 1 - If = 1 - Else = 2 - End = 2 - Br = 2 - BrIf = 3 - BrTable = 2 - Return = 3 - Call = 3 - CallIndirect = 3 - Drop = 3 - Select = 3 - TypedSelect = 3 - LocalGet = 3 - LocalSet = 3 - LocalTee = 3 - GlobalGet = 3 - GlobalSet = 3 - I32Load = 3 - I64Load = 3 - F32Load = 6 - F64Load = 6 - I32Load8S = 3 - I32Load8U = 3 - I32Load16S = 3 - I32Load16U = 3 - I64Load8S = 3 - I64Load8U = 3 - I64Load16S = 3 - I64Load16U = 3 - I64Load32S = 3 - I64Load32U = 3 - I32Store = 3 - I64Store = 3 - F32Store = 12 - F64Store = 12 - I32Store8 = 3 - I32Store16 = 3 - I64Store8 = 3 - I64Store16 = 3 - I64Store32 = 3 - MemorySize = 5 - MemoryGrow = 5 - I32Const = 1 - I64Const = 1 - F32Const = 1 - F64Const = 1 - RefNull = 1 - RefIsNull = 1 - RefFunc = 1 - I32Eqz = 1 - I32Eq = 1 - I32Ne = 1 - I32LtS = 1 - I32LtU = 1 - I32GtS = 1 - I32GtU = 1 - I32LeS = 1 - I32LeU = 1 - I32GeS = 1 - I32GeU = 1 - I64Eqz = 1 - I64Eq = 1 - I64Ne = 1 - I64LtS = 1 - I64LtU = 1 - I64GtS = 1 - I64GtU = 1 - I64LeS = 1 - I64LeU = 1 - I64GeS = 1 - I64GeU = 1 - F32Eq = 6 - F32Ne = 6 - F32Lt = 6 - F32Gt = 6 - F32Le = 6 - F32Ge = 6 - F64Eq = 6 - F64Ne = 6 - F64Lt = 6 - F64Gt = 6 - F64Le = 6 - F64Ge = 6 - I32Clz = 100 - I32Ctz = 100 - I32Popcnt = 100 - I32Add = 1 - I32Sub = 1 - I32Mul = 3 - I32DivS = 18 - I32DivU = 18 - I32RemS = 18 - I32RemU = 18 - I32And = 1 - I32Or = 1 - I32Xor = 1 - I32Shl = 3 - I32ShrS = 3 - I32ShrU = 3 - I32Rotl = 5 - I32Rotr = 5 - I64Clz = 100 - I64Ctz = 100 - I64Popcnt = 100 - I64Add = 1 - I64Sub = 1 - I64Mul = 3 - I64DivS = 18 - I64DivU = 18 - I64RemS = 18 - I64RemU = 18 - I64And = 1 - I64Or = 1 - I64Xor = 1 - I64Shl = 3 - I64ShrS = 3 - I64ShrU = 3 - I64Rotl = 5 - I64Rotr = 5 - F32Abs = 5 - F32Neg = 5 - F32Ceil = 100 - F32Floor = 100 - F32Trunc = 100 - F32Nearest = 100 - F32Sqrt = 100 - F32Add = 5 - F32Sub = 5 - F32Mul = 15 - F32Div = 100 - F32Min = 15 - F32Max = 15 - F32Copysign = 5 - F64Abs = 5 - F64Neg = 5 - F64Ceil = 100 - F64Floor = 100 - F64Trunc = 100 - F64Nearest = 100 - F64Sqrt = 100 - F64Add = 5 - F64Sub = 5 - F64Mul = 15 - F64Div = 100 - F64Min = 15 - F64Max = 15 - F64Copysign = 5 - I32WrapI64 = 9 - I32TruncF32S = 100 - I32TruncF32U = 100 - I32TruncF64S = 100 - I32TruncF64U = 100 - I64ExtendI32S = 9 - I64ExtendI32U = 9 - I64TruncF32S = 100 - I64TruncF32U = 100 - I64TruncF64S = 100 - I64TruncF64U = 100 - F32ConvertI32S = 100 - F32ConvertI32U = 100 - F32ConvertI64S = 100 - F32ConvertI64U = 100 - F32DemoteF64 = 100 - F64ConvertI32S = 100 - F64ConvertI32U = 100 - F64ConvertI64S = 100 - F64ConvertI64U = 100 - F64PromoteF32 = 100 - I32ReinterpretF32 = 100 - I64ReinterpretF64 = 100 - F32ReinterpretI32 = 100 - F64ReinterpretI64 = 100 - I32Extend8S = 9 - I32Extend16S = 9 - I64Extend8S = 9 - I64Extend16S = 9 - I64Extend32S = 9 - I32TruncSatF32S = 100 - I32TruncSatF32U = 100 - I32TruncSatF64S = 100 - I32TruncSatF64U = 100 - I64TruncSatF32S = 100 - I64TruncSatF32U = 100 - I64TruncSatF64S = 100 - I64TruncSatF64U = 100 - MemoryInit = 5 - DataDrop = 5 - MemoryCopy = 5 - MemoryFill = 5 - TableInit = 10 - ElemDrop = 10 - TableCopy = 10 - TableFill = 10 - TableGet = 10 - TableSet = 10 - TableGrow = 10 - TableSize = 10 - AtomicNotify = 10 - I32AtomicWait = 10 - I64AtomicWait = 10 - AtomicFence = 10 - I32AtomicLoad = 15 - I64AtomicLoad = 15 - I32AtomicLoad8U = 15 - I32AtomicLoad16U = 15 - I64AtomicLoad8U = 15 - I64AtomicLoad16U = 15 - I64AtomicLoad32U = 15 - I32AtomicStore = 15 - I64AtomicStore = 15 - I32AtomicStore8 = 15 - I32AtomicStore16 = 15 - I64AtomicStore8 = 15 - I64AtomicStore16 = 15 - I64AtomicStore32 = 15 - I32AtomicRmwAdd = 20 - I64AtomicRmwAdd = 20 - I32AtomicRmw8AddU = 20 - I32AtomicRmw16AddU = 20 - I64AtomicRmw8AddU = 20 - I64AtomicRmw16AddU = 20 - I64AtomicRmw32AddU = 20 - I32AtomicRmwSub = 20 - I64AtomicRmwSub = 20 - I32AtomicRmw8SubU = 20 - I32AtomicRmw16SubU = 20 - I64AtomicRmw8SubU = 20 - I64AtomicRmw16SubU = 20 - I64AtomicRmw32SubU = 20 - I32AtomicRmwAnd = 15 - I64AtomicRmwAnd = 15 - I32AtomicRmw8AndU = 15 - I32AtomicRmw16AndU = 15 - I64AtomicRmw8AndU = 15 - I64AtomicRmw16AndU = 15 - I64AtomicRmw32AndU = 15 - I32AtomicRmwOr = 15 - I64AtomicRmwOr = 15 - I32AtomicRmw8OrU = 15 - I32AtomicRmw16OrU = 15 - I64AtomicRmw8OrU = 15 - I64AtomicRmw16OrU = 15 - I64AtomicRmw32OrU = 15 - I32AtomicRmwXor = 15 - I64AtomicRmwXor = 15 - I32AtomicRmw8XorU = 15 - I32AtomicRmw16XorU = 15 - I64AtomicRmw8XorU = 15 - I64AtomicRmw16XorU = 15 - I64AtomicRmw32XorU = 15 - I32AtomicRmwXchg = 30 - I64AtomicRmwXchg = 30 - I32AtomicRmw8XchgU = 30 - I32AtomicRmw16XchgU = 30 - I64AtomicRmw8XchgU = 30 - I64AtomicRmw16XchgU = 30 - I64AtomicRmw32XchgU = 30 - I32AtomicRmwCmpxchg = 30 - I64AtomicRmwCmpxchg = 30 - I32AtomicRmw8CmpxchgU = 30 - I32AtomicRmw16CmpxchgU = 30 - I64AtomicRmw8CmpxchgU = 30 - I64AtomicRmw16CmpxchgU = 30 - I64AtomicRmw32CmpxchgU = 30 - V128Load = 18 - V128Store = 18 - V128Const = 18 - I8x16Splat = 20 - I8x16ExtractLaneS = 20 - I8x16ExtractLaneU = 20 - I8x16ReplaceLane = 20 - I16x8Splat = 20 - I16x8ExtractLaneS = 20 - I16x8ExtractLaneU = 20 - I16x8ReplaceLane = 20 - I32x4Splat = 20 - I32x4ExtractLane = 20 - I32x4ReplaceLane = 20 - I64x2Splat = 20 - I64x2ExtractLane = 20 - I64x2ReplaceLane = 20 - F32x4Splat = 120 - F32x4ExtractLane = 120 - F32x4ReplaceLane = 120 - F64x2Splat = 120 - F64x2ExtractLane = 120 - F64x2ReplaceLane = 120 - I8x16Eq = 30 - I8x16Ne = 30 - I8x16LtS = 40 - I8x16LtU = 40 - I8x16GtS = 40 - I8x16GtU = 40 - I8x16LeS = 40 - I8x16LeU = 40 - I8x16GeS = 40 - I8x16GeU = 40 - I16x8Eq = 30 - I16x8Ne = 30 - I16x8LtS = 40 - I16x8LtU = 40 - I16x8GtS = 40 - I16x8GtU = 40 - I16x8LeS = 40 - I16x8LeU = 40 - I16x8GeS = 40 - I16x8GeU = 40 - I32x4Eq = 30 - I32x4Ne = 30 - I32x4LtS = 40 - I32x4LtU = 40 - I32x4GtS = 40 - I32x4GtU = 40 - I32x4LeS = 40 - I32x4LeU = 40 - I32x4GeS = 40 - I32x4GeU = 40 - F32x4Eq = 120 - F32x4Ne = 120 - F32x4Lt = 120 - F32x4Gt = 120 - F32x4Le = 120 - F32x4Ge = 120 - F64x2Eq = 120 - F64x2Ne = 120 - F64x2Lt = 120 - F64x2Gt = 120 - F64x2Le = 120 - F64x2Ge = 120 - V128Not = 40 - V128And = 40 - V128AndNot = 40 - V128Or = 40 - V128Xor = 40 - V128Bitselect = 40 - I8x16Neg = 20 - I8x16AnyTrue = 20 - I8x16AllTrue = 20 - I8x16Shl = 30 - I8x16ShrS = 30 - I8x16ShrU = 30 - I8x16Add = 20 - I8x16AddSaturateS = 20 - I8x16AddSaturateU = 20 - I8x16Sub = 20 - I8x16SubSaturateS = 20 - I8x16SubSaturateU = 20 - I8x16MinS = 40 - I8x16MinU = 40 - I8x16MaxS = 40 - I8x16MaxU = 40 - I8x16Mul = 80 - I16x8Neg = 40 - I16x8AnyTrue = 40 - I16x8AllTrue = 40 - I16x8Shl = 30 - I16x8ShrS = 30 - I16x8ShrU = 30 - I16x8Add = 20 - I16x8AddSaturateS = 20 - I16x8AddSaturateU = 20 - I16x8Sub = 20 - I16x8SubSaturateS = 20 - I16x8SubSaturateU = 20 - I16x8Mul = 40 - I16x8MinS = 40 - I16x8MinU = 40 - I16x8MaxS = 40 - I16x8MaxU = 40 - I32x4Neg = 20 - I32x4AnyTrue = 20 - I32x4AllTrue = 20 - I32x4Shl = 30 - I32x4ShrS = 30 - I32x4ShrU = 30 - I32x4Add = 20 - I32x4Sub = 20 - I32x4Mul = 80 - I32x4MinS = 40 - I32x4MinU = 40 - I32x4MaxS = 40 - I32x4MaxU = 40 - I64x2Neg = 40 - I64x2AnyTrue = 20 - I64x2AllTrue = 20 - I64x2Shl = 30 - I64x2ShrS = 30 - I64x2ShrU = 30 - I64x2Add = 20 - I64x2Sub = 20 - I64x2Mul = 80 - F32x4Abs = 200 - F32x4Neg = 200 - F32x4Sqrt = 1000 - F32x4Add = 200 - F32x4Sub = 200 - F32x4Mul = 800 - F32x4Div = 1000 - F32x4Min = 500 - F32x4Max = 500 - F64x2Abs = 500 - F64x2Neg = 400 - F64x2Sqrt = 1000 - F64x2Add = 200 - F64x2Sub = 200 - F64x2Mul = 800 - F64x2Div = 1000 - F64x2Min = 500 - F64x2Max = 500 - I32x4TruncSatF32x4S = 1000 - I32x4TruncSatF32x4U = 1000 - I64x2TruncSatF64x2S = 1000 - I64x2TruncSatF64x2U = 1000 - F32x4ConvertI32x4S = 1000 - F32x4ConvertI32x4U = 1000 - F64x2ConvertI64x2S = 1000 - F64x2ConvertI64x2U = 1000 - V8x16Swizzle = 1200 - V8x16Shuffle = 1200 - V8x16LoadSplat = 40 - V16x8LoadSplat = 40 - V32x4LoadSplat = 40 - V64x2LoadSplat = 40 - I8x16NarrowI16x8S = 800 - I8x16NarrowI16x8U = 800 - I16x8NarrowI32x4S = 800 - I16x8NarrowI32x4U = 800 - I16x8WidenLowI8x16S = 800 - I16x8WidenHighI8x16S = 800 - I16x8WidenLowI8x16U = 800 - I16x8WidenHighI8x16U = 800 - I32x4WidenLowI16x8S = 800 - I32x4WidenHighI16x8S = 800 - I32x4WidenLowI16x8U = 800 - I32x4WidenHighI16x8U = 800 - I16x8Load8x8S = 400 - I16x8Load8x8U = 400 - I32x4Load16x4S = 400 - I32x4Load16x4U = 400 - I64x2Load32x2S = 400 - I64x2Load32x2U = 400 - I8x16RoundingAverageU = 200 - I16x8RoundingAverageU = 200 - LocalAllocate = 2 - LocalsUnmetered = 100 - MaxMemoryGrowDelta = 100 - MaxMemoryGrow = 100 - Catch = 1 - CatchAll = 1 - Delegate = 1 - F32x4Ceil = 1 - F32x4DemoteF64x2Zero = 1 - F32x4Floor = 1 - F32x4Nearest = 1 - F32x4PMax = 1 - F32x4PMin = 1 - F32x4Trunc = 1 - F64x2Ceil = 1 - F64x2ConvertLowI32x4S = 1 - F64x2ConvertLowI32x4U = 1 - F64x2Floor = 1 - F64x2Nearest = 1 - F64x2PMax = 1 - F64x2PMin = 1 - F64x2PromoteLowF32x4 = 1 - F64x2Trunc = 1 - I16x8Abs = 1 - I16x8AddSatS = 1 - I16x8AddSatU = 1 - I16x8Bitmask = 1 - I16x8ExtAddPairwiseI8x16S = 1 - I16x8ExtAddPairwiseI8x16U = 1 - I16x8ExtMulHighI8x16S = 1 - I16x8ExtMulHighI8x16U = 1 - I16x8ExtMulLowI8x16S = 1 - I16x8ExtMulLowI8x16U = 1 - I16x8ExtendHighI8x16S = 1 - I16x8ExtendHighI8x16U = 1 - I16x8ExtendLowI8x16S = 1 - I16x8ExtendLowI8x16U = 1 - I16x8Q15MulrSatS = 1 - I16x8SubSatS = 1 - I16x8SubSatU = 1 - I32x4Abs = 1 - I32x4Bitmask = 1 - I32x4DotI16x8S = 1 - I32x4ExtAddPairwiseI16x8S = 1 - I32x4ExtAddPairwiseI16x8U = 1 - I32x4ExtMulHighI16x8S = 1 - I32x4ExtMulHighI16x8U = 1 - I32x4ExtMulLowI16x8S = 1 - I32x4ExtMulLowI16x8U = 1 - I32x4ExtendHighI16x8S = 1 - I32x4ExtendHighI16x8U = 1 - I32x4ExtendLowI16x8S = 1 - I32x4ExtendLowI16x8U = 1 - I32x4TruncSatF64x2SZero = 1 - I32x4TruncSatF64x2UZero = 1 - I64x2Abs = 1 - I64x2Bitmask = 1 - I64x2Eq = 1 - I64x2ExtMulHighI32x4S = 1 - I64x2ExtMulHighI32x4U = 1 - I64x2ExtMulLowI32x4S = 1 - I64x2ExtMulLowI32x4U = 1 - I64x2ExtendHighI32x4S = 1 - I64x2ExtendHighI32x4U = 1 - I64x2ExtendLowI32x4S = 1 - I64x2ExtendLowI32x4U = 1 - I64x2GeS = 1 - I64x2GtS = 1 - I64x2LeS = 1 - I64x2LtS = 1 - I64x2Ne = 1 - I8x16Abs = 1 - I8x16AddSatS = 1 - I8x16AddSatU = 1 - I8x16Bitmask = 1 - I8x16Popcnt = 1 - I8x16Shuffle = 1 - I8x16SubSatS = 1 - I8x16SubSatU = 1 - I8x16Swizzle = 1 - MemoryAtomicNotify = 1 - MemoryAtomicWait32 = 1 - MemoryAtomicWait64 = 1 - Rethrow = 1 - ReturnCall = 1 - ReturnCallIndirect = 1 - Throw = 1 - Try = 1 - Unwind = 1 - V128AnyTrue = 1 - V128Load16Lane = 1 - V128Load16Splat = 1 - V128Load16x4S = 1 - V128Load16x4U = 1 - V128Load32Lane = 1 - V128Load32Splat = 1 - V128Load32Zero = 1 - V128Load32x2S = 1 - V128Load32x2U = 1 - V128Load64Lane = 1 - V128Load64Splat = 1 - V128Load64Zero = 1 - V128Load8Lane = 1 - V128Load8Splat = 1 - V128Load8x8S = 1 - V128Load8x8U = 1 - V128Store16Lane = 1 - V128Store32Lane = 1 - V128Store64Lane = 1 - V128Store8Lane = 1 - -[MaxPerTransaction] - MaxBuiltInCallsPerTx = 100 - MaxNumberOfTransfersPerTx = 250 - MaxNumberOfTrieReadsPerTx = 1500 - -# Quadratic, Linear and Constant are the coefficients for a quadratic func. Separate variables are used for the -# sign of each coefficient, 0 meaning positive and 1 meaning negative -# The current values for the coefficients were computed based on benchmarking. -# For the given coefficients, the minimum of the function must not be lower than MinimumGasCost -[DynamicStorageLoad] - QuadraticCoefficient = 688 - SignOfQuadratic = 0 - LinearCoefficient = 31858 - SignOfLinear = 0 - ConstantCoefficient = 15287 - SignOfConstant = 0 - MinimumGasCost = 10000 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV2.toml b/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV2.toml deleted file mode 100644 index 38157aeb..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV2.toml +++ /dev/null @@ -1,827 +0,0 @@ -[BuiltInCost] - ChangeOwnerAddress = 5000000 - ClaimDeveloperRewards = 5000000 - SaveUserName = 1000000 - SaveKeyValue = 250000 - ESDTTransfer = 250000 - ESDTBurn = 250000 - ESDTLocalMint = 250000 - ESDTLocalBurn = 250000 - ESDTNFTCreate = 500000 - ESDTNFTAddQuantity = 500000 - ESDTNFTBurn = 500000 - ESDTNFTTransfer = 500000 - ESDTNFTChangeCreateOwner = 1000000 - ESDTNFTAddUri = 500000 - ESDTNFTUpdateAttributes = 500000 - ESDTNFTMultiTransfer = 1000000 - SetGuardian = 250000 - GuardAccount = 250000 - UnGuardAccount = 250000 - TrieLoadPerNode = 100000 - TrieStorePerNode = 50000 - -[MetaChainSystemSCsCost] - Stake = 5000000 - UnStake = 5000000 - UnBond = 5000000 - Claim = 5000000 - Get = 5000000 - ChangeRewardAddress = 5000000 - ChangeValidatorKeys = 5000000 - UnJail = 5000000 - ESDTIssue = 50000000 - ESDTOperations = 50000000 - Proposal = 5000000 - Vote = 500000 - DelegateVote = 1000000 - RevokeVote = 500000 - CloseProposal = 1000000 - DelegationOps = 1000000 - UnstakeTokens = 5000000 - UnbondTokens = 5000000 - GetActiveFund = 50000 - DelegationMgrOps = 50000000 - ValidatorToDelegation = 500000000 - GetAllNodeStates = 100000000 - FixWaitingListSize = 500000000 - -[BaseOperationCost] - StorePerByte = 50000 - ReleasePerByte = 10000 - DataCopyPerByte = 1000 - PersistPerByte = 10000 - CompilePerByte = 300 - AoTPreparePerByte = 300 - GetCode = 1000000 - -[BaseOpsAPICost] - GetSCAddress = 100 - GetOwnerAddress = 5000 - IsSmartContract = 5000 - GetShardOfAddress = 5000 - GetExternalBalance = 7000 - GetBlockHash = 10000 - TransferValue = 150000 - GetArgument = 100 - GetFunction = 100 - GetNumArguments = 100 - StorageStore = 250000 - StorageLoad = 100000 - CachedStorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - Log = 3750 - Finish = 1 - SignalError = 1 - GetBlockTimeStamp = 10000 - GetGasLeft = 100 - Int64GetArgument = 100 - Int64StorageStore = 250000 - Int64StorageLoad = 100000 - Int64Finish = 1000 - GetStateRootHash = 10000 - GetBlockNonce = 10000 - GetBlockEpoch = 10000 - GetBlockRound = 10000 - GetBlockRandomSeed = 10000 - ExecuteOnSameContext = 160000 - ExecuteOnDestContext = 160000 - DelegateExecution = 160000 - AsyncCallStep = 200000 - AsyncCallbackGasLock = 2000000 - ExecuteReadOnly = 160000 - CreateContract = 300000 - GetReturnData = 100 - GetNumReturnData = 100 - GetReturnDataSize = 100 - CleanReturnData = 100 - DeleteFromReturnData = 100 - GetOriginalTxHash = 10000 - GetPrevTxHash = 10000 - GetCurrentTxHash = 10000 - CreateAsyncCall = 200000 - SetAsyncCallback = 100000 - SetAsyncGroupCallback = 100000 - SetAsyncContextCallback = 100000 - GetCallbackClosure = 10000 - GetCodeMetadata = 10000 - IsBuiltinFunction = 10000 - -[EthAPICost] - UseGas = 100 - GetAddress = 100000 - GetExternalBalance = 70000 - GetBlockHash = 100000 - Call = 160000 - CallDataCopy = 200 - GetCallDataSize = 100 - CallCode = 160000 - CallDelegate = 160000 - CallStatic = 160000 - StorageStore = 250000 - StorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - CodeCopy = 1000 - GetCodeSize = 100 - GetBlockCoinbase = 100 - Create = 320000 - GetBlockDifficulty = 100 - ExternalCodeCopy = 3000 - GetExternalCodeSize = 2500 - GetGasLeft = 100 - GetBlockGasLimit = 100000 - GetTxGasPrice = 1000 - Log = 3750 - GetBlockNumber = 100000 - GetTxOrigin = 100000 - Finish = 1 - Revert = 1 - GetReturnDataSize = 200 - ReturnDataCopy = 500 - SelfDestruct = 5000000 - GetBlockTimeStamp = 100000 - -[BigIntAPICost] - BigIntNew = 2000 - BigIntByteLength = 2000 - BigIntUnsignedByteLength = 2000 - BigIntSignedByteLength = 2000 - BigIntGetBytes = 2000 - BigIntGetUnsignedBytes = 2000 - BigIntGetSignedBytes = 2000 - BigIntSetBytes = 2000 - BigIntSetUnsignedBytes = 2000 - BigIntSetSignedBytes = 2000 - BigIntIsInt64 = 2000 - BigIntGetInt64 = 2000 - BigIntSetInt64 = 2000 - BigIntAdd = 2000 - BigIntSub = 2000 - BigIntMul = 6000 - BigIntSqrt = 6000 - BigIntPow = 6000 - BigIntLog = 6000 - BigIntTDiv = 6000 - BigIntTMod = 6000 - BigIntEDiv = 6000 - BigIntEMod = 6000 - BigIntAbs = 2000 - BigIntNeg = 2000 - BigIntSign = 2000 - BigIntCmp = 2000 - BigIntNot = 2000 - BigIntAnd = 2000 - BigIntOr = 2000 - BigIntXor = 2000 - BigIntShr = 2000 - BigIntShl = 2000 - BigIntFinishUnsigned = 1000 - BigIntFinishSigned = 1000 - BigIntStorageLoadUnsigned = 100000 - BigIntStorageStoreUnsigned = 250000 - BigIntGetArgument = 1000 - BigIntGetUnsignedArgument = 1000 - BigIntGetSignedArgument = 1000 - BigIntGetCallValue = 1000 - BigIntGetExternalBalance = 10000 - CopyPerByteForTooBig = 1000 - -[CryptoAPICost] - SHA256 = 1000000 - Keccak256 = 1000000 - Ripemd160 = 1000000 - VerifyBLS = 5000000 - VerifyEd25519 = 2000000 - VerifySecp256k1 = 2000000 - EllipticCurveNew = 10000 - AddECC = 75000 - DoubleECC = 65000 - IsOnCurveECC = 10000 - ScalarMultECC = 400000 - MarshalECC = 13000 - MarshalCompressedECC = 15000 - UnmarshalECC = 20000 - UnmarshalCompressedECC = 270000 - GenerateKeyECC = 7000000 - EncodeDERSig = 10000000 - -[ManagedBufferAPICost] - MBufferNew = 2000 - MBufferNewFromBytes = 4000 - MBufferGetLength = 2000 - MBufferGetBytes = 2000 - MBufferGetByteSlice = 2000 - MBufferCopyByteSlice = 2000 - MBufferSetBytes = 2000 - MBufferAppend = 2000 - MBufferAppendBytes = 2000 - MBufferToBigIntUnsigned = 4000 - MBufferToBigIntSigned = 10000 - MBufferFromBigIntUnsigned = 4000 - MBufferFromBigIntSigned = 10000 - MBufferStorageStore = 250000 - MBufferStorageLoad = 100000 - MBufferGetArgument = 1000 - MBufferFinish = 1000 - MBufferSetRandom = 6000 - MBufferToBigFloat = 2000 - MBufferFromBigFloat = 2000 - -[BigFloatAPICost] - BigFloatNewFromParts = 3000 - BigFloatAdd = 7000 - BigFloatSub = 7000 - BigFloatMul = 7000 - BigFloatDiv = 7000 - BigFloatTruncate = 5000 - BigFloatNeg = 5000 - BigFloatClone = 5000 - BigFloatCmp = 4000 - BigFloatAbs = 5000 - BigFloatSqrt = 7000 - BigFloatPow = 10000 - BigFloatFloor = 5000 - BigFloatCeil = 5000 - BigFloatIsInt = 3000 - BigFloatSetBigInt = 3000 - BigFloatSetInt64 = 1000 - BigFloatGetConst = 1000 - -[WASMOpcodeCost] - Unreachable = 1 - Nop = 1 - Block = 1 - Loop = 1 - If = 1 - Else = 2 - End = 2 - Br = 2 - BrIf = 3 - BrTable = 2 - Return = 3 - Call = 3 - CallIndirect = 3 - Drop = 3 - Select = 3 - TypedSelect = 3 - LocalGet = 3 - LocalSet = 3 - LocalTee = 3 - GlobalGet = 3 - GlobalSet = 3 - I32Load = 3 - I64Load = 3 - F32Load = 6 - F64Load = 6 - I32Load8S = 3 - I32Load8U = 3 - I32Load16S = 3 - I32Load16U = 3 - I64Load8S = 3 - I64Load8U = 3 - I64Load16S = 3 - I64Load16U = 3 - I64Load32S = 3 - I64Load32U = 3 - I32Store = 3 - I64Store = 3 - F32Store = 12 - F64Store = 12 - I32Store8 = 3 - I32Store16 = 3 - I64Store8 = 3 - I64Store16 = 3 - I64Store32 = 3 - MemorySize = 5 - MemoryGrow = 5 - I32Const = 1 - I64Const = 1 - F32Const = 1 - F64Const = 1 - RefNull = 1 - RefIsNull = 1 - RefFunc = 1 - I32Eqz = 1 - I32Eq = 1 - I32Ne = 1 - I32LtS = 1 - I32LtU = 1 - I32GtS = 1 - I32GtU = 1 - I32LeS = 1 - I32LeU = 1 - I32GeS = 1 - I32GeU = 1 - I64Eqz = 1 - I64Eq = 1 - I64Ne = 1 - I64LtS = 1 - I64LtU = 1 - I64GtS = 1 - I64GtU = 1 - I64LeS = 1 - I64LeU = 1 - I64GeS = 1 - I64GeU = 1 - F32Eq = 6 - F32Ne = 6 - F32Lt = 6 - F32Gt = 6 - F32Le = 6 - F32Ge = 6 - F64Eq = 6 - F64Ne = 6 - F64Lt = 6 - F64Gt = 6 - F64Le = 6 - F64Ge = 6 - I32Clz = 100 - I32Ctz = 100 - I32Popcnt = 100 - I32Add = 1 - I32Sub = 1 - I32Mul = 3 - I32DivS = 18 - I32DivU = 18 - I32RemS = 18 - I32RemU = 18 - I32And = 1 - I32Or = 1 - I32Xor = 1 - I32Shl = 3 - I32ShrS = 3 - I32ShrU = 3 - I32Rotl = 5 - I32Rotr = 5 - I64Clz = 100 - I64Ctz = 100 - I64Popcnt = 100 - I64Add = 1 - I64Sub = 1 - I64Mul = 3 - I64DivS = 18 - I64DivU = 18 - I64RemS = 18 - I64RemU = 18 - I64And = 1 - I64Or = 1 - I64Xor = 1 - I64Shl = 3 - I64ShrS = 3 - I64ShrU = 3 - I64Rotl = 5 - I64Rotr = 5 - F32Abs = 5 - F32Neg = 5 - F32Ceil = 100 - F32Floor = 100 - F32Trunc = 100 - F32Nearest = 100 - F32Sqrt = 100 - F32Add = 5 - F32Sub = 5 - F32Mul = 15 - F32Div = 100 - F32Min = 15 - F32Max = 15 - F32Copysign = 5 - F64Abs = 5 - F64Neg = 5 - F64Ceil = 100 - F64Floor = 100 - F64Trunc = 100 - F64Nearest = 100 - F64Sqrt = 100 - F64Add = 5 - F64Sub = 5 - F64Mul = 15 - F64Div = 100 - F64Min = 15 - F64Max = 15 - F64Copysign = 5 - I32WrapI64 = 9 - I32TruncF32S = 100 - I32TruncF32U = 100 - I32TruncF64S = 100 - I32TruncF64U = 100 - I64ExtendI32S = 9 - I64ExtendI32U = 9 - I64TruncF32S = 100 - I64TruncF32U = 100 - I64TruncF64S = 100 - I64TruncF64U = 100 - F32ConvertI32S = 100 - F32ConvertI32U = 100 - F32ConvertI64S = 100 - F32ConvertI64U = 100 - F32DemoteF64 = 100 - F64ConvertI32S = 100 - F64ConvertI32U = 100 - F64ConvertI64S = 100 - F64ConvertI64U = 100 - F64PromoteF32 = 100 - I32ReinterpretF32 = 100 - I64ReinterpretF64 = 100 - F32ReinterpretI32 = 100 - F64ReinterpretI64 = 100 - I32Extend8S = 9 - I32Extend16S = 9 - I64Extend8S = 9 - I64Extend16S = 9 - I64Extend32S = 9 - I32TruncSatF32S = 100 - I32TruncSatF32U = 100 - I32TruncSatF64S = 100 - I32TruncSatF64U = 100 - I64TruncSatF32S = 100 - I64TruncSatF32U = 100 - I64TruncSatF64S = 100 - I64TruncSatF64U = 100 - MemoryInit = 5 - DataDrop = 5 - MemoryCopy = 5 - MemoryFill = 5 - TableInit = 10 - ElemDrop = 10 - TableCopy = 10 - TableFill = 10 - TableGet = 10 - TableSet = 10 - TableGrow = 10 - TableSize = 10 - AtomicNotify = 10 - I32AtomicWait = 10 - I64AtomicWait = 10 - AtomicFence = 10 - I32AtomicLoad = 15 - I64AtomicLoad = 15 - I32AtomicLoad8U = 15 - I32AtomicLoad16U = 15 - I64AtomicLoad8U = 15 - I64AtomicLoad16U = 15 - I64AtomicLoad32U = 15 - I32AtomicStore = 15 - I64AtomicStore = 15 - I32AtomicStore8 = 15 - I32AtomicStore16 = 15 - I64AtomicStore8 = 15 - I64AtomicStore16 = 15 - I64AtomicStore32 = 15 - I32AtomicRmwAdd = 20 - I64AtomicRmwAdd = 20 - I32AtomicRmw8AddU = 20 - I32AtomicRmw16AddU = 20 - I64AtomicRmw8AddU = 20 - I64AtomicRmw16AddU = 20 - I64AtomicRmw32AddU = 20 - I32AtomicRmwSub = 20 - I64AtomicRmwSub = 20 - I32AtomicRmw8SubU = 20 - I32AtomicRmw16SubU = 20 - I64AtomicRmw8SubU = 20 - I64AtomicRmw16SubU = 20 - I64AtomicRmw32SubU = 20 - I32AtomicRmwAnd = 15 - I64AtomicRmwAnd = 15 - I32AtomicRmw8AndU = 15 - I32AtomicRmw16AndU = 15 - I64AtomicRmw8AndU = 15 - I64AtomicRmw16AndU = 15 - I64AtomicRmw32AndU = 15 - I32AtomicRmwOr = 15 - I64AtomicRmwOr = 15 - I32AtomicRmw8OrU = 15 - I32AtomicRmw16OrU = 15 - I64AtomicRmw8OrU = 15 - I64AtomicRmw16OrU = 15 - I64AtomicRmw32OrU = 15 - I32AtomicRmwXor = 15 - I64AtomicRmwXor = 15 - I32AtomicRmw8XorU = 15 - I32AtomicRmw16XorU = 15 - I64AtomicRmw8XorU = 15 - I64AtomicRmw16XorU = 15 - I64AtomicRmw32XorU = 15 - I32AtomicRmwXchg = 30 - I64AtomicRmwXchg = 30 - I32AtomicRmw8XchgU = 30 - I32AtomicRmw16XchgU = 30 - I64AtomicRmw8XchgU = 30 - I64AtomicRmw16XchgU = 30 - I64AtomicRmw32XchgU = 30 - I32AtomicRmwCmpxchg = 30 - I64AtomicRmwCmpxchg = 30 - I32AtomicRmw8CmpxchgU = 30 - I32AtomicRmw16CmpxchgU = 30 - I64AtomicRmw8CmpxchgU = 30 - I64AtomicRmw16CmpxchgU = 30 - I64AtomicRmw32CmpxchgU = 30 - V128Load = 18 - V128Store = 18 - V128Const = 18 - I8x16Splat = 20 - I8x16ExtractLaneS = 20 - I8x16ExtractLaneU = 20 - I8x16ReplaceLane = 20 - I16x8Splat = 20 - I16x8ExtractLaneS = 20 - I16x8ExtractLaneU = 20 - I16x8ReplaceLane = 20 - I32x4Splat = 20 - I32x4ExtractLane = 20 - I32x4ReplaceLane = 20 - I64x2Splat = 20 - I64x2ExtractLane = 20 - I64x2ReplaceLane = 20 - F32x4Splat = 120 - F32x4ExtractLane = 120 - F32x4ReplaceLane = 120 - F64x2Splat = 120 - F64x2ExtractLane = 120 - F64x2ReplaceLane = 120 - I8x16Eq = 30 - I8x16Ne = 30 - I8x16LtS = 40 - I8x16LtU = 40 - I8x16GtS = 40 - I8x16GtU = 40 - I8x16LeS = 40 - I8x16LeU = 40 - I8x16GeS = 40 - I8x16GeU = 40 - I16x8Eq = 30 - I16x8Ne = 30 - I16x8LtS = 40 - I16x8LtU = 40 - I16x8GtS = 40 - I16x8GtU = 40 - I16x8LeS = 40 - I16x8LeU = 40 - I16x8GeS = 40 - I16x8GeU = 40 - I32x4Eq = 30 - I32x4Ne = 30 - I32x4LtS = 40 - I32x4LtU = 40 - I32x4GtS = 40 - I32x4GtU = 40 - I32x4LeS = 40 - I32x4LeU = 40 - I32x4GeS = 40 - I32x4GeU = 40 - F32x4Eq = 120 - F32x4Ne = 120 - F32x4Lt = 120 - F32x4Gt = 120 - F32x4Le = 120 - F32x4Ge = 120 - F64x2Eq = 120 - F64x2Ne = 120 - F64x2Lt = 120 - F64x2Gt = 120 - F64x2Le = 120 - F64x2Ge = 120 - V128Not = 40 - V128And = 40 - V128AndNot = 40 - V128Or = 40 - V128Xor = 40 - V128Bitselect = 40 - I8x16Neg = 20 - I8x16AnyTrue = 20 - I8x16AllTrue = 20 - I8x16Shl = 30 - I8x16ShrS = 30 - I8x16ShrU = 30 - I8x16Add = 20 - I8x16AddSaturateS = 20 - I8x16AddSaturateU = 20 - I8x16Sub = 20 - I8x16SubSaturateS = 20 - I8x16SubSaturateU = 20 - I8x16MinS = 40 - I8x16MinU = 40 - I8x16MaxS = 40 - I8x16MaxU = 40 - I8x16Mul = 80 - I16x8Neg = 40 - I16x8AnyTrue = 40 - I16x8AllTrue = 40 - I16x8Shl = 30 - I16x8ShrS = 30 - I16x8ShrU = 30 - I16x8Add = 20 - I16x8AddSaturateS = 20 - I16x8AddSaturateU = 20 - I16x8Sub = 20 - I16x8SubSaturateS = 20 - I16x8SubSaturateU = 20 - I16x8Mul = 40 - I16x8MinS = 40 - I16x8MinU = 40 - I16x8MaxS = 40 - I16x8MaxU = 40 - I32x4Neg = 20 - I32x4AnyTrue = 20 - I32x4AllTrue = 20 - I32x4Shl = 30 - I32x4ShrS = 30 - I32x4ShrU = 30 - I32x4Add = 20 - I32x4Sub = 20 - I32x4Mul = 80 - I32x4MinS = 40 - I32x4MinU = 40 - I32x4MaxS = 40 - I32x4MaxU = 40 - I64x2Neg = 40 - I64x2AnyTrue = 20 - I64x2AllTrue = 20 - I64x2Shl = 30 - I64x2ShrS = 30 - I64x2ShrU = 30 - I64x2Add = 20 - I64x2Sub = 20 - I64x2Mul = 80 - F32x4Abs = 200 - F32x4Neg = 200 - F32x4Sqrt = 1000 - F32x4Add = 200 - F32x4Sub = 200 - F32x4Mul = 800 - F32x4Div = 1000 - F32x4Min = 500 - F32x4Max = 500 - F64x2Abs = 500 - F64x2Neg = 400 - F64x2Sqrt = 1000 - F64x2Add = 200 - F64x2Sub = 200 - F64x2Mul = 800 - F64x2Div = 1000 - F64x2Min = 500 - F64x2Max = 500 - I32x4TruncSatF32x4S = 1000 - I32x4TruncSatF32x4U = 1000 - I64x2TruncSatF64x2S = 1000 - I64x2TruncSatF64x2U = 1000 - F32x4ConvertI32x4S = 1000 - F32x4ConvertI32x4U = 1000 - F64x2ConvertI64x2S = 1000 - F64x2ConvertI64x2U = 1000 - V8x16Swizzle = 1200 - V8x16Shuffle = 1200 - V8x16LoadSplat = 40 - V16x8LoadSplat = 40 - V32x4LoadSplat = 40 - V64x2LoadSplat = 40 - I8x16NarrowI16x8S = 800 - I8x16NarrowI16x8U = 800 - I16x8NarrowI32x4S = 800 - I16x8NarrowI32x4U = 800 - I16x8WidenLowI8x16S = 800 - I16x8WidenHighI8x16S = 800 - I16x8WidenLowI8x16U = 800 - I16x8WidenHighI8x16U = 800 - I32x4WidenLowI16x8S = 800 - I32x4WidenHighI16x8S = 800 - I32x4WidenLowI16x8U = 800 - I32x4WidenHighI16x8U = 800 - I16x8Load8x8S = 400 - I16x8Load8x8U = 400 - I32x4Load16x4S = 400 - I32x4Load16x4U = 400 - I64x2Load32x2S = 400 - I64x2Load32x2U = 400 - I8x16RoundingAverageU = 200 - I16x8RoundingAverageU = 200 - LocalAllocate = 2 - LocalsUnmetered = 100 - MaxMemoryGrowDelta = 100 - MaxMemoryGrow = 100 - Catch = 1 - CatchAll = 1 - Delegate = 1 - F32x4Ceil = 1 - F32x4DemoteF64x2Zero = 1 - F32x4Floor = 1 - F32x4Nearest = 1 - F32x4PMax = 1 - F32x4PMin = 1 - F32x4Trunc = 1 - F64x2Ceil = 1 - F64x2ConvertLowI32x4S = 1 - F64x2ConvertLowI32x4U = 1 - F64x2Floor = 1 - F64x2Nearest = 1 - F64x2PMax = 1 - F64x2PMin = 1 - F64x2PromoteLowF32x4 = 1 - F64x2Trunc = 1 - I16x8Abs = 1 - I16x8AddSatS = 1 - I16x8AddSatU = 1 - I16x8Bitmask = 1 - I16x8ExtAddPairwiseI8x16S = 1 - I16x8ExtAddPairwiseI8x16U = 1 - I16x8ExtMulHighI8x16S = 1 - I16x8ExtMulHighI8x16U = 1 - I16x8ExtMulLowI8x16S = 1 - I16x8ExtMulLowI8x16U = 1 - I16x8ExtendHighI8x16S = 1 - I16x8ExtendHighI8x16U = 1 - I16x8ExtendLowI8x16S = 1 - I16x8ExtendLowI8x16U = 1 - I16x8Q15MulrSatS = 1 - I16x8SubSatS = 1 - I16x8SubSatU = 1 - I32x4Abs = 1 - I32x4Bitmask = 1 - I32x4DotI16x8S = 1 - I32x4ExtAddPairwiseI16x8S = 1 - I32x4ExtAddPairwiseI16x8U = 1 - I32x4ExtMulHighI16x8S = 1 - I32x4ExtMulHighI16x8U = 1 - I32x4ExtMulLowI16x8S = 1 - I32x4ExtMulLowI16x8U = 1 - I32x4ExtendHighI16x8S = 1 - I32x4ExtendHighI16x8U = 1 - I32x4ExtendLowI16x8S = 1 - I32x4ExtendLowI16x8U = 1 - I32x4TruncSatF64x2SZero = 1 - I32x4TruncSatF64x2UZero = 1 - I64x2Abs = 1 - I64x2Bitmask = 1 - I64x2Eq = 1 - I64x2ExtMulHighI32x4S = 1 - I64x2ExtMulHighI32x4U = 1 - I64x2ExtMulLowI32x4S = 1 - I64x2ExtMulLowI32x4U = 1 - I64x2ExtendHighI32x4S = 1 - I64x2ExtendHighI32x4U = 1 - I64x2ExtendLowI32x4S = 1 - I64x2ExtendLowI32x4U = 1 - I64x2GeS = 1 - I64x2GtS = 1 - I64x2LeS = 1 - I64x2LtS = 1 - I64x2Ne = 1 - I8x16Abs = 1 - I8x16AddSatS = 1 - I8x16AddSatU = 1 - I8x16Bitmask = 1 - I8x16Popcnt = 1 - I8x16Shuffle = 1 - I8x16SubSatS = 1 - I8x16SubSatU = 1 - I8x16Swizzle = 1 - MemoryAtomicNotify = 1 - MemoryAtomicWait32 = 1 - MemoryAtomicWait64 = 1 - Rethrow = 1 - ReturnCall = 1 - ReturnCallIndirect = 1 - Throw = 1 - Try = 1 - Unwind = 1 - V128AnyTrue = 1 - V128Load16Lane = 1 - V128Load16Splat = 1 - V128Load16x4S = 1 - V128Load16x4U = 1 - V128Load32Lane = 1 - V128Load32Splat = 1 - V128Load32Zero = 1 - V128Load32x2S = 1 - V128Load32x2U = 1 - V128Load64Lane = 1 - V128Load64Splat = 1 - V128Load64Zero = 1 - V128Load8Lane = 1 - V128Load8Splat = 1 - V128Load8x8S = 1 - V128Load8x8U = 1 - V128Store16Lane = 1 - V128Store32Lane = 1 - V128Store64Lane = 1 - V128Store8Lane = 1 - -[MaxPerTransaction] - MaxBuiltInCallsPerTx = 100 - MaxNumberOfTransfersPerTx = 250 - MaxNumberOfTrieReadsPerTx = 1500 - -# Quadratic, Linear and Constant are the coefficients for a quadratic func. Separate variables are used for the -# sign of each coefficient, 0 meaning positive and 1 meaning negative -# The current values for the coefficients were computed based on benchmarking. -# For the given coefficients, the minimum of the function must not be lower than MinimumGasCost -[DynamicStorageLoad] - QuadraticCoefficient = 688 - SignOfQuadratic = 0 - LinearCoefficient = 31858 - SignOfLinear = 0 - ConstantCoefficient = 15287 - SignOfConstant = 0 - MinimumGasCost = 10000 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV3.toml b/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV3.toml deleted file mode 100644 index 3767f028..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV3.toml +++ /dev/null @@ -1,827 +0,0 @@ -[BuiltInCost] - ChangeOwnerAddress = 5000000 - ClaimDeveloperRewards = 5000000 - SaveUserName = 1000000 - SaveKeyValue = 250000 - ESDTTransfer = 250000 - ESDTBurn = 250000 - ESDTLocalMint = 250000 - ESDTLocalBurn = 250000 - ESDTNFTCreate = 500000 - ESDTNFTAddQuantity = 500000 - ESDTNFTBurn = 500000 - ESDTNFTTransfer = 500000 - ESDTNFTChangeCreateOwner = 1000000 - ESDTNFTAddUri = 500000 - ESDTNFTUpdateAttributes = 500000 - ESDTNFTMultiTransfer = 1000000 - SetGuardian = 250000 - GuardAccount = 250000 - UnGuardAccount = 250000 - TrieLoadPerNode = 100000 - TrieStorePerNode = 50000 - -[MetaChainSystemSCsCost] - Stake = 5000000 - UnStake = 5000000 - UnBond = 5000000 - Claim = 5000000 - Get = 5000000 - ChangeRewardAddress = 5000000 - ChangeValidatorKeys = 5000000 - UnJail = 5000000 - DelegationOps = 1000000 - DelegationMgrOps = 50000000 - ValidatorToDelegation = 500000000 - ESDTIssue = 50000000 - ESDTOperations = 50000000 - Proposal = 50000000 - Vote = 50000000 - DelegateVote = 50000000 - RevokeVote = 50000000 - CloseProposal = 50000000 - GetAllNodeStates = 20000000 - UnstakeTokens = 5000000 - UnbondTokens = 5000000 - GetActiveFund = 50000 - FixWaitingListSize = 500000000 - -[BaseOperationCost] - StorePerByte = 50000 - ReleasePerByte = 10000 - DataCopyPerByte = 1000 - PersistPerByte = 10000 - CompilePerByte = 300 - AoTPreparePerByte = 300 - GetCode = 1000000 - -[BaseOpsAPICost] - GetSCAddress = 100 - GetOwnerAddress = 5000 - IsSmartContract = 5000 - GetShardOfAddress = 5000 - GetExternalBalance = 7000 - GetBlockHash = 10000 - TransferValue = 150000 - GetArgument = 100 - GetFunction = 100 - GetNumArguments = 100 - StorageStore = 250000 - StorageLoad = 100000 - CachedStorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - Log = 3750 - Finish = 1 - SignalError = 1 - GetBlockTimeStamp = 10000 - GetGasLeft = 100 - Int64GetArgument = 100 - Int64StorageStore = 250000 - Int64StorageLoad = 100000 - Int64Finish = 1000 - GetStateRootHash = 10000 - GetBlockNonce = 10000 - GetBlockEpoch = 10000 - GetBlockRound = 10000 - GetBlockRandomSeed = 10000 - ExecuteOnSameContext = 160000 - ExecuteOnDestContext = 160000 - DelegateExecution = 160000 - AsyncCallStep = 200000 - AsyncCallbackGasLock = 2000000 - ExecuteReadOnly = 160000 - CreateContract = 300000 - GetReturnData = 100 - GetNumReturnData = 100 - GetReturnDataSize = 100 - CleanReturnData = 100 - DeleteFromReturnData = 100 - GetOriginalTxHash = 10000 - GetPrevTxHash = 10000 - GetCurrentTxHash = 10000 - CreateAsyncCall = 200000 - SetAsyncCallback = 100000 - SetAsyncGroupCallback = 100000 - SetAsyncContextCallback = 100000 - GetCallbackClosure = 10000 - GetCodeMetadata = 10000 - IsBuiltinFunction = 10000 - -[EthAPICost] - UseGas = 100 - GetAddress = 100000 - GetExternalBalance = 70000 - GetBlockHash = 100000 - Call = 160000 - CallDataCopy = 200 - GetCallDataSize = 100 - CallCode = 160000 - CallDelegate = 160000 - CallStatic = 160000 - StorageStore = 250000 - StorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - CodeCopy = 1000 - GetCodeSize = 100 - GetBlockCoinbase = 100 - Create = 320000 - GetBlockDifficulty = 100 - ExternalCodeCopy = 3000 - GetExternalCodeSize = 2500 - GetGasLeft = 100 - GetBlockGasLimit = 100000 - GetTxGasPrice = 1000 - Log = 3750 - GetBlockNumber = 100000 - GetTxOrigin = 100000 - Finish = 1 - Revert = 1 - GetReturnDataSize = 200 - ReturnDataCopy = 500 - SelfDestruct = 5000000 - GetBlockTimeStamp = 100000 - -[BigIntAPICost] - BigIntNew = 2000 - BigIntByteLength = 2000 - BigIntUnsignedByteLength = 2000 - BigIntSignedByteLength = 2000 - BigIntGetBytes = 2000 - BigIntGetUnsignedBytes = 2000 - BigIntGetSignedBytes = 2000 - BigIntSetBytes = 2000 - BigIntSetUnsignedBytes = 2000 - BigIntSetSignedBytes = 2000 - BigIntIsInt64 = 2000 - BigIntGetInt64 = 2000 - BigIntSetInt64 = 2000 - BigIntAdd = 2000 - BigIntSub = 2000 - BigIntMul = 6000 - BigIntSqrt = 6000 - BigIntPow = 6000 - BigIntLog = 6000 - BigIntTDiv = 6000 - BigIntTMod = 6000 - BigIntEDiv = 6000 - BigIntEMod = 6000 - BigIntAbs = 2000 - BigIntNeg = 2000 - BigIntSign = 2000 - BigIntCmp = 2000 - BigIntNot = 2000 - BigIntAnd = 2000 - BigIntOr = 2000 - BigIntXor = 2000 - BigIntShr = 2000 - BigIntShl = 2000 - BigIntFinishUnsigned = 1000 - BigIntFinishSigned = 1000 - BigIntStorageLoadUnsigned = 100000 - BigIntStorageStoreUnsigned = 250000 - BigIntGetArgument = 1000 - BigIntGetUnsignedArgument = 1000 - BigIntGetSignedArgument = 1000 - BigIntGetCallValue = 1000 - BigIntGetExternalBalance = 10000 - CopyPerByteForTooBig = 1000 - -[CryptoAPICost] - SHA256 = 1000000 - Keccak256 = 1000000 - Ripemd160 = 1000000 - VerifyBLS = 5000000 - VerifyEd25519 = 2000000 - VerifySecp256k1 = 2000000 - EllipticCurveNew = 10000 - AddECC = 75000 - DoubleECC = 65000 - IsOnCurveECC = 10000 - ScalarMultECC = 400000 - MarshalECC = 13000 - MarshalCompressedECC = 15000 - UnmarshalECC = 20000 - UnmarshalCompressedECC = 270000 - GenerateKeyECC = 7000000 - EncodeDERSig = 10000000 - -[ManagedBufferAPICost] - MBufferNew = 2000 - MBufferNewFromBytes = 4000 - MBufferGetLength = 2000 - MBufferGetBytes = 2000 - MBufferGetByteSlice = 2000 - MBufferCopyByteSlice = 2000 - MBufferSetBytes = 2000 - MBufferAppend = 2000 - MBufferAppendBytes = 2000 - MBufferToBigIntUnsigned = 4000 - MBufferToBigIntSigned = 10000 - MBufferFromBigIntUnsigned = 4000 - MBufferFromBigIntSigned = 10000 - MBufferStorageStore = 250000 - MBufferStorageLoad = 100000 - MBufferGetArgument = 1000 - MBufferFinish = 1000 - MBufferSetRandom = 6000 - MBufferToBigFloat = 2000 - MBufferFromBigFloat = 2000 - -[BigFloatAPICost] - BigFloatNewFromParts = 3000 - BigFloatAdd = 7000 - BigFloatSub = 7000 - BigFloatMul = 7000 - BigFloatDiv = 7000 - BigFloatTruncate = 5000 - BigFloatNeg = 5000 - BigFloatClone = 5000 - BigFloatCmp = 4000 - BigFloatAbs = 5000 - BigFloatSqrt = 7000 - BigFloatPow = 10000 - BigFloatFloor = 5000 - BigFloatCeil = 5000 - BigFloatIsInt = 3000 - BigFloatSetBigInt = 3000 - BigFloatSetInt64 = 1000 - BigFloatGetConst = 1000 - -[WASMOpcodeCost] - Unreachable = 1 - Nop = 1 - Block = 1 - Loop = 1 - If = 1 - Else = 2 - End = 2 - Br = 2 - BrIf = 3 - BrTable = 2 - Return = 3 - Call = 3 - CallIndirect = 3 - Drop = 3 - Select = 3 - TypedSelect = 3 - LocalGet = 3 - LocalSet = 3 - LocalTee = 3 - GlobalGet = 3 - GlobalSet = 3 - I32Load = 3 - I64Load = 3 - F32Load = 6 - F64Load = 6 - I32Load8S = 3 - I32Load8U = 3 - I32Load16S = 3 - I32Load16U = 3 - I64Load8S = 3 - I64Load8U = 3 - I64Load16S = 3 - I64Load16U = 3 - I64Load32S = 3 - I64Load32U = 3 - I32Store = 3 - I64Store = 3 - F32Store = 12 - F64Store = 12 - I32Store8 = 3 - I32Store16 = 3 - I64Store8 = 3 - I64Store16 = 3 - I64Store32 = 3 - MemorySize = 5 - MemoryGrow = 5 - I32Const = 1 - I64Const = 1 - F32Const = 1 - F64Const = 1 - RefNull = 1 - RefIsNull = 1 - RefFunc = 1 - I32Eqz = 1 - I32Eq = 1 - I32Ne = 1 - I32LtS = 1 - I32LtU = 1 - I32GtS = 1 - I32GtU = 1 - I32LeS = 1 - I32LeU = 1 - I32GeS = 1 - I32GeU = 1 - I64Eqz = 1 - I64Eq = 1 - I64Ne = 1 - I64LtS = 1 - I64LtU = 1 - I64GtS = 1 - I64GtU = 1 - I64LeS = 1 - I64LeU = 1 - I64GeS = 1 - I64GeU = 1 - F32Eq = 6 - F32Ne = 6 - F32Lt = 6 - F32Gt = 6 - F32Le = 6 - F32Ge = 6 - F64Eq = 6 - F64Ne = 6 - F64Lt = 6 - F64Gt = 6 - F64Le = 6 - F64Ge = 6 - I32Clz = 100 - I32Ctz = 100 - I32Popcnt = 100 - I32Add = 1 - I32Sub = 1 - I32Mul = 3 - I32DivS = 18 - I32DivU = 18 - I32RemS = 18 - I32RemU = 18 - I32And = 1 - I32Or = 1 - I32Xor = 1 - I32Shl = 3 - I32ShrS = 3 - I32ShrU = 3 - I32Rotl = 5 - I32Rotr = 5 - I64Clz = 100 - I64Ctz = 100 - I64Popcnt = 100 - I64Add = 1 - I64Sub = 1 - I64Mul = 3 - I64DivS = 18 - I64DivU = 18 - I64RemS = 18 - I64RemU = 18 - I64And = 1 - I64Or = 1 - I64Xor = 1 - I64Shl = 3 - I64ShrS = 3 - I64ShrU = 3 - I64Rotl = 5 - I64Rotr = 5 - F32Abs = 5 - F32Neg = 5 - F32Ceil = 100 - F32Floor = 100 - F32Trunc = 100 - F32Nearest = 100 - F32Sqrt = 100 - F32Add = 5 - F32Sub = 5 - F32Mul = 15 - F32Div = 100 - F32Min = 15 - F32Max = 15 - F32Copysign = 5 - F64Abs = 5 - F64Neg = 5 - F64Ceil = 100 - F64Floor = 100 - F64Trunc = 100 - F64Nearest = 100 - F64Sqrt = 100 - F64Add = 5 - F64Sub = 5 - F64Mul = 15 - F64Div = 100 - F64Min = 15 - F64Max = 15 - F64Copysign = 5 - I32WrapI64 = 9 - I32TruncF32S = 100 - I32TruncF32U = 100 - I32TruncF64S = 100 - I32TruncF64U = 100 - I64ExtendI32S = 9 - I64ExtendI32U = 9 - I64TruncF32S = 100 - I64TruncF32U = 100 - I64TruncF64S = 100 - I64TruncF64U = 100 - F32ConvertI32S = 100 - F32ConvertI32U = 100 - F32ConvertI64S = 100 - F32ConvertI64U = 100 - F32DemoteF64 = 100 - F64ConvertI32S = 100 - F64ConvertI32U = 100 - F64ConvertI64S = 100 - F64ConvertI64U = 100 - F64PromoteF32 = 100 - I32ReinterpretF32 = 100 - I64ReinterpretF64 = 100 - F32ReinterpretI32 = 100 - F64ReinterpretI64 = 100 - I32Extend8S = 9 - I32Extend16S = 9 - I64Extend8S = 9 - I64Extend16S = 9 - I64Extend32S = 9 - I32TruncSatF32S = 100 - I32TruncSatF32U = 100 - I32TruncSatF64S = 100 - I32TruncSatF64U = 100 - I64TruncSatF32S = 100 - I64TruncSatF32U = 100 - I64TruncSatF64S = 100 - I64TruncSatF64U = 100 - MemoryInit = 5 - DataDrop = 5 - MemoryCopy = 5 - MemoryFill = 5 - TableInit = 10 - ElemDrop = 10 - TableCopy = 10 - TableFill = 10 - TableGet = 10 - TableSet = 10 - TableGrow = 10 - TableSize = 10 - AtomicNotify = 10 - I32AtomicWait = 10 - I64AtomicWait = 10 - AtomicFence = 10 - I32AtomicLoad = 15 - I64AtomicLoad = 15 - I32AtomicLoad8U = 15 - I32AtomicLoad16U = 15 - I64AtomicLoad8U = 15 - I64AtomicLoad16U = 15 - I64AtomicLoad32U = 15 - I32AtomicStore = 15 - I64AtomicStore = 15 - I32AtomicStore8 = 15 - I32AtomicStore16 = 15 - I64AtomicStore8 = 15 - I64AtomicStore16 = 15 - I64AtomicStore32 = 15 - I32AtomicRmwAdd = 20 - I64AtomicRmwAdd = 20 - I32AtomicRmw8AddU = 20 - I32AtomicRmw16AddU = 20 - I64AtomicRmw8AddU = 20 - I64AtomicRmw16AddU = 20 - I64AtomicRmw32AddU = 20 - I32AtomicRmwSub = 20 - I64AtomicRmwSub = 20 - I32AtomicRmw8SubU = 20 - I32AtomicRmw16SubU = 20 - I64AtomicRmw8SubU = 20 - I64AtomicRmw16SubU = 20 - I64AtomicRmw32SubU = 20 - I32AtomicRmwAnd = 15 - I64AtomicRmwAnd = 15 - I32AtomicRmw8AndU = 15 - I32AtomicRmw16AndU = 15 - I64AtomicRmw8AndU = 15 - I64AtomicRmw16AndU = 15 - I64AtomicRmw32AndU = 15 - I32AtomicRmwOr = 15 - I64AtomicRmwOr = 15 - I32AtomicRmw8OrU = 15 - I32AtomicRmw16OrU = 15 - I64AtomicRmw8OrU = 15 - I64AtomicRmw16OrU = 15 - I64AtomicRmw32OrU = 15 - I32AtomicRmwXor = 15 - I64AtomicRmwXor = 15 - I32AtomicRmw8XorU = 15 - I32AtomicRmw16XorU = 15 - I64AtomicRmw8XorU = 15 - I64AtomicRmw16XorU = 15 - I64AtomicRmw32XorU = 15 - I32AtomicRmwXchg = 30 - I64AtomicRmwXchg = 30 - I32AtomicRmw8XchgU = 30 - I32AtomicRmw16XchgU = 30 - I64AtomicRmw8XchgU = 30 - I64AtomicRmw16XchgU = 30 - I64AtomicRmw32XchgU = 30 - I32AtomicRmwCmpxchg = 30 - I64AtomicRmwCmpxchg = 30 - I32AtomicRmw8CmpxchgU = 30 - I32AtomicRmw16CmpxchgU = 30 - I64AtomicRmw8CmpxchgU = 30 - I64AtomicRmw16CmpxchgU = 30 - I64AtomicRmw32CmpxchgU = 30 - V128Load = 18 - V128Store = 18 - V128Const = 18 - I8x16Splat = 20 - I8x16ExtractLaneS = 20 - I8x16ExtractLaneU = 20 - I8x16ReplaceLane = 20 - I16x8Splat = 20 - I16x8ExtractLaneS = 20 - I16x8ExtractLaneU = 20 - I16x8ReplaceLane = 20 - I32x4Splat = 20 - I32x4ExtractLane = 20 - I32x4ReplaceLane = 20 - I64x2Splat = 20 - I64x2ExtractLane = 20 - I64x2ReplaceLane = 20 - F32x4Splat = 120 - F32x4ExtractLane = 120 - F32x4ReplaceLane = 120 - F64x2Splat = 120 - F64x2ExtractLane = 120 - F64x2ReplaceLane = 120 - I8x16Eq = 30 - I8x16Ne = 30 - I8x16LtS = 40 - I8x16LtU = 40 - I8x16GtS = 40 - I8x16GtU = 40 - I8x16LeS = 40 - I8x16LeU = 40 - I8x16GeS = 40 - I8x16GeU = 40 - I16x8Eq = 30 - I16x8Ne = 30 - I16x8LtS = 40 - I16x8LtU = 40 - I16x8GtS = 40 - I16x8GtU = 40 - I16x8LeS = 40 - I16x8LeU = 40 - I16x8GeS = 40 - I16x8GeU = 40 - I32x4Eq = 30 - I32x4Ne = 30 - I32x4LtS = 40 - I32x4LtU = 40 - I32x4GtS = 40 - I32x4GtU = 40 - I32x4LeS = 40 - I32x4LeU = 40 - I32x4GeS = 40 - I32x4GeU = 40 - F32x4Eq = 120 - F32x4Ne = 120 - F32x4Lt = 120 - F32x4Gt = 120 - F32x4Le = 120 - F32x4Ge = 120 - F64x2Eq = 120 - F64x2Ne = 120 - F64x2Lt = 120 - F64x2Gt = 120 - F64x2Le = 120 - F64x2Ge = 120 - V128Not = 40 - V128And = 40 - V128AndNot = 40 - V128Or = 40 - V128Xor = 40 - V128Bitselect = 40 - I8x16Neg = 20 - I8x16AnyTrue = 20 - I8x16AllTrue = 20 - I8x16Shl = 30 - I8x16ShrS = 30 - I8x16ShrU = 30 - I8x16Add = 20 - I8x16AddSaturateS = 20 - I8x16AddSaturateU = 20 - I8x16Sub = 20 - I8x16SubSaturateS = 20 - I8x16SubSaturateU = 20 - I8x16MinS = 40 - I8x16MinU = 40 - I8x16MaxS = 40 - I8x16MaxU = 40 - I8x16Mul = 80 - I16x8Neg = 40 - I16x8AnyTrue = 40 - I16x8AllTrue = 40 - I16x8Shl = 30 - I16x8ShrS = 30 - I16x8ShrU = 30 - I16x8Add = 20 - I16x8AddSaturateS = 20 - I16x8AddSaturateU = 20 - I16x8Sub = 20 - I16x8SubSaturateS = 20 - I16x8SubSaturateU = 20 - I16x8Mul = 40 - I16x8MinS = 40 - I16x8MinU = 40 - I16x8MaxS = 40 - I16x8MaxU = 40 - I32x4Neg = 20 - I32x4AnyTrue = 20 - I32x4AllTrue = 20 - I32x4Shl = 30 - I32x4ShrS = 30 - I32x4ShrU = 30 - I32x4Add = 20 - I32x4Sub = 20 - I32x4Mul = 80 - I32x4MinS = 40 - I32x4MinU = 40 - I32x4MaxS = 40 - I32x4MaxU = 40 - I64x2Neg = 40 - I64x2AnyTrue = 20 - I64x2AllTrue = 20 - I64x2Shl = 30 - I64x2ShrS = 30 - I64x2ShrU = 30 - I64x2Add = 20 - I64x2Sub = 20 - I64x2Mul = 80 - F32x4Abs = 200 - F32x4Neg = 200 - F32x4Sqrt = 1000 - F32x4Add = 200 - F32x4Sub = 200 - F32x4Mul = 800 - F32x4Div = 1000 - F32x4Min = 500 - F32x4Max = 500 - F64x2Abs = 500 - F64x2Neg = 400 - F64x2Sqrt = 1000 - F64x2Add = 200 - F64x2Sub = 200 - F64x2Mul = 800 - F64x2Div = 1000 - F64x2Min = 500 - F64x2Max = 500 - I32x4TruncSatF32x4S = 1000 - I32x4TruncSatF32x4U = 1000 - I64x2TruncSatF64x2S = 1000 - I64x2TruncSatF64x2U = 1000 - F32x4ConvertI32x4S = 1000 - F32x4ConvertI32x4U = 1000 - F64x2ConvertI64x2S = 1000 - F64x2ConvertI64x2U = 1000 - V8x16Swizzle = 1200 - V8x16Shuffle = 1200 - V8x16LoadSplat = 40 - V16x8LoadSplat = 40 - V32x4LoadSplat = 40 - V64x2LoadSplat = 40 - I8x16NarrowI16x8S = 800 - I8x16NarrowI16x8U = 800 - I16x8NarrowI32x4S = 800 - I16x8NarrowI32x4U = 800 - I16x8WidenLowI8x16S = 800 - I16x8WidenHighI8x16S = 800 - I16x8WidenLowI8x16U = 800 - I16x8WidenHighI8x16U = 800 - I32x4WidenLowI16x8S = 800 - I32x4WidenHighI16x8S = 800 - I32x4WidenLowI16x8U = 800 - I32x4WidenHighI16x8U = 800 - I16x8Load8x8S = 400 - I16x8Load8x8U = 400 - I32x4Load16x4S = 400 - I32x4Load16x4U = 400 - I64x2Load32x2S = 400 - I64x2Load32x2U = 400 - I8x16RoundingAverageU = 200 - I16x8RoundingAverageU = 200 - LocalAllocate = 2 - LocalsUnmetered = 100 - MaxMemoryGrowDelta = 100 - MaxMemoryGrow = 100 - Catch = 1 - CatchAll = 1 - Delegate = 1 - F32x4Ceil = 1 - F32x4DemoteF64x2Zero = 1 - F32x4Floor = 1 - F32x4Nearest = 1 - F32x4PMax = 1 - F32x4PMin = 1 - F32x4Trunc = 1 - F64x2Ceil = 1 - F64x2ConvertLowI32x4S = 1 - F64x2ConvertLowI32x4U = 1 - F64x2Floor = 1 - F64x2Nearest = 1 - F64x2PMax = 1 - F64x2PMin = 1 - F64x2PromoteLowF32x4 = 1 - F64x2Trunc = 1 - I16x8Abs = 1 - I16x8AddSatS = 1 - I16x8AddSatU = 1 - I16x8Bitmask = 1 - I16x8ExtAddPairwiseI8x16S = 1 - I16x8ExtAddPairwiseI8x16U = 1 - I16x8ExtMulHighI8x16S = 1 - I16x8ExtMulHighI8x16U = 1 - I16x8ExtMulLowI8x16S = 1 - I16x8ExtMulLowI8x16U = 1 - I16x8ExtendHighI8x16S = 1 - I16x8ExtendHighI8x16U = 1 - I16x8ExtendLowI8x16S = 1 - I16x8ExtendLowI8x16U = 1 - I16x8Q15MulrSatS = 1 - I16x8SubSatS = 1 - I16x8SubSatU = 1 - I32x4Abs = 1 - I32x4Bitmask = 1 - I32x4DotI16x8S = 1 - I32x4ExtAddPairwiseI16x8S = 1 - I32x4ExtAddPairwiseI16x8U = 1 - I32x4ExtMulHighI16x8S = 1 - I32x4ExtMulHighI16x8U = 1 - I32x4ExtMulLowI16x8S = 1 - I32x4ExtMulLowI16x8U = 1 - I32x4ExtendHighI16x8S = 1 - I32x4ExtendHighI16x8U = 1 - I32x4ExtendLowI16x8S = 1 - I32x4ExtendLowI16x8U = 1 - I32x4TruncSatF64x2SZero = 1 - I32x4TruncSatF64x2UZero = 1 - I64x2Abs = 1 - I64x2Bitmask = 1 - I64x2Eq = 1 - I64x2ExtMulHighI32x4S = 1 - I64x2ExtMulHighI32x4U = 1 - I64x2ExtMulLowI32x4S = 1 - I64x2ExtMulLowI32x4U = 1 - I64x2ExtendHighI32x4S = 1 - I64x2ExtendHighI32x4U = 1 - I64x2ExtendLowI32x4S = 1 - I64x2ExtendLowI32x4U = 1 - I64x2GeS = 1 - I64x2GtS = 1 - I64x2LeS = 1 - I64x2LtS = 1 - I64x2Ne = 1 - I8x16Abs = 1 - I8x16AddSatS = 1 - I8x16AddSatU = 1 - I8x16Bitmask = 1 - I8x16Popcnt = 1 - I8x16Shuffle = 1 - I8x16SubSatS = 1 - I8x16SubSatU = 1 - I8x16Swizzle = 1 - MemoryAtomicNotify = 1 - MemoryAtomicWait32 = 1 - MemoryAtomicWait64 = 1 - Rethrow = 1 - ReturnCall = 1 - ReturnCallIndirect = 1 - Throw = 1 - Try = 1 - Unwind = 1 - V128AnyTrue = 1 - V128Load16Lane = 1 - V128Load16Splat = 1 - V128Load16x4S = 1 - V128Load16x4U = 1 - V128Load32Lane = 1 - V128Load32Splat = 1 - V128Load32Zero = 1 - V128Load32x2S = 1 - V128Load32x2U = 1 - V128Load64Lane = 1 - V128Load64Splat = 1 - V128Load64Zero = 1 - V128Load8Lane = 1 - V128Load8Splat = 1 - V128Load8x8S = 1 - V128Load8x8U = 1 - V128Store16Lane = 1 - V128Store32Lane = 1 - V128Store64Lane = 1 - V128Store8Lane = 1 - -[MaxPerTransaction] - MaxBuiltInCallsPerTx = 100 - MaxNumberOfTransfersPerTx = 250 - MaxNumberOfTrieReadsPerTx = 1500 - -# Quadratic, Linear and Constant are the coefficients for a quadratic func. Separate variables are used for the -# sign of each coefficient, 0 meaning positive and 1 meaning negative -# The current values for the coefficients were computed based on benchmarking. -# For the given coefficients, the minimum of the function must not be lower than MinimumGasCost -[DynamicStorageLoad] - QuadraticCoefficient = 688 - SignOfQuadratic = 0 - LinearCoefficient = 31858 - SignOfLinear = 0 - ConstantCoefficient = 15287 - SignOfConstant = 0 - MinimumGasCost = 10000 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV4.toml b/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV4.toml deleted file mode 100644 index f7d8e3a0..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV4.toml +++ /dev/null @@ -1,827 +0,0 @@ -[BuiltInCost] - ChangeOwnerAddress = 5000000 - ClaimDeveloperRewards = 5000000 - SaveUserName = 1000000 - SaveKeyValue = 100000 - ESDTTransfer = 200000 - ESDTBurn = 100000 - ESDTLocalMint = 50000 - ESDTLocalBurn = 50000 - ESDTNFTCreate = 150000 - ESDTNFTAddQuantity = 50000 - ESDTNFTBurn = 50000 - ESDTNFTTransfer = 200000 - ESDTNFTChangeCreateOwner = 1000000 - ESDTNFTAddUri = 50000 - ESDTNFTUpdateAttributes = 50000 - ESDTNFTMultiTransfer = 200000 - SetGuardian = 250000 - GuardAccount = 250000 - UnGuardAccount = 250000 - TrieLoadPerNode = 100000 - TrieStorePerNode = 50000 - -[MetaChainSystemSCsCost] - Stake = 5000000 - UnStake = 5000000 - UnBond = 5000000 - Claim = 5000000 - Get = 5000000 - ChangeRewardAddress = 5000000 - ChangeValidatorKeys = 5000000 - UnJail = 5000000 - DelegationOps = 1000000 - DelegationMgrOps = 50000000 - ValidatorToDelegation = 500000000 - ESDTIssue = 50000000 - ESDTOperations = 50000000 - Proposal = 50000000 - Vote = 50000000 - DelegateVote = 50000000 - RevokeVote = 50000000 - CloseProposal = 50000000 - GetAllNodeStates = 20000000 - UnstakeTokens = 5000000 - UnbondTokens = 5000000 - GetActiveFund = 50000 - FixWaitingListSize = 500000000 - -[BaseOperationCost] - StorePerByte = 10000 - ReleasePerByte = 1000 - DataCopyPerByte = 100 - PersistPerByte = 1000 - CompilePerByte = 300 - AoTPreparePerByte = 100 - GetCode = 1000000 - -[BaseOpsAPICost] - GetSCAddress = 100 - GetOwnerAddress = 5000 - IsSmartContract = 5000 - GetShardOfAddress = 5000 - GetExternalBalance = 7000 - GetBlockHash = 10000 - TransferValue = 100000 - GetArgument = 100 - GetFunction = 100 - GetNumArguments = 100 - StorageStore = 75000 - StorageLoad = 50000 - CachedStorageLoad = 50000 - GetCaller = 100 - GetCallValue = 100 - Log = 3750 - Finish = 1 - SignalError = 1 - GetBlockTimeStamp = 10000 - GetGasLeft = 100 - Int64GetArgument = 100 - Int64StorageStore = 75000 - Int64StorageLoad = 50000 - Int64Finish = 1000 - GetStateRootHash = 10000 - GetBlockNonce = 10000 - GetBlockEpoch = 10000 - GetBlockRound = 10000 - GetBlockRandomSeed = 10000 - ExecuteOnSameContext = 100000 - ExecuteOnDestContext = 100000 - DelegateExecution = 100000 - AsyncCallStep = 100000 - AsyncCallbackGasLock = 4000000 - CreateAsyncCall = 200000 - SetAsyncCallback = 100000 - SetAsyncGroupCallback = 100000 - SetAsyncContextCallback = 100000 - ExecuteReadOnly = 160000 - CreateContract = 300000 - GetReturnData = 100 - GetNumReturnData = 100 - GetReturnDataSize = 100 - CleanReturnData = 100 - DeleteFromReturnData = 100 - GetOriginalTxHash = 10000 - GetPrevTxHash = 10000 - GetCurrentTxHash = 10000 - GetCallbackClosure = 10000 - GetCodeMetadata = 10000 - IsBuiltinFunction = 10000 - -[EthAPICost] - UseGas = 100 - GetAddress = 100000 - GetExternalBalance = 70000 - GetBlockHash = 100000 - Call = 160000 - CallDataCopy = 200 - GetCallDataSize = 100 - CallCode = 160000 - CallDelegate = 160000 - CallStatic = 160000 - StorageStore = 250000 - StorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - CodeCopy = 1000 - GetCodeSize = 100 - GetBlockCoinbase = 100 - Create = 320000 - GetBlockDifficulty = 100 - ExternalCodeCopy = 3000 - GetExternalCodeSize = 2500 - GetGasLeft = 100 - GetBlockGasLimit = 100000 - GetTxGasPrice = 1000 - Log = 3750 - GetBlockNumber = 100000 - GetTxOrigin = 100000 - Finish = 1 - Revert = 1 - GetReturnDataSize = 200 - ReturnDataCopy = 500 - SelfDestruct = 5000000 - GetBlockTimeStamp = 100000 - -[BigIntAPICost] - BigIntNew = 2000 - BigIntByteLength = 2000 - BigIntUnsignedByteLength = 2000 - BigIntSignedByteLength = 2000 - BigIntGetBytes = 2000 - BigIntGetUnsignedBytes = 2000 - BigIntGetSignedBytes = 2000 - BigIntSetBytes = 2000 - BigIntSetUnsignedBytes = 2000 - BigIntSetSignedBytes = 2000 - BigIntIsInt64 = 2000 - BigIntGetInt64 = 2000 - BigIntSetInt64 = 2000 - BigIntAdd = 2000 - BigIntSub = 2000 - BigIntMul = 6000 - BigIntSqrt = 6000 - BigIntPow = 6000 - BigIntLog = 6000 - BigIntTDiv = 6000 - BigIntTMod = 6000 - BigIntEDiv = 6000 - BigIntEMod = 6000 - BigIntAbs = 2000 - BigIntNeg = 2000 - BigIntSign = 2000 - BigIntCmp = 2000 - BigIntNot = 2000 - BigIntAnd = 2000 - BigIntOr = 2000 - BigIntXor = 2000 - BigIntShr = 2000 - BigIntShl = 2000 - BigIntFinishUnsigned = 1000 - BigIntFinishSigned = 1000 - BigIntStorageLoadUnsigned = 50000 - BigIntStorageStoreUnsigned = 75000 - BigIntGetArgument = 1000 - BigIntGetUnsignedArgument = 1000 - BigIntGetSignedArgument = 1000 - BigIntGetCallValue = 1000 - BigIntGetExternalBalance = 10000 - CopyPerByteForTooBig = 1000 - -[CryptoAPICost] - SHA256 = 1000000 - Keccak256 = 1000000 - Ripemd160 = 1000000 - VerifyBLS = 5000000 - VerifyEd25519 = 2000000 - VerifySecp256k1 = 2000000 - EllipticCurveNew = 10000 - AddECC = 75000 - DoubleECC = 65000 - IsOnCurveECC = 10000 - ScalarMultECC = 400000 - MarshalECC = 13000 - MarshalCompressedECC = 15000 - UnmarshalECC = 20000 - UnmarshalCompressedECC = 270000 - GenerateKeyECC = 7000000 - EncodeDERSig = 10000000 - -[ManagedBufferAPICost] - MBufferNew = 2000 - MBufferNewFromBytes = 2000 - MBufferGetLength = 2000 - MBufferGetBytes = 2000 - MBufferGetByteSlice = 2000 - MBufferCopyByteSlice = 2000 - MBufferSetBytes = 2000 - MBufferAppend = 2000 - MBufferAppendBytes = 2000 - MBufferToBigIntUnsigned = 2000 - MBufferToBigIntSigned = 5000 - MBufferFromBigIntUnsigned = 2000 - MBufferFromBigIntSigned = 5000 - MBufferStorageStore = 75000 - MBufferStorageLoad = 50000 - MBufferGetArgument = 1000 - MBufferFinish = 1000 - MBufferSetRandom = 6000 - MBufferToBigFloat = 2000 - MBufferFromBigFloat = 2000 - -[BigFloatAPICost] - BigFloatNewFromParts = 3000 - BigFloatAdd = 7000 - BigFloatSub = 7000 - BigFloatMul = 7000 - BigFloatDiv = 7000 - BigFloatTruncate = 5000 - BigFloatNeg = 5000 - BigFloatClone = 5000 - BigFloatCmp = 4000 - BigFloatAbs = 5000 - BigFloatSqrt = 7000 - BigFloatPow = 10000 - BigFloatFloor = 5000 - BigFloatCeil = 5000 - BigFloatIsInt = 3000 - BigFloatSetBigInt = 3000 - BigFloatSetInt64 = 1000 - BigFloatGetConst = 1000 - -[WASMOpcodeCost] - Unreachable = 5 - Nop = 5 - Block = 5 - Loop = 5 - If = 5 - Else = 5 - End = 5 - Br = 5 - BrIf = 5 - BrTable = 5 - Return = 5 - Call = 5 - CallIndirect = 5 - Drop = 5 - Select = 5 - TypedSelect = 5 - LocalGet = 5 - LocalSet = 5 - LocalTee = 5 - GlobalGet = 5 - GlobalSet = 5 - I32Load = 5 - I64Load = 5 - F32Load = 6 - F64Load = 6 - I32Load8S = 5 - I32Load8U = 5 - I32Load16S = 5 - I32Load16U = 5 - I64Load8S = 5 - I64Load8U = 5 - I64Load16S = 5 - I64Load16U = 5 - I64Load32S = 5 - I64Load32U = 5 - I32Store = 5 - I64Store = 5 - F32Store = 12 - F64Store = 12 - I32Store8 = 5 - I32Store16 = 5 - I64Store8 = 5 - I64Store16 = 5 - I64Store32 = 5 - MemorySize = 5 - MemoryGrow = 5 - I32Const = 5 - I64Const = 5 - F32Const = 5 - F64Const = 5 - RefNull = 5 - RefIsNull = 5 - RefFunc = 5 - I32Eqz = 5 - I32Eq = 5 - I32Ne = 5 - I32LtS = 5 - I32LtU = 5 - I32GtS = 5 - I32GtU = 5 - I32LeS = 5 - I32LeU = 5 - I32GeS = 5 - I32GeU = 5 - I64Eqz = 5 - I64Eq = 5 - I64Ne = 5 - I64LtS = 5 - I64LtU = 5 - I64GtS = 5 - I64GtU = 5 - I64LeS = 5 - I64LeU = 5 - I64GeS = 5 - I64GeU = 5 - F32Eq = 6 - F32Ne = 6 - F32Lt = 6 - F32Gt = 6 - F32Le = 6 - F32Ge = 6 - F64Eq = 6 - F64Ne = 6 - F64Lt = 6 - F64Gt = 6 - F64Le = 6 - F64Ge = 6 - I32Clz = 100 - I32Ctz = 100 - I32Popcnt = 100 - I32Add = 5 - I32Sub = 5 - I32Mul = 5 - I32DivS = 18 - I32DivU = 18 - I32RemS = 18 - I32RemU = 18 - I32And = 5 - I32Or = 5 - I32Xor = 5 - I32Shl = 5 - I32ShrS = 5 - I32ShrU = 5 - I32Rotl = 5 - I32Rotr = 5 - I64Clz = 100 - I64Ctz = 100 - I64Popcnt = 100 - I64Add = 5 - I64Sub = 5 - I64Mul = 5 - I64DivS = 18 - I64DivU = 18 - I64RemS = 18 - I64RemU = 18 - I64And = 5 - I64Or = 5 - I64Xor = 5 - I64Shl = 5 - I64ShrS = 5 - I64ShrU = 5 - I64Rotl = 5 - I64Rotr = 5 - F32Abs = 5 - F32Neg = 5 - F32Ceil = 100 - F32Floor = 100 - F32Trunc = 100 - F32Nearest = 100 - F32Sqrt = 100 - F32Add = 5 - F32Sub = 5 - F32Mul = 15 - F32Div = 100 - F32Min = 15 - F32Max = 15 - F32Copysign = 5 - F64Abs = 5 - F64Neg = 5 - F64Ceil = 100 - F64Floor = 100 - F64Trunc = 100 - F64Nearest = 100 - F64Sqrt = 100 - F64Add = 5 - F64Sub = 5 - F64Mul = 15 - F64Div = 100 - F64Min = 15 - F64Max = 15 - F64Copysign = 5 - I32WrapI64 = 9 - I32TruncF32S = 100 - I32TruncF32U = 100 - I32TruncF64S = 100 - I32TruncF64U = 100 - I64ExtendI32S = 9 - I64ExtendI32U = 9 - I64TruncF32S = 100 - I64TruncF32U = 100 - I64TruncF64S = 100 - I64TruncF64U = 100 - F32ConvertI32S = 100 - F32ConvertI32U = 100 - F32ConvertI64S = 100 - F32ConvertI64U = 100 - F32DemoteF64 = 100 - F64ConvertI32S = 100 - F64ConvertI32U = 100 - F64ConvertI64S = 100 - F64ConvertI64U = 100 - F64PromoteF32 = 100 - I32ReinterpretF32 = 100 - I64ReinterpretF64 = 100 - F32ReinterpretI32 = 100 - F64ReinterpretI64 = 100 - I32Extend8S = 9 - I32Extend16S = 9 - I64Extend8S = 9 - I64Extend16S = 9 - I64Extend32S = 9 - I32TruncSatF32S = 100 - I32TruncSatF32U = 100 - I32TruncSatF64S = 100 - I32TruncSatF64U = 100 - I64TruncSatF32S = 100 - I64TruncSatF32U = 100 - I64TruncSatF64S = 100 - I64TruncSatF64U = 100 - MemoryInit = 5 - DataDrop = 5 - MemoryCopy = 5 - MemoryFill = 5 - TableInit = 10 - ElemDrop = 10 - TableCopy = 10 - TableFill = 10 - TableGet = 10 - TableSet = 10 - TableGrow = 10 - TableSize = 10 - AtomicNotify = 10 - I32AtomicWait = 10 - I64AtomicWait = 10 - AtomicFence = 10 - I32AtomicLoad = 15 - I64AtomicLoad = 15 - I32AtomicLoad8U = 15 - I32AtomicLoad16U = 15 - I64AtomicLoad8U = 15 - I64AtomicLoad16U = 15 - I64AtomicLoad32U = 15 - I32AtomicStore = 15 - I64AtomicStore = 15 - I32AtomicStore8 = 15 - I32AtomicStore16 = 15 - I64AtomicStore8 = 15 - I64AtomicStore16 = 15 - I64AtomicStore32 = 15 - I32AtomicRmwAdd = 20 - I64AtomicRmwAdd = 20 - I32AtomicRmw8AddU = 20 - I32AtomicRmw16AddU = 20 - I64AtomicRmw8AddU = 20 - I64AtomicRmw16AddU = 20 - I64AtomicRmw32AddU = 20 - I32AtomicRmwSub = 20 - I64AtomicRmwSub = 20 - I32AtomicRmw8SubU = 20 - I32AtomicRmw16SubU = 20 - I64AtomicRmw8SubU = 20 - I64AtomicRmw16SubU = 20 - I64AtomicRmw32SubU = 20 - I32AtomicRmwAnd = 15 - I64AtomicRmwAnd = 15 - I32AtomicRmw8AndU = 15 - I32AtomicRmw16AndU = 15 - I64AtomicRmw8AndU = 15 - I64AtomicRmw16AndU = 15 - I64AtomicRmw32AndU = 15 - I32AtomicRmwOr = 15 - I64AtomicRmwOr = 15 - I32AtomicRmw8OrU = 15 - I32AtomicRmw16OrU = 15 - I64AtomicRmw8OrU = 15 - I64AtomicRmw16OrU = 15 - I64AtomicRmw32OrU = 15 - I32AtomicRmwXor = 15 - I64AtomicRmwXor = 15 - I32AtomicRmw8XorU = 15 - I32AtomicRmw16XorU = 15 - I64AtomicRmw8XorU = 15 - I64AtomicRmw16XorU = 15 - I64AtomicRmw32XorU = 15 - I32AtomicRmwXchg = 30 - I64AtomicRmwXchg = 30 - I32AtomicRmw8XchgU = 30 - I32AtomicRmw16XchgU = 30 - I64AtomicRmw8XchgU = 30 - I64AtomicRmw16XchgU = 30 - I64AtomicRmw32XchgU = 30 - I32AtomicRmwCmpxchg = 30 - I64AtomicRmwCmpxchg = 30 - I32AtomicRmw8CmpxchgU = 30 - I32AtomicRmw16CmpxchgU = 30 - I64AtomicRmw8CmpxchgU = 30 - I64AtomicRmw16CmpxchgU = 30 - I64AtomicRmw32CmpxchgU = 30 - V128Load = 18 - V128Store = 18 - V128Const = 18 - I8x16Splat = 20 - I8x16ExtractLaneS = 20 - I8x16ExtractLaneU = 20 - I8x16ReplaceLane = 20 - I16x8Splat = 20 - I16x8ExtractLaneS = 20 - I16x8ExtractLaneU = 20 - I16x8ReplaceLane = 20 - I32x4Splat = 20 - I32x4ExtractLane = 20 - I32x4ReplaceLane = 20 - I64x2Splat = 20 - I64x2ExtractLane = 20 - I64x2ReplaceLane = 20 - F32x4Splat = 120 - F32x4ExtractLane = 120 - F32x4ReplaceLane = 120 - F64x2Splat = 120 - F64x2ExtractLane = 120 - F64x2ReplaceLane = 120 - I8x16Eq = 30 - I8x16Ne = 30 - I8x16LtS = 40 - I8x16LtU = 40 - I8x16GtS = 40 - I8x16GtU = 40 - I8x16LeS = 40 - I8x16LeU = 40 - I8x16GeS = 40 - I8x16GeU = 40 - I16x8Eq = 30 - I16x8Ne = 30 - I16x8LtS = 40 - I16x8LtU = 40 - I16x8GtS = 40 - I16x8GtU = 40 - I16x8LeS = 40 - I16x8LeU = 40 - I16x8GeS = 40 - I16x8GeU = 40 - I32x4Eq = 30 - I32x4Ne = 30 - I32x4LtS = 40 - I32x4LtU = 40 - I32x4GtS = 40 - I32x4GtU = 40 - I32x4LeS = 40 - I32x4LeU = 40 - I32x4GeS = 40 - I32x4GeU = 40 - F32x4Eq = 120 - F32x4Ne = 120 - F32x4Lt = 120 - F32x4Gt = 120 - F32x4Le = 120 - F32x4Ge = 120 - F64x2Eq = 120 - F64x2Ne = 120 - F64x2Lt = 120 - F64x2Gt = 120 - F64x2Le = 120 - F64x2Ge = 120 - V128Not = 40 - V128And = 40 - V128AndNot = 40 - V128Or = 40 - V128Xor = 40 - V128Bitselect = 40 - I8x16Neg = 20 - I8x16AnyTrue = 20 - I8x16AllTrue = 20 - I8x16Shl = 30 - I8x16ShrS = 30 - I8x16ShrU = 30 - I8x16Add = 20 - I8x16AddSaturateS = 20 - I8x16AddSaturateU = 20 - I8x16Sub = 20 - I8x16SubSaturateS = 20 - I8x16SubSaturateU = 20 - I8x16MinS = 40 - I8x16MinU = 40 - I8x16MaxS = 40 - I8x16MaxU = 40 - I8x16Mul = 80 - I16x8Neg = 40 - I16x8AnyTrue = 40 - I16x8AllTrue = 40 - I16x8Shl = 30 - I16x8ShrS = 30 - I16x8ShrU = 30 - I16x8Add = 20 - I16x8AddSaturateS = 20 - I16x8AddSaturateU = 20 - I16x8Sub = 20 - I16x8SubSaturateS = 20 - I16x8SubSaturateU = 20 - I16x8Mul = 40 - I16x8MinS = 40 - I16x8MinU = 40 - I16x8MaxS = 40 - I16x8MaxU = 40 - I32x4Neg = 20 - I32x4AnyTrue = 20 - I32x4AllTrue = 20 - I32x4Shl = 30 - I32x4ShrS = 30 - I32x4ShrU = 30 - I32x4Add = 20 - I32x4Sub = 20 - I32x4Mul = 80 - I32x4MinS = 40 - I32x4MinU = 40 - I32x4MaxS = 40 - I32x4MaxU = 40 - I64x2Neg = 40 - I64x2AnyTrue = 20 - I64x2AllTrue = 20 - I64x2Shl = 30 - I64x2ShrS = 30 - I64x2ShrU = 30 - I64x2Add = 20 - I64x2Sub = 20 - I64x2Mul = 80 - F32x4Abs = 200 - F32x4Neg = 200 - F32x4Sqrt = 1000 - F32x4Add = 200 - F32x4Sub = 200 - F32x4Mul = 800 - F32x4Div = 1000 - F32x4Min = 500 - F32x4Max = 500 - F64x2Abs = 500 - F64x2Neg = 400 - F64x2Sqrt = 1000 - F64x2Add = 200 - F64x2Sub = 200 - F64x2Mul = 800 - F64x2Div = 1000 - F64x2Min = 500 - F64x2Max = 500 - I32x4TruncSatF32x4S = 1000 - I32x4TruncSatF32x4U = 1000 - I64x2TruncSatF64x2S = 1000 - I64x2TruncSatF64x2U = 1000 - F32x4ConvertI32x4S = 1000 - F32x4ConvertI32x4U = 1000 - F64x2ConvertI64x2S = 1000 - F64x2ConvertI64x2U = 1000 - V8x16Swizzle = 1200 - V8x16Shuffle = 1200 - V8x16LoadSplat = 40 - V16x8LoadSplat = 40 - V32x4LoadSplat = 40 - V64x2LoadSplat = 40 - I8x16NarrowI16x8S = 800 - I8x16NarrowI16x8U = 800 - I16x8NarrowI32x4S = 800 - I16x8NarrowI32x4U = 800 - I16x8WidenLowI8x16S = 800 - I16x8WidenHighI8x16S = 800 - I16x8WidenLowI8x16U = 800 - I16x8WidenHighI8x16U = 800 - I32x4WidenLowI16x8S = 800 - I32x4WidenHighI16x8S = 800 - I32x4WidenLowI16x8U = 800 - I32x4WidenHighI16x8U = 800 - I16x8Load8x8S = 400 - I16x8Load8x8U = 400 - I32x4Load16x4S = 400 - I32x4Load16x4U = 400 - I64x2Load32x2S = 400 - I64x2Load32x2U = 400 - I8x16RoundingAverageU = 200 - I16x8RoundingAverageU = 200 - LocalAllocate = 5 - LocalsUnmetered = 100 - MaxMemoryGrowDelta = 100 - MaxMemoryGrow = 100 - Catch = 1 - CatchAll = 1 - Delegate = 1 - F32x4Ceil = 1 - F32x4DemoteF64x2Zero = 1 - F32x4Floor = 1 - F32x4Nearest = 1 - F32x4PMax = 1 - F32x4PMin = 1 - F32x4Trunc = 1 - F64x2Ceil = 1 - F64x2ConvertLowI32x4S = 1 - F64x2ConvertLowI32x4U = 1 - F64x2Floor = 1 - F64x2Nearest = 1 - F64x2PMax = 1 - F64x2PMin = 1 - F64x2PromoteLowF32x4 = 1 - F64x2Trunc = 1 - I16x8Abs = 1 - I16x8AddSatS = 1 - I16x8AddSatU = 1 - I16x8Bitmask = 1 - I16x8ExtAddPairwiseI8x16S = 1 - I16x8ExtAddPairwiseI8x16U = 1 - I16x8ExtMulHighI8x16S = 1 - I16x8ExtMulHighI8x16U = 1 - I16x8ExtMulLowI8x16S = 1 - I16x8ExtMulLowI8x16U = 1 - I16x8ExtendHighI8x16S = 1 - I16x8ExtendHighI8x16U = 1 - I16x8ExtendLowI8x16S = 1 - I16x8ExtendLowI8x16U = 1 - I16x8Q15MulrSatS = 1 - I16x8SubSatS = 1 - I16x8SubSatU = 1 - I32x4Abs = 1 - I32x4Bitmask = 1 - I32x4DotI16x8S = 1 - I32x4ExtAddPairwiseI16x8S = 1 - I32x4ExtAddPairwiseI16x8U = 1 - I32x4ExtMulHighI16x8S = 1 - I32x4ExtMulHighI16x8U = 1 - I32x4ExtMulLowI16x8S = 1 - I32x4ExtMulLowI16x8U = 1 - I32x4ExtendHighI16x8S = 1 - I32x4ExtendHighI16x8U = 1 - I32x4ExtendLowI16x8S = 1 - I32x4ExtendLowI16x8U = 1 - I32x4TruncSatF64x2SZero = 1 - I32x4TruncSatF64x2UZero = 1 - I64x2Abs = 1 - I64x2Bitmask = 1 - I64x2Eq = 1 - I64x2ExtMulHighI32x4S = 1 - I64x2ExtMulHighI32x4U = 1 - I64x2ExtMulLowI32x4S = 1 - I64x2ExtMulLowI32x4U = 1 - I64x2ExtendHighI32x4S = 1 - I64x2ExtendHighI32x4U = 1 - I64x2ExtendLowI32x4S = 1 - I64x2ExtendLowI32x4U = 1 - I64x2GeS = 1 - I64x2GtS = 1 - I64x2LeS = 1 - I64x2LtS = 1 - I64x2Ne = 1 - I8x16Abs = 1 - I8x16AddSatS = 1 - I8x16AddSatU = 1 - I8x16Bitmask = 1 - I8x16Popcnt = 1 - I8x16Shuffle = 1 - I8x16SubSatS = 1 - I8x16SubSatU = 1 - I8x16Swizzle = 1 - MemoryAtomicNotify = 1 - MemoryAtomicWait32 = 1 - MemoryAtomicWait64 = 1 - Rethrow = 1 - ReturnCall = 1 - ReturnCallIndirect = 1 - Throw = 1 - Try = 1 - Unwind = 1 - V128AnyTrue = 1 - V128Load16Lane = 1 - V128Load16Splat = 1 - V128Load16x4S = 1 - V128Load16x4U = 1 - V128Load32Lane = 1 - V128Load32Splat = 1 - V128Load32Zero = 1 - V128Load32x2S = 1 - V128Load32x2U = 1 - V128Load64Lane = 1 - V128Load64Splat = 1 - V128Load64Zero = 1 - V128Load8Lane = 1 - V128Load8Splat = 1 - V128Load8x8S = 1 - V128Load8x8U = 1 - V128Store16Lane = 1 - V128Store32Lane = 1 - V128Store64Lane = 1 - V128Store8Lane = 1 - -[MaxPerTransaction] - MaxBuiltInCallsPerTx = 100 - MaxNumberOfTransfersPerTx = 250 - MaxNumberOfTrieReadsPerTx = 1500 - -# Quadratic, Linear and Constant are the coefficients for a quadratic func. Separate variables are used for the -# sign of each coefficient, 0 meaning positive and 1 meaning negative -# The current values for the coefficients were computed based on benchmarking. -# For the given coefficients, the minimum of the function must not be lower than MinimumGasCost -[DynamicStorageLoad] - QuadraticCoefficient = 688 - SignOfQuadratic = 0 - LinearCoefficient = 31858 - SignOfLinear = 0 - ConstantCoefficient = 15287 - SignOfConstant = 0 - MinimumGasCost = 10000 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV5.toml b/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV5.toml deleted file mode 100644 index 9e2b3ae7..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV5.toml +++ /dev/null @@ -1,827 +0,0 @@ -[BuiltInCost] - ChangeOwnerAddress = 5000000 - ClaimDeveloperRewards = 5000000 - SaveUserName = 1000000 - SaveKeyValue = 100000 - ESDTTransfer = 200000 - ESDTBurn = 100000 - ESDTLocalMint = 50000 - ESDTLocalBurn = 50000 - ESDTNFTCreate = 150000 - ESDTNFTAddQuantity = 50000 - ESDTNFTBurn = 50000 - ESDTNFTTransfer = 200000 - ESDTNFTChangeCreateOwner = 1000000 - ESDTNFTAddUri = 50000 - ESDTNFTUpdateAttributes = 50000 - ESDTNFTMultiTransfer = 200000 - SetGuardian = 250000 - GuardAccount = 250000 - UnGuardAccount = 250000 - TrieLoadPerNode = 100000 - TrieStorePerNode = 50000 - -[MetaChainSystemSCsCost] - Stake = 5000000 - UnStake = 5000000 - UnBond = 5000000 - Claim = 5000000 - Get = 5000000 - ChangeRewardAddress = 5000000 - ChangeValidatorKeys = 5000000 - UnJail = 5000000 - DelegationOps = 1000000 - DelegationMgrOps = 50000000 - ValidatorToDelegation = 500000000 - ESDTIssue = 50000000 - ESDTOperations = 50000000 - Proposal = 50000000 - Vote = 50000000 - DelegateVote = 50000000 - RevokeVote = 50000000 - CloseProposal = 50000000 - GetAllNodeStates = 20000000 - UnstakeTokens = 5000000 - UnbondTokens = 5000000 - GetActiveFund = 50000 - FixWaitingListSize = 500000000 - -[BaseOperationCost] - StorePerByte = 10000 - ReleasePerByte = 1000 - DataCopyPerByte = 100 - PersistPerByte = 1000 - CompilePerByte = 300 - AoTPreparePerByte = 100 - GetCode = 1000000 - -[BaseOpsAPICost] - GetSCAddress = 100 - GetOwnerAddress = 5000 - IsSmartContract = 5000 - GetShardOfAddress = 5000 - GetExternalBalance = 7000 - GetBlockHash = 10000 - TransferValue = 100000 - GetArgument = 100 - GetFunction = 100 - GetNumArguments = 100 - StorageStore = 75000 - StorageLoad = 50000 - CachedStorageLoad = 50000 - GetCaller = 100 - GetCallValue = 100 - Log = 3750 - Finish = 1 - SignalError = 1 - GetBlockTimeStamp = 10000 - GetGasLeft = 100 - Int64GetArgument = 100 - Int64StorageStore = 75000 - Int64StorageLoad = 50000 - Int64Finish = 1000 - GetStateRootHash = 10000 - GetBlockNonce = 10000 - GetBlockEpoch = 10000 - GetBlockRound = 10000 - GetBlockRandomSeed = 10000 - ExecuteOnSameContext = 100000 - ExecuteOnDestContext = 100000 - DelegateExecution = 100000 - AsyncCallStep = 100000 - AsyncCallbackGasLock = 4000000 - ExecuteReadOnly = 160000 - CreateContract = 300000 - GetReturnData = 100 - GetNumReturnData = 100 - GetReturnDataSize = 100 - CleanReturnData = 100 - DeleteFromReturnData = 100 - GetOriginalTxHash = 10000 - GetPrevTxHash = 10000 - GetCurrentTxHash = 10000 - CreateAsyncCall = 200000 - SetAsyncCallback = 100000 - SetAsyncGroupCallback = 100000 - SetAsyncContextCallback = 100000 - GetCallbackClosure = 10000 - GetCodeMetadata = 10000 - IsBuiltinFunction = 10000 - -[EthAPICost] - UseGas = 100 - GetAddress = 100000 - GetExternalBalance = 70000 - GetBlockHash = 100000 - Call = 160000 - CallDataCopy = 200 - GetCallDataSize = 100 - CallCode = 160000 - CallDelegate = 160000 - CallStatic = 160000 - StorageStore = 250000 - StorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - CodeCopy = 1000 - GetCodeSize = 100 - GetBlockCoinbase = 100 - Create = 320000 - GetBlockDifficulty = 100 - ExternalCodeCopy = 3000 - GetExternalCodeSize = 2500 - GetGasLeft = 100 - GetBlockGasLimit = 100000 - GetTxGasPrice = 1000 - Log = 3750 - GetBlockNumber = 100000 - GetTxOrigin = 100000 - Finish = 1 - Revert = 1 - GetReturnDataSize = 200 - ReturnDataCopy = 500 - SelfDestruct = 5000000 - GetBlockTimeStamp = 100000 - -[BigIntAPICost] - BigIntNew = 2000 - BigIntByteLength = 2000 - BigIntUnsignedByteLength = 2000 - BigIntSignedByteLength = 2000 - BigIntGetBytes = 2000 - BigIntGetUnsignedBytes = 2000 - BigIntGetSignedBytes = 2000 - BigIntSetBytes = 2000 - BigIntSetUnsignedBytes = 2000 - BigIntSetSignedBytes = 2000 - BigIntIsInt64 = 2000 - BigIntGetInt64 = 2000 - BigIntSetInt64 = 2000 - BigIntAdd = 2000 - BigIntSub = 2000 - BigIntMul = 6000 - BigIntSqrt = 6000 - BigIntPow = 6000 - BigIntLog = 6000 - BigIntTDiv = 6000 - BigIntTMod = 6000 - BigIntEDiv = 6000 - BigIntEMod = 6000 - BigIntAbs = 2000 - BigIntNeg = 2000 - BigIntSign = 2000 - BigIntCmp = 2000 - BigIntNot = 2000 - BigIntAnd = 2000 - BigIntOr = 2000 - BigIntXor = 2000 - BigIntShr = 2000 - BigIntShl = 2000 - BigIntFinishUnsigned = 1000 - BigIntFinishSigned = 1000 - BigIntStorageLoadUnsigned = 50000 - BigIntStorageStoreUnsigned = 75000 - BigIntGetArgument = 1000 - BigIntGetUnsignedArgument = 1000 - BigIntGetSignedArgument = 1000 - BigIntGetCallValue = 1000 - BigIntGetExternalBalance = 10000 - CopyPerByteForTooBig = 1000 - -[CryptoAPICost] - SHA256 = 1000000 - Keccak256 = 1000000 - Ripemd160 = 1000000 - VerifyBLS = 5000000 - VerifyEd25519 = 2000000 - VerifySecp256k1 = 2000000 - EllipticCurveNew = 10000 - AddECC = 75000 - DoubleECC = 65000 - IsOnCurveECC = 10000 - ScalarMultECC = 400000 - MarshalECC = 13000 - MarshalCompressedECC = 15000 - UnmarshalECC = 20000 - UnmarshalCompressedECC = 270000 - GenerateKeyECC = 7000000 - EncodeDERSig = 10000000 - -[ManagedBufferAPICost] - MBufferNew = 2000 - MBufferNewFromBytes = 2000 - MBufferGetLength = 2000 - MBufferGetBytes = 2000 - MBufferGetByteSlice = 2000 - MBufferCopyByteSlice = 2000 - MBufferSetBytes = 2000 - MBufferAppend = 2000 - MBufferAppendBytes = 2000 - MBufferToBigIntUnsigned = 2000 - MBufferToBigIntSigned = 5000 - MBufferFromBigIntUnsigned = 2000 - MBufferFromBigIntSigned = 5000 - MBufferStorageStore = 75000 - MBufferStorageLoad = 50000 - MBufferGetArgument = 1000 - MBufferFinish = 1000 - MBufferSetRandom = 6000 - MBufferToBigFloat = 2000 - MBufferFromBigFloat = 2000 - -[BigFloatAPICost] - BigFloatNewFromParts = 3000 - BigFloatAdd = 7000 - BigFloatSub = 7000 - BigFloatMul = 7000 - BigFloatDiv = 7000 - BigFloatTruncate = 5000 - BigFloatNeg = 5000 - BigFloatClone = 5000 - BigFloatCmp = 4000 - BigFloatAbs = 5000 - BigFloatSqrt = 7000 - BigFloatPow = 10000 - BigFloatFloor = 5000 - BigFloatCeil = 5000 - BigFloatIsInt = 3000 - BigFloatSetBigInt = 3000 - BigFloatSetInt64 = 1000 - BigFloatGetConst = 1000 - -[WASMOpcodeCost] - Unreachable = 5 - Nop = 5 - Block = 5 - Loop = 5 - If = 5 - Else = 5 - End = 5 - Br = 5 - BrIf = 5 - BrTable = 5 - Return = 5 - Call = 5 - CallIndirect = 5 - Drop = 5 - Select = 5 - TypedSelect = 5 - LocalGet = 5 - LocalSet = 5 - LocalTee = 5 - GlobalGet = 5 - GlobalSet = 5 - I32Load = 5 - I64Load = 5 - F32Load = 6 - F64Load = 6 - I32Load8S = 5 - I32Load8U = 5 - I32Load16S = 5 - I32Load16U = 5 - I64Load8S = 5 - I64Load8U = 5 - I64Load16S = 5 - I64Load16U = 5 - I64Load32S = 5 - I64Load32U = 5 - I32Store = 5 - I64Store = 5 - F32Store = 12 - F64Store = 12 - I32Store8 = 5 - I32Store16 = 5 - I64Store8 = 5 - I64Store16 = 5 - I64Store32 = 5 - MemorySize = 5 - MemoryGrow = 250000000 - I32Const = 5 - I64Const = 5 - F32Const = 5 - F64Const = 5 - RefNull = 5 - RefIsNull = 5 - RefFunc = 5 - I32Eqz = 5 - I32Eq = 5 - I32Ne = 5 - I32LtS = 5 - I32LtU = 5 - I32GtS = 5 - I32GtU = 5 - I32LeS = 5 - I32LeU = 5 - I32GeS = 5 - I32GeU = 5 - I64Eqz = 5 - I64Eq = 5 - I64Ne = 5 - I64LtS = 5 - I64LtU = 5 - I64GtS = 5 - I64GtU = 5 - I64LeS = 5 - I64LeU = 5 - I64GeS = 5 - I64GeU = 5 - F32Eq = 6 - F32Ne = 6 - F32Lt = 6 - F32Gt = 6 - F32Le = 6 - F32Ge = 6 - F64Eq = 6 - F64Ne = 6 - F64Lt = 6 - F64Gt = 6 - F64Le = 6 - F64Ge = 6 - I32Clz = 100 - I32Ctz = 100 - I32Popcnt = 100 - I32Add = 5 - I32Sub = 5 - I32Mul = 5 - I32DivS = 18 - I32DivU = 18 - I32RemS = 18 - I32RemU = 18 - I32And = 5 - I32Or = 5 - I32Xor = 5 - I32Shl = 5 - I32ShrS = 5 - I32ShrU = 5 - I32Rotl = 5 - I32Rotr = 5 - I64Clz = 100 - I64Ctz = 100 - I64Popcnt = 100 - I64Add = 5 - I64Sub = 5 - I64Mul = 5 - I64DivS = 18 - I64DivU = 18 - I64RemS = 18 - I64RemU = 18 - I64And = 5 - I64Or = 5 - I64Xor = 5 - I64Shl = 5 - I64ShrS = 5 - I64ShrU = 5 - I64Rotl = 5 - I64Rotr = 5 - F32Abs = 5 - F32Neg = 5 - F32Ceil = 100 - F32Floor = 100 - F32Trunc = 100 - F32Nearest = 100 - F32Sqrt = 100 - F32Add = 5 - F32Sub = 5 - F32Mul = 15 - F32Div = 100 - F32Min = 15 - F32Max = 15 - F32Copysign = 5 - F64Abs = 5 - F64Neg = 5 - F64Ceil = 100 - F64Floor = 100 - F64Trunc = 100 - F64Nearest = 100 - F64Sqrt = 100 - F64Add = 5 - F64Sub = 5 - F64Mul = 15 - F64Div = 100 - F64Min = 15 - F64Max = 15 - F64Copysign = 5 - I32WrapI64 = 9 - I32TruncF32S = 100 - I32TruncF32U = 100 - I32TruncF64S = 100 - I32TruncF64U = 100 - I64ExtendI32S = 9 - I64ExtendI32U = 9 - I64TruncF32S = 100 - I64TruncF32U = 100 - I64TruncF64S = 100 - I64TruncF64U = 100 - F32ConvertI32S = 100 - F32ConvertI32U = 100 - F32ConvertI64S = 100 - F32ConvertI64U = 100 - F32DemoteF64 = 100 - F64ConvertI32S = 100 - F64ConvertI32U = 100 - F64ConvertI64S = 100 - F64ConvertI64U = 100 - F64PromoteF32 = 100 - I32ReinterpretF32 = 100 - I64ReinterpretF64 = 100 - F32ReinterpretI32 = 100 - F64ReinterpretI64 = 100 - I32Extend8S = 9 - I32Extend16S = 9 - I64Extend8S = 9 - I64Extend16S = 9 - I64Extend32S = 9 - I32TruncSatF32S = 100 - I32TruncSatF32U = 100 - I32TruncSatF64S = 100 - I32TruncSatF64U = 100 - I64TruncSatF32S = 100 - I64TruncSatF32U = 100 - I64TruncSatF64S = 100 - I64TruncSatF64U = 100 - MemoryInit = 5 - DataDrop = 5 - MemoryCopy = 5 - MemoryFill = 5 - TableInit = 10 - ElemDrop = 10 - TableCopy = 10 - TableFill = 10 - TableGet = 10 - TableSet = 10 - TableGrow = 10 - TableSize = 10 - AtomicNotify = 10 - I32AtomicWait = 10 - I64AtomicWait = 10 - AtomicFence = 10 - I32AtomicLoad = 15 - I64AtomicLoad = 15 - I32AtomicLoad8U = 15 - I32AtomicLoad16U = 15 - I64AtomicLoad8U = 15 - I64AtomicLoad16U = 15 - I64AtomicLoad32U = 15 - I32AtomicStore = 15 - I64AtomicStore = 15 - I32AtomicStore8 = 15 - I32AtomicStore16 = 15 - I64AtomicStore8 = 15 - I64AtomicStore16 = 15 - I64AtomicStore32 = 15 - I32AtomicRmwAdd = 20 - I64AtomicRmwAdd = 20 - I32AtomicRmw8AddU = 20 - I32AtomicRmw16AddU = 20 - I64AtomicRmw8AddU = 20 - I64AtomicRmw16AddU = 20 - I64AtomicRmw32AddU = 20 - I32AtomicRmwSub = 20 - I64AtomicRmwSub = 20 - I32AtomicRmw8SubU = 20 - I32AtomicRmw16SubU = 20 - I64AtomicRmw8SubU = 20 - I64AtomicRmw16SubU = 20 - I64AtomicRmw32SubU = 20 - I32AtomicRmwAnd = 15 - I64AtomicRmwAnd = 15 - I32AtomicRmw8AndU = 15 - I32AtomicRmw16AndU = 15 - I64AtomicRmw8AndU = 15 - I64AtomicRmw16AndU = 15 - I64AtomicRmw32AndU = 15 - I32AtomicRmwOr = 15 - I64AtomicRmwOr = 15 - I32AtomicRmw8OrU = 15 - I32AtomicRmw16OrU = 15 - I64AtomicRmw8OrU = 15 - I64AtomicRmw16OrU = 15 - I64AtomicRmw32OrU = 15 - I32AtomicRmwXor = 15 - I64AtomicRmwXor = 15 - I32AtomicRmw8XorU = 15 - I32AtomicRmw16XorU = 15 - I64AtomicRmw8XorU = 15 - I64AtomicRmw16XorU = 15 - I64AtomicRmw32XorU = 15 - I32AtomicRmwXchg = 30 - I64AtomicRmwXchg = 30 - I32AtomicRmw8XchgU = 30 - I32AtomicRmw16XchgU = 30 - I64AtomicRmw8XchgU = 30 - I64AtomicRmw16XchgU = 30 - I64AtomicRmw32XchgU = 30 - I32AtomicRmwCmpxchg = 30 - I64AtomicRmwCmpxchg = 30 - I32AtomicRmw8CmpxchgU = 30 - I32AtomicRmw16CmpxchgU = 30 - I64AtomicRmw8CmpxchgU = 30 - I64AtomicRmw16CmpxchgU = 30 - I64AtomicRmw32CmpxchgU = 30 - V128Load = 18 - V128Store = 18 - V128Const = 18 - I8x16Splat = 20 - I8x16ExtractLaneS = 20 - I8x16ExtractLaneU = 20 - I8x16ReplaceLane = 20 - I16x8Splat = 20 - I16x8ExtractLaneS = 20 - I16x8ExtractLaneU = 20 - I16x8ReplaceLane = 20 - I32x4Splat = 20 - I32x4ExtractLane = 20 - I32x4ReplaceLane = 20 - I64x2Splat = 20 - I64x2ExtractLane = 20 - I64x2ReplaceLane = 20 - F32x4Splat = 120 - F32x4ExtractLane = 120 - F32x4ReplaceLane = 120 - F64x2Splat = 120 - F64x2ExtractLane = 120 - F64x2ReplaceLane = 120 - I8x16Eq = 30 - I8x16Ne = 30 - I8x16LtS = 40 - I8x16LtU = 40 - I8x16GtS = 40 - I8x16GtU = 40 - I8x16LeS = 40 - I8x16LeU = 40 - I8x16GeS = 40 - I8x16GeU = 40 - I16x8Eq = 30 - I16x8Ne = 30 - I16x8LtS = 40 - I16x8LtU = 40 - I16x8GtS = 40 - I16x8GtU = 40 - I16x8LeS = 40 - I16x8LeU = 40 - I16x8GeS = 40 - I16x8GeU = 40 - I32x4Eq = 30 - I32x4Ne = 30 - I32x4LtS = 40 - I32x4LtU = 40 - I32x4GtS = 40 - I32x4GtU = 40 - I32x4LeS = 40 - I32x4LeU = 40 - I32x4GeS = 40 - I32x4GeU = 40 - F32x4Eq = 120 - F32x4Ne = 120 - F32x4Lt = 120 - F32x4Gt = 120 - F32x4Le = 120 - F32x4Ge = 120 - F64x2Eq = 120 - F64x2Ne = 120 - F64x2Lt = 120 - F64x2Gt = 120 - F64x2Le = 120 - F64x2Ge = 120 - V128Not = 40 - V128And = 40 - V128AndNot = 40 - V128Or = 40 - V128Xor = 40 - V128Bitselect = 40 - I8x16Neg = 20 - I8x16AnyTrue = 20 - I8x16AllTrue = 20 - I8x16Shl = 30 - I8x16ShrS = 30 - I8x16ShrU = 30 - I8x16Add = 20 - I8x16AddSaturateS = 20 - I8x16AddSaturateU = 20 - I8x16Sub = 20 - I8x16SubSaturateS = 20 - I8x16SubSaturateU = 20 - I8x16MinS = 40 - I8x16MinU = 40 - I8x16MaxS = 40 - I8x16MaxU = 40 - I8x16Mul = 80 - I16x8Neg = 40 - I16x8AnyTrue = 40 - I16x8AllTrue = 40 - I16x8Shl = 30 - I16x8ShrS = 30 - I16x8ShrU = 30 - I16x8Add = 20 - I16x8AddSaturateS = 20 - I16x8AddSaturateU = 20 - I16x8Sub = 20 - I16x8SubSaturateS = 20 - I16x8SubSaturateU = 20 - I16x8Mul = 40 - I16x8MinS = 40 - I16x8MinU = 40 - I16x8MaxS = 40 - I16x8MaxU = 40 - I32x4Neg = 20 - I32x4AnyTrue = 20 - I32x4AllTrue = 20 - I32x4Shl = 30 - I32x4ShrS = 30 - I32x4ShrU = 30 - I32x4Add = 20 - I32x4Sub = 20 - I32x4Mul = 80 - I32x4MinS = 40 - I32x4MinU = 40 - I32x4MaxS = 40 - I32x4MaxU = 40 - I64x2Neg = 40 - I64x2AnyTrue = 20 - I64x2AllTrue = 20 - I64x2Shl = 30 - I64x2ShrS = 30 - I64x2ShrU = 30 - I64x2Add = 20 - I64x2Sub = 20 - I64x2Mul = 80 - F32x4Abs = 200 - F32x4Neg = 200 - F32x4Sqrt = 1000 - F32x4Add = 200 - F32x4Sub = 200 - F32x4Mul = 800 - F32x4Div = 1000 - F32x4Min = 500 - F32x4Max = 500 - F64x2Abs = 500 - F64x2Neg = 400 - F64x2Sqrt = 1000 - F64x2Add = 200 - F64x2Sub = 200 - F64x2Mul = 800 - F64x2Div = 1000 - F64x2Min = 500 - F64x2Max = 500 - I32x4TruncSatF32x4S = 1000 - I32x4TruncSatF32x4U = 1000 - I64x2TruncSatF64x2S = 1000 - I64x2TruncSatF64x2U = 1000 - F32x4ConvertI32x4S = 1000 - F32x4ConvertI32x4U = 1000 - F64x2ConvertI64x2S = 1000 - F64x2ConvertI64x2U = 1000 - V8x16Swizzle = 1200 - V8x16Shuffle = 1200 - V8x16LoadSplat = 40 - V16x8LoadSplat = 40 - V32x4LoadSplat = 40 - V64x2LoadSplat = 40 - I8x16NarrowI16x8S = 800 - I8x16NarrowI16x8U = 800 - I16x8NarrowI32x4S = 800 - I16x8NarrowI32x4U = 800 - I16x8WidenLowI8x16S = 800 - I16x8WidenHighI8x16S = 800 - I16x8WidenLowI8x16U = 800 - I16x8WidenHighI8x16U = 800 - I32x4WidenLowI16x8S = 800 - I32x4WidenHighI16x8S = 800 - I32x4WidenLowI16x8U = 800 - I32x4WidenHighI16x8U = 800 - I16x8Load8x8S = 400 - I16x8Load8x8U = 400 - I32x4Load16x4S = 400 - I32x4Load16x4U = 400 - I64x2Load32x2S = 400 - I64x2Load32x2U = 400 - I8x16RoundingAverageU = 200 - I16x8RoundingAverageU = 200 - LocalAllocate = 5 - LocalsUnmetered = 100 - MaxMemoryGrowDelta = 100 - MaxMemoryGrow = 100 - Catch = 1 - CatchAll = 1 - Delegate = 1 - F32x4Ceil = 1 - F32x4DemoteF64x2Zero = 1 - F32x4Floor = 1 - F32x4Nearest = 1 - F32x4PMax = 1 - F32x4PMin = 1 - F32x4Trunc = 1 - F64x2Ceil = 1 - F64x2ConvertLowI32x4S = 1 - F64x2ConvertLowI32x4U = 1 - F64x2Floor = 1 - F64x2Nearest = 1 - F64x2PMax = 1 - F64x2PMin = 1 - F64x2PromoteLowF32x4 = 1 - F64x2Trunc = 1 - I16x8Abs = 1 - I16x8AddSatS = 1 - I16x8AddSatU = 1 - I16x8Bitmask = 1 - I16x8ExtAddPairwiseI8x16S = 1 - I16x8ExtAddPairwiseI8x16U = 1 - I16x8ExtMulHighI8x16S = 1 - I16x8ExtMulHighI8x16U = 1 - I16x8ExtMulLowI8x16S = 1 - I16x8ExtMulLowI8x16U = 1 - I16x8ExtendHighI8x16S = 1 - I16x8ExtendHighI8x16U = 1 - I16x8ExtendLowI8x16S = 1 - I16x8ExtendLowI8x16U = 1 - I16x8Q15MulrSatS = 1 - I16x8SubSatS = 1 - I16x8SubSatU = 1 - I32x4Abs = 1 - I32x4Bitmask = 1 - I32x4DotI16x8S = 1 - I32x4ExtAddPairwiseI16x8S = 1 - I32x4ExtAddPairwiseI16x8U = 1 - I32x4ExtMulHighI16x8S = 1 - I32x4ExtMulHighI16x8U = 1 - I32x4ExtMulLowI16x8S = 1 - I32x4ExtMulLowI16x8U = 1 - I32x4ExtendHighI16x8S = 1 - I32x4ExtendHighI16x8U = 1 - I32x4ExtendLowI16x8S = 1 - I32x4ExtendLowI16x8U = 1 - I32x4TruncSatF64x2SZero = 1 - I32x4TruncSatF64x2UZero = 1 - I64x2Abs = 1 - I64x2Bitmask = 1 - I64x2Eq = 1 - I64x2ExtMulHighI32x4S = 1 - I64x2ExtMulHighI32x4U = 1 - I64x2ExtMulLowI32x4S = 1 - I64x2ExtMulLowI32x4U = 1 - I64x2ExtendHighI32x4S = 1 - I64x2ExtendHighI32x4U = 1 - I64x2ExtendLowI32x4S = 1 - I64x2ExtendLowI32x4U = 1 - I64x2GeS = 1 - I64x2GtS = 1 - I64x2LeS = 1 - I64x2LtS = 1 - I64x2Ne = 1 - I8x16Abs = 1 - I8x16AddSatS = 1 - I8x16AddSatU = 1 - I8x16Bitmask = 1 - I8x16Popcnt = 1 - I8x16Shuffle = 1 - I8x16SubSatS = 1 - I8x16SubSatU = 1 - I8x16Swizzle = 1 - MemoryAtomicNotify = 1 - MemoryAtomicWait32 = 1 - MemoryAtomicWait64 = 1 - Rethrow = 1 - ReturnCall = 1 - ReturnCallIndirect = 1 - Throw = 1 - Try = 1 - Unwind = 1 - V128AnyTrue = 1 - V128Load16Lane = 1 - V128Load16Splat = 1 - V128Load16x4S = 1 - V128Load16x4U = 1 - V128Load32Lane = 1 - V128Load32Splat = 1 - V128Load32Zero = 1 - V128Load32x2S = 1 - V128Load32x2U = 1 - V128Load64Lane = 1 - V128Load64Splat = 1 - V128Load64Zero = 1 - V128Load8Lane = 1 - V128Load8Splat = 1 - V128Load8x8S = 1 - V128Load8x8U = 1 - V128Store16Lane = 1 - V128Store32Lane = 1 - V128Store64Lane = 1 - V128Store8Lane = 1 - -[MaxPerTransaction] - MaxBuiltInCallsPerTx = 100 - MaxNumberOfTransfersPerTx = 250 - MaxNumberOfTrieReadsPerTx = 1500 - -# Quadratic, Linear and Constant are the coefficients for a quadratic func. Separate variables are used for the -# sign of each coefficient, 0 meaning positive and 1 meaning negative -# The current values for the coefficients were computed based on benchmarking. -# For the given coefficients, the minimum of the function must not be lower than MinimumGasCost -[DynamicStorageLoad] - QuadraticCoefficient = 688 - SignOfQuadratic = 0 - LinearCoefficient = 31858 - SignOfLinear = 0 - ConstantCoefficient = 15287 - SignOfConstant = 0 - MinimumGasCost = 10000 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV6.toml b/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV6.toml deleted file mode 100644 index 82c658a1..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV6.toml +++ /dev/null @@ -1,827 +0,0 @@ -[BuiltInCost] - ChangeOwnerAddress = 5000000 - ClaimDeveloperRewards = 5000000 - SaveUserName = 1000000 - SaveKeyValue = 100000 - ESDTTransfer = 200000 - ESDTBurn = 100000 - ESDTLocalMint = 50000 - ESDTLocalBurn = 50000 - ESDTNFTCreate = 150000 - ESDTNFTAddQuantity = 50000 - ESDTNFTBurn = 50000 - ESDTNFTTransfer = 200000 - ESDTNFTChangeCreateOwner = 1000000 - ESDTNFTAddUri = 50000 - ESDTNFTUpdateAttributes = 50000 - ESDTNFTMultiTransfer = 200000 - SetGuardian = 250000 - GuardAccount = 250000 - UnGuardAccount = 250000 - TrieLoadPerNode = 100000 - TrieStorePerNode = 50000 - -[MetaChainSystemSCsCost] - Stake = 5000000 - UnStake = 5000000 - UnBond = 5000000 - Claim = 5000000 - Get = 5000000 - ChangeRewardAddress = 5000000 - ChangeValidatorKeys = 5000000 - UnJail = 5000000 - DelegationOps = 1000000 - DelegationMgrOps = 50000000 - ValidatorToDelegation = 500000000 - ESDTIssue = 50000000 - ESDTOperations = 50000000 - Proposal = 50000000 - Vote = 50000000 - DelegateVote = 50000000 - RevokeVote = 50000000 - CloseProposal = 50000000 - GetAllNodeStates = 20000000 - UnstakeTokens = 5000000 - UnbondTokens = 5000000 - GetActiveFund = 50000 - FixWaitingListSize = 500000000 - -[BaseOperationCost] - StorePerByte = 10000 - ReleasePerByte = 1000 - DataCopyPerByte = 50 - PersistPerByte = 1000 - CompilePerByte = 300 - AoTPreparePerByte = 100 - GetCode = 1000000 - -[BaseOpsAPICost] - GetSCAddress = 100 - GetOwnerAddress = 5000 - IsSmartContract = 5000 - GetShardOfAddress = 5000 - GetExternalBalance = 7000 - GetBlockHash = 10000 - TransferValue = 100000 - GetArgument = 100 - GetFunction = 100 - GetNumArguments = 100 - StorageStore = 75000 - StorageLoad = 50000 - CachedStorageLoad = 1000 - GetCaller = 100 - GetCallValue = 100 - Log = 3750 - Finish = 1 - SignalError = 1 - GetBlockTimeStamp = 10000 - GetGasLeft = 100 - Int64GetArgument = 100 - Int64StorageStore = 75000 - Int64StorageLoad = 50000 - Int64Finish = 1000 - GetStateRootHash = 10000 - GetBlockNonce = 10000 - GetBlockEpoch = 10000 - GetBlockRound = 10000 - GetBlockRandomSeed = 10000 - ExecuteOnSameContext = 100000 - ExecuteOnDestContext = 100000 - DelegateExecution = 100000 - AsyncCallStep = 100000 - AsyncCallbackGasLock = 4000000 - ExecuteReadOnly = 160000 - CreateContract = 300000 - GetReturnData = 100 - GetNumReturnData = 100 - GetReturnDataSize = 100 - GetOriginalTxHash = 10000 - CleanReturnData = 100 - DeleteFromReturnData = 100 - GetPrevTxHash = 10000 - GetCurrentTxHash = 10000 - CreateAsyncCall = 200000 - SetAsyncCallback = 100000 - SetAsyncGroupCallback = 100000 - SetAsyncContextCallback = 100000 - GetCallbackClosure = 10000 - GetCodeMetadata = 10000 - IsBuiltinFunction = 10000 - -[EthAPICost] - UseGas = 100 - GetAddress = 100000 - GetExternalBalance = 70000 - GetBlockHash = 100000 - Call = 160000 - CallDataCopy = 200 - GetCallDataSize = 100 - CallCode = 160000 - CallDelegate = 160000 - CallStatic = 160000 - StorageStore = 250000 - StorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - CodeCopy = 1000 - GetCodeSize = 100 - GetBlockCoinbase = 100 - Create = 320000 - GetBlockDifficulty = 100 - ExternalCodeCopy = 3000 - GetExternalCodeSize = 2500 - GetGasLeft = 100 - GetBlockGasLimit = 100000 - GetTxGasPrice = 1000 - Log = 3750 - GetBlockNumber = 100000 - GetTxOrigin = 100000 - Finish = 1 - Revert = 1 - GetReturnDataSize = 200 - ReturnDataCopy = 500 - SelfDestruct = 5000000 - GetBlockTimeStamp = 100000 - -[BigIntAPICost] - BigIntNew = 2000 - BigIntByteLength = 2000 - BigIntUnsignedByteLength = 2000 - BigIntSignedByteLength = 2000 - BigIntGetBytes = 2000 - BigIntGetUnsignedBytes = 2000 - BigIntGetSignedBytes = 2000 - BigIntSetBytes = 2000 - BigIntSetUnsignedBytes = 2000 - BigIntSetSignedBytes = 2000 - BigIntIsInt64 = 2000 - BigIntGetInt64 = 2000 - BigIntSetInt64 = 2000 - BigIntAdd = 2000 - BigIntSub = 2000 - BigIntMul = 6000 - BigIntSqrt = 6000 - BigIntPow = 6000 - BigIntLog = 6000 - BigIntTDiv = 6000 - BigIntTMod = 6000 - BigIntEDiv = 6000 - BigIntEMod = 6000 - BigIntAbs = 2000 - BigIntNeg = 2000 - BigIntSign = 2000 - BigIntCmp = 2000 - BigIntNot = 2000 - BigIntAnd = 2000 - BigIntOr = 2000 - BigIntXor = 2000 - BigIntShr = 2000 - BigIntShl = 2000 - BigIntFinishUnsigned = 1000 - BigIntFinishSigned = 1000 - BigIntStorageLoadUnsigned = 50000 - BigIntStorageStoreUnsigned = 75000 - BigIntGetArgument = 1000 - BigIntGetUnsignedArgument = 1000 - BigIntGetSignedArgument = 1000 - BigIntGetCallValue = 1000 - BigIntGetExternalBalance = 10000 - CopyPerByteForTooBig = 1000 - -[CryptoAPICost] - SHA256 = 1000000 - Keccak256 = 1000000 - Ripemd160 = 1000000 - VerifyBLS = 5000000 - VerifyEd25519 = 2000000 - VerifySecp256k1 = 2000000 - EllipticCurveNew = 10000 - AddECC = 75000 - DoubleECC = 65000 - IsOnCurveECC = 10000 - ScalarMultECC = 400000 - MarshalECC = 13000 - MarshalCompressedECC = 15000 - UnmarshalECC = 20000 - UnmarshalCompressedECC = 270000 - GenerateKeyECC = 7000000 - EncodeDERSig = 10000000 - -[ManagedBufferAPICost] - MBufferNew = 2000 - MBufferNewFromBytes = 2000 - MBufferGetLength = 2000 - MBufferGetBytes = 2000 - MBufferGetByteSlice = 2000 - MBufferCopyByteSlice = 2000 - MBufferSetBytes = 2000 - MBufferAppend = 2000 - MBufferAppendBytes = 2000 - MBufferToBigIntUnsigned = 2000 - MBufferToBigIntSigned = 5000 - MBufferFromBigIntUnsigned = 2000 - MBufferFromBigIntSigned = 5000 - MBufferStorageStore = 75000 - MBufferStorageLoad = 50000 - MBufferGetArgument = 1000 - MBufferFinish = 1000 - MBufferSetRandom = 6000 - MBufferToBigFloat = 2000 - MBufferFromBigFloat = 2000 - -[BigFloatAPICost] - BigFloatNewFromParts = 3000 - BigFloatAdd = 7000 - BigFloatSub = 7000 - BigFloatMul = 7000 - BigFloatDiv = 7000 - BigFloatTruncate = 5000 - BigFloatNeg = 5000 - BigFloatClone = 5000 - BigFloatCmp = 4000 - BigFloatAbs = 5000 - BigFloatSqrt = 7000 - BigFloatPow = 10000 - BigFloatFloor = 5000 - BigFloatCeil = 5000 - BigFloatIsInt = 3000 - BigFloatSetBigInt = 3000 - BigFloatSetInt64 = 1000 - BigFloatGetConst = 1000 - -[WASMOpcodeCost] - Unreachable = 5 - Nop = 5 - Block = 5 - Loop = 5 - If = 5 - Else = 5 - End = 5 - Br = 5 - BrIf = 5 - BrTable = 5 - Return = 5 - Call = 5 - CallIndirect = 5 - Drop = 5 - Select = 5 - TypedSelect = 5 - LocalGet = 5 - LocalSet = 5 - LocalTee = 5 - GlobalGet = 5 - GlobalSet = 5 - I32Load = 5 - I64Load = 5 - F32Load = 6 - F64Load = 6 - I32Load8S = 5 - I32Load8U = 5 - I32Load16S = 5 - I32Load16U = 5 - I64Load8S = 5 - I64Load8U = 5 - I64Load16S = 5 - I64Load16U = 5 - I64Load32S = 5 - I64Load32U = 5 - I32Store = 5 - I64Store = 5 - F32Store = 12 - F64Store = 12 - I32Store8 = 5 - I32Store16 = 5 - I64Store8 = 5 - I64Store16 = 5 - I64Store32 = 5 - MemorySize = 5 - MemoryGrow = 1000000 - I32Const = 5 - I64Const = 5 - F32Const = 5 - F64Const = 5 - RefNull = 5 - RefIsNull = 5 - RefFunc = 5 - I32Eqz = 5 - I32Eq = 5 - I32Ne = 5 - I32LtS = 5 - I32LtU = 5 - I32GtS = 5 - I32GtU = 5 - I32LeS = 5 - I32LeU = 5 - I32GeS = 5 - I32GeU = 5 - I64Eqz = 5 - I64Eq = 5 - I64Ne = 5 - I64LtS = 5 - I64LtU = 5 - I64GtS = 5 - I64GtU = 5 - I64LeS = 5 - I64LeU = 5 - I64GeS = 5 - I64GeU = 5 - F32Eq = 6 - F32Ne = 6 - F32Lt = 6 - F32Gt = 6 - F32Le = 6 - F32Ge = 6 - F64Eq = 6 - F64Ne = 6 - F64Lt = 6 - F64Gt = 6 - F64Le = 6 - F64Ge = 6 - I32Clz = 100 - I32Ctz = 100 - I32Popcnt = 100 - I32Add = 5 - I32Sub = 5 - I32Mul = 5 - I32DivS = 18 - I32DivU = 18 - I32RemS = 18 - I32RemU = 18 - I32And = 5 - I32Or = 5 - I32Xor = 5 - I32Shl = 5 - I32ShrS = 5 - I32ShrU = 5 - I32Rotl = 5 - I32Rotr = 5 - I64Clz = 100 - I64Ctz = 100 - I64Popcnt = 100 - I64Add = 5 - I64Sub = 5 - I64Mul = 5 - I64DivS = 18 - I64DivU = 18 - I64RemS = 18 - I64RemU = 18 - I64And = 5 - I64Or = 5 - I64Xor = 5 - I64Shl = 5 - I64ShrS = 5 - I64ShrU = 5 - I64Rotl = 5 - I64Rotr = 5 - F32Abs = 5 - F32Neg = 5 - F32Ceil = 100 - F32Floor = 100 - F32Trunc = 100 - F32Nearest = 100 - F32Sqrt = 100 - F32Add = 5 - F32Sub = 5 - F32Mul = 15 - F32Div = 100 - F32Min = 15 - F32Max = 15 - F32Copysign = 5 - F64Abs = 5 - F64Neg = 5 - F64Ceil = 100 - F64Floor = 100 - F64Trunc = 100 - F64Nearest = 100 - F64Sqrt = 100 - F64Add = 5 - F64Sub = 5 - F64Mul = 15 - F64Div = 100 - F64Min = 15 - F64Max = 15 - F64Copysign = 5 - I32WrapI64 = 9 - I32TruncF32S = 100 - I32TruncF32U = 100 - I32TruncF64S = 100 - I32TruncF64U = 100 - I64ExtendI32S = 9 - I64ExtendI32U = 9 - I64TruncF32S = 100 - I64TruncF32U = 100 - I64TruncF64S = 100 - I64TruncF64U = 100 - F32ConvertI32S = 100 - F32ConvertI32U = 100 - F32ConvertI64S = 100 - F32ConvertI64U = 100 - F32DemoteF64 = 100 - F64ConvertI32S = 100 - F64ConvertI32U = 100 - F64ConvertI64S = 100 - F64ConvertI64U = 100 - F64PromoteF32 = 100 - I32ReinterpretF32 = 100 - I64ReinterpretF64 = 100 - F32ReinterpretI32 = 100 - F64ReinterpretI64 = 100 - I32Extend8S = 9 - I32Extend16S = 9 - I64Extend8S = 9 - I64Extend16S = 9 - I64Extend32S = 9 - I32TruncSatF32S = 100 - I32TruncSatF32U = 100 - I32TruncSatF64S = 100 - I32TruncSatF64U = 100 - I64TruncSatF32S = 100 - I64TruncSatF32U = 100 - I64TruncSatF64S = 100 - I64TruncSatF64U = 100 - MemoryInit = 5 - DataDrop = 5 - MemoryCopy = 5 - MemoryFill = 5 - TableInit = 10 - ElemDrop = 10 - TableCopy = 10 - TableFill = 10 - TableGet = 10 - TableSet = 10 - TableGrow = 10 - TableSize = 10 - AtomicNotify = 1000000 - I32AtomicWait = 1000000 - I64AtomicWait = 1000000 - AtomicFence = 1000000 - I32AtomicLoad = 1000000 - I64AtomicLoad = 1000000 - I32AtomicLoad8U = 1000000 - I32AtomicLoad16U = 1000000 - I64AtomicLoad8U = 1000000 - I64AtomicLoad16U = 1000000 - I64AtomicLoad32U = 1000000 - I32AtomicStore = 1000000 - I64AtomicStore = 1000000 - I32AtomicStore8 = 1000000 - I32AtomicStore16 = 1000000 - I64AtomicStore8 = 1000000 - I64AtomicStore16 = 1000000 - I64AtomicStore32 = 1000000 - I32AtomicRmwAdd = 1000000 - I64AtomicRmwAdd = 1000000 - I32AtomicRmw8AddU = 1000000 - I32AtomicRmw16AddU = 1000000 - I64AtomicRmw8AddU = 1000000 - I64AtomicRmw16AddU = 1000000 - I64AtomicRmw32AddU = 1000000 - I32AtomicRmwSub = 1000000 - I64AtomicRmwSub = 1000000 - I32AtomicRmw8SubU = 1000000 - I32AtomicRmw16SubU = 1000000 - I64AtomicRmw8SubU = 1000000 - I64AtomicRmw16SubU = 1000000 - I64AtomicRmw32SubU = 1000000 - I32AtomicRmwAnd = 1000000 - I64AtomicRmwAnd = 1000000 - I32AtomicRmw8AndU = 1000000 - I32AtomicRmw16AndU = 1000000 - I64AtomicRmw8AndU = 1000000 - I64AtomicRmw16AndU = 1000000 - I64AtomicRmw32AndU = 1000000 - I32AtomicRmwOr = 1000000 - I64AtomicRmwOr = 1000000 - I32AtomicRmw8OrU = 1000000 - I32AtomicRmw16OrU = 1000000 - I64AtomicRmw8OrU = 1000000 - I64AtomicRmw16OrU = 1000000 - I64AtomicRmw32OrU = 1000000 - I32AtomicRmwXor = 1000000 - I64AtomicRmwXor = 1000000 - I32AtomicRmw8XorU = 1000000 - I32AtomicRmw16XorU = 1000000 - I64AtomicRmw8XorU = 1000000 - I64AtomicRmw16XorU = 1000000 - I64AtomicRmw32XorU = 1000000 - I32AtomicRmwXchg = 1000000 - I64AtomicRmwXchg = 1000000 - I32AtomicRmw8XchgU = 1000000 - I32AtomicRmw16XchgU = 1000000 - I64AtomicRmw8XchgU = 1000000 - I64AtomicRmw16XchgU = 1000000 - I64AtomicRmw32XchgU = 1000000 - I32AtomicRmwCmpxchg = 1000000 - I64AtomicRmwCmpxchg = 1000000 - I32AtomicRmw8CmpxchgU = 1000000 - I32AtomicRmw16CmpxchgU = 1000000 - I64AtomicRmw8CmpxchgU = 1000000 - I64AtomicRmw16CmpxchgU = 1000000 - I64AtomicRmw32CmpxchgU = 1000000 - V128Load = 1000000 - V128Store = 1000000 - V128Const = 1000000 - I8x16Splat = 1000000 - I8x16ExtractLaneS = 1000000 - I8x16ExtractLaneU = 1000000 - I8x16ReplaceLane = 1000000 - I16x8Splat = 1000000 - I16x8ExtractLaneS = 1000000 - I16x8ExtractLaneU = 1000000 - I16x8ReplaceLane = 1000000 - I32x4Splat = 1000000 - I32x4ExtractLane = 1000000 - I32x4ReplaceLane = 1000000 - I64x2Splat = 1000000 - I64x2ExtractLane = 1000000 - I64x2ReplaceLane = 1000000 - F32x4Splat = 1000000 - F32x4ExtractLane = 1000000 - F32x4ReplaceLane = 1000000 - F64x2Splat = 1000000 - F64x2ExtractLane = 1000000 - F64x2ReplaceLane = 1000000 - I8x16Eq = 1000000 - I8x16Ne = 1000000 - I8x16LtS = 1000000 - I8x16LtU = 1000000 - I8x16GtS = 1000000 - I8x16GtU = 1000000 - I8x16LeS = 1000000 - I8x16LeU = 1000000 - I8x16GeS = 1000000 - I8x16GeU = 1000000 - I16x8Eq = 1000000 - I16x8Ne = 1000000 - I16x8LtS = 1000000 - I16x8LtU = 1000000 - I16x8GtS = 1000000 - I16x8GtU = 1000000 - I16x8LeS = 1000000 - I16x8LeU = 1000000 - I16x8GeS = 1000000 - I16x8GeU = 1000000 - I32x4Eq = 1000000 - I32x4Ne = 1000000 - I32x4LtS = 1000000 - I32x4LtU = 1000000 - I32x4GtS = 1000000 - I32x4GtU = 1000000 - I32x4LeS = 1000000 - I32x4LeU = 1000000 - I32x4GeS = 1000000 - I32x4GeU = 1000000 - F32x4Eq = 1000000 - F32x4Ne = 1000000 - F32x4Lt = 1000000 - F32x4Gt = 1000000 - F32x4Le = 1000000 - F32x4Ge = 1000000 - F64x2Eq = 1000000 - F64x2Ne = 1000000 - F64x2Lt = 1000000 - F64x2Gt = 1000000 - F64x2Le = 1000000 - F64x2Ge = 1000000 - V128Not = 1000000 - V128And = 1000000 - V128AndNot = 1000000 - V128Or = 1000000 - V128Xor = 1000000 - V128Bitselect = 1000000 - I8x16Neg = 1000000 - I8x16AnyTrue = 1000000 - I8x16AllTrue = 1000000 - I8x16Shl = 1000000 - I8x16ShrS = 1000000 - I8x16ShrU = 1000000 - I8x16Add = 1000000 - I8x16AddSaturateS = 1000000 - I8x16AddSaturateU = 1000000 - I8x16Sub = 1000000 - I8x16SubSaturateS = 1000000 - I8x16SubSaturateU = 1000000 - I8x16MinS = 1000000 - I8x16MinU = 1000000 - I8x16MaxS = 1000000 - I8x16MaxU = 1000000 - I8x16Mul = 1000000 - I16x8Neg = 1000000 - I16x8AnyTrue = 1000000 - I16x8AllTrue = 1000000 - I16x8Shl = 1000000 - I16x8ShrS = 1000000 - I16x8ShrU = 1000000 - I16x8Add = 1000000 - I16x8AddSaturateS = 1000000 - I16x8AddSaturateU = 1000000 - I16x8Sub = 1000000 - I16x8SubSaturateS = 1000000 - I16x8SubSaturateU = 1000000 - I16x8Mul = 1000000 - I16x8MinS = 1000000 - I16x8MinU = 1000000 - I16x8MaxS = 1000000 - I16x8MaxU = 1000000 - I32x4Neg = 1000000 - I32x4AnyTrue = 1000000 - I32x4AllTrue = 1000000 - I32x4Shl = 1000000 - I32x4ShrS = 1000000 - I32x4ShrU = 1000000 - I32x4Add = 1000000 - I32x4Sub = 1000000 - I32x4Mul = 1000000 - I32x4MinS = 1000000 - I32x4MinU = 1000000 - I32x4MaxS = 1000000 - I32x4MaxU = 1000000 - I64x2Neg = 1000000 - I64x2AnyTrue = 1000000 - I64x2AllTrue = 1000000 - I64x2Shl = 1000000 - I64x2ShrS = 1000000 - I64x2ShrU = 1000000 - I64x2Add = 1000000 - I64x2Sub = 1000000 - I64x2Mul = 1000000 - F32x4Abs = 1000000 - F32x4Neg = 1000000 - F32x4Sqrt = 1000000 - F32x4Add = 1000000 - F32x4Sub = 1000000 - F32x4Mul = 1000000 - F32x4Div = 1000000 - F32x4Min = 1000000 - F32x4Max = 1000000 - F64x2Abs = 1000000 - F64x2Neg = 1000000 - F64x2Sqrt = 1000000 - F64x2Add = 1000000 - F64x2Sub = 1000000 - F64x2Mul = 1000000 - F64x2Div = 1000000 - F64x2Min = 1000000 - F64x2Max = 1000000 - I32x4TruncSatF32x4S = 1000000 - I32x4TruncSatF32x4U = 1000000 - I64x2TruncSatF64x2S = 1000000 - I64x2TruncSatF64x2U = 1000000 - F32x4ConvertI32x4S = 1000000 - F32x4ConvertI32x4U = 1000000 - F64x2ConvertI64x2S = 1000000 - F64x2ConvertI64x2U = 1000000 - V8x16Swizzle = 1000000 - V8x16Shuffle = 1000000 - V8x16LoadSplat = 1000000 - V16x8LoadSplat = 1000000 - V32x4LoadSplat = 1000000 - V64x2LoadSplat = 1000000 - I8x16NarrowI16x8S = 1000000 - I8x16NarrowI16x8U = 1000000 - I16x8NarrowI32x4S = 1000000 - I16x8NarrowI32x4U = 1000000 - I16x8WidenLowI8x16S = 1000000 - I16x8WidenHighI8x16S = 1000000 - I16x8WidenLowI8x16U = 1000000 - I16x8WidenHighI8x16U = 1000000 - I32x4WidenLowI16x8S = 1000000 - I32x4WidenHighI16x8S = 1000000 - I32x4WidenLowI16x8U = 1000000 - I32x4WidenHighI16x8U = 1000000 - I16x8Load8x8S = 1000000 - I16x8Load8x8U = 1000000 - I32x4Load16x4S = 1000000 - I32x4Load16x4U = 1000000 - I64x2Load32x2S = 1000000 - I64x2Load32x2U = 1000000 - I8x16RoundingAverageU = 1000000 - I16x8RoundingAverageU = 1000000 - LocalAllocate = 5 - LocalsUnmetered = 100 - MaxMemoryGrowDelta = 1 - MaxMemoryGrow = 10 - Catch = 1 - CatchAll = 1 - Delegate = 1 - F32x4Ceil = 1 - F32x4DemoteF64x2Zero = 1 - F32x4Floor = 1 - F32x4Nearest = 1 - F32x4PMax = 1 - F32x4PMin = 1 - F32x4Trunc = 1 - F64x2Ceil = 1 - F64x2ConvertLowI32x4S = 1 - F64x2ConvertLowI32x4U = 1 - F64x2Floor = 1 - F64x2Nearest = 1 - F64x2PMax = 1 - F64x2PMin = 1 - F64x2PromoteLowF32x4 = 1 - F64x2Trunc = 1 - I16x8Abs = 1 - I16x8AddSatS = 1 - I16x8AddSatU = 1 - I16x8Bitmask = 1 - I16x8ExtAddPairwiseI8x16S = 1 - I16x8ExtAddPairwiseI8x16U = 1 - I16x8ExtMulHighI8x16S = 1 - I16x8ExtMulHighI8x16U = 1 - I16x8ExtMulLowI8x16S = 1 - I16x8ExtMulLowI8x16U = 1 - I16x8ExtendHighI8x16S = 1 - I16x8ExtendHighI8x16U = 1 - I16x8ExtendLowI8x16S = 1 - I16x8ExtendLowI8x16U = 1 - I16x8Q15MulrSatS = 1 - I16x8SubSatS = 1 - I16x8SubSatU = 1 - I32x4Abs = 1 - I32x4Bitmask = 1 - I32x4DotI16x8S = 1 - I32x4ExtAddPairwiseI16x8S = 1 - I32x4ExtAddPairwiseI16x8U = 1 - I32x4ExtMulHighI16x8S = 1 - I32x4ExtMulHighI16x8U = 1 - I32x4ExtMulLowI16x8S = 1 - I32x4ExtMulLowI16x8U = 1 - I32x4ExtendHighI16x8S = 1 - I32x4ExtendHighI16x8U = 1 - I32x4ExtendLowI16x8S = 1 - I32x4ExtendLowI16x8U = 1 - I32x4TruncSatF64x2SZero = 1 - I32x4TruncSatF64x2UZero = 1 - I64x2Abs = 1 - I64x2Bitmask = 1 - I64x2Eq = 1 - I64x2ExtMulHighI32x4S = 1 - I64x2ExtMulHighI32x4U = 1 - I64x2ExtMulLowI32x4S = 1 - I64x2ExtMulLowI32x4U = 1 - I64x2ExtendHighI32x4S = 1 - I64x2ExtendHighI32x4U = 1 - I64x2ExtendLowI32x4S = 1 - I64x2ExtendLowI32x4U = 1 - I64x2GeS = 1 - I64x2GtS = 1 - I64x2LeS = 1 - I64x2LtS = 1 - I64x2Ne = 1 - I8x16Abs = 1 - I8x16AddSatS = 1 - I8x16AddSatU = 1 - I8x16Bitmask = 1 - I8x16Popcnt = 1 - I8x16Shuffle = 1 - I8x16SubSatS = 1 - I8x16SubSatU = 1 - I8x16Swizzle = 1 - MemoryAtomicNotify = 1 - MemoryAtomicWait32 = 1 - MemoryAtomicWait64 = 1 - Rethrow = 1 - ReturnCall = 1 - ReturnCallIndirect = 1 - Throw = 1 - Try = 1 - Unwind = 1 - V128AnyTrue = 1 - V128Load16Lane = 1 - V128Load16Splat = 1 - V128Load16x4S = 1 - V128Load16x4U = 1 - V128Load32Lane = 1 - V128Load32Splat = 1 - V128Load32Zero = 1 - V128Load32x2S = 1 - V128Load32x2U = 1 - V128Load64Lane = 1 - V128Load64Splat = 1 - V128Load64Zero = 1 - V128Load8Lane = 1 - V128Load8Splat = 1 - V128Load8x8S = 1 - V128Load8x8U = 1 - V128Store16Lane = 1 - V128Store32Lane = 1 - V128Store64Lane = 1 - V128Store8Lane = 1 - -[MaxPerTransaction] - MaxBuiltInCallsPerTx = 100 - MaxNumberOfTransfersPerTx = 250 - MaxNumberOfTrieReadsPerTx = 1500 - -# Quadratic, Linear and Constant are the coefficients for a quadratic func. Separate variables are used for the -# sign of each coefficient, 0 meaning positive and 1 meaning negative -# The current values for the coefficients were computed based on benchmarking. -# For the given coefficients, the minimum of the function must not be lower than MinimumGasCost -[DynamicStorageLoad] - QuadraticCoefficient = 688 - SignOfQuadratic = 0 - LinearCoefficient = 31858 - SignOfLinear = 0 - ConstantCoefficient = 15287 - SignOfConstant = 0 - MinimumGasCost = 10000 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV7.toml b/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV7.toml deleted file mode 100644 index f3930be8..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/gasSchedules/gasScheduleV7.toml +++ /dev/null @@ -1,828 +0,0 @@ -[BuiltInCost] - ChangeOwnerAddress = 5000000 - ClaimDeveloperRewards = 5000000 - SaveUserName = 1000000 - SaveKeyValue = 100000 - ESDTTransfer = 200000 - ESDTBurn = 100000 - ESDTLocalMint = 50000 - ESDTLocalBurn = 50000 - ESDTNFTCreate = 150000 - ESDTNFTAddQuantity = 50000 - ESDTNFTBurn = 50000 - ESDTNFTTransfer = 200000 - ESDTNFTChangeCreateOwner = 1000000 - ESDTNFTAddUri = 50000 - ESDTNFTUpdateAttributes = 50000 - ESDTNFTMultiTransfer = 200000 - MultiESDTNFTTransfer = 200000 # should be the same value with the ESDTNFTMultiTransfer - SetGuardian = 250000 - GuardAccount = 250000 - UnGuardAccount = 250000 - TrieLoadPerNode = 100000 - TrieStorePerNode = 50000 - -[MetaChainSystemSCsCost] - Stake = 5000000 - UnStake = 5000000 - UnBond = 5000000 - Claim = 5000000 - Get = 5000000 - ChangeRewardAddress = 5000000 - ChangeValidatorKeys = 5000000 - UnJail = 5000000 - DelegationOps = 1000000 - DelegationMgrOps = 50000000 - ValidatorToDelegation = 500000000 - ESDTIssue = 50000000 - ESDTOperations = 50000000 - Proposal = 50000000 - Vote = 5000000 - DelegateVote = 50000000 - RevokeVote = 50000000 - CloseProposal = 50000000 - GetAllNodeStates = 20000000 - UnstakeTokens = 5000000 - UnbondTokens = 5000000 - GetActiveFund = 50000 - FixWaitingListSize = 500000000 - -[BaseOperationCost] - StorePerByte = 10000 - ReleasePerByte = 1000 - DataCopyPerByte = 50 - PersistPerByte = 1000 - CompilePerByte = 300 - AoTPreparePerByte = 100 - GetCode = 1000000 - -[BaseOpsAPICost] - GetSCAddress = 100 - GetOwnerAddress = 5000 - IsSmartContract = 5000 - GetShardOfAddress = 5000 - GetExternalBalance = 7000 - GetBlockHash = 10000 - TransferValue = 100000 - GetArgument = 100 - GetFunction = 100 - GetNumArguments = 100 - StorageStore = 75000 - StorageLoad = 50000 - CachedStorageLoad = 1000 - GetCaller = 100 - GetCallValue = 100 - Log = 3750 - Finish = 1 - SignalError = 1 - GetBlockTimeStamp = 10000 - GetGasLeft = 100 - Int64GetArgument = 100 - Int64StorageStore = 75000 - Int64StorageLoad = 50000 - Int64Finish = 1000 - GetStateRootHash = 10000 - GetBlockNonce = 10000 - GetBlockEpoch = 10000 - GetBlockRound = 10000 - GetBlockRandomSeed = 10000 - ExecuteOnSameContext = 100000 - ExecuteOnDestContext = 100000 - DelegateExecution = 100000 - AsyncCallStep = 100000 - AsyncCallbackGasLock = 4000000 - ExecuteReadOnly = 160000 - CreateContract = 300000 - GetReturnData = 100 - GetNumReturnData = 100 - GetReturnDataSize = 100 - GetOriginalTxHash = 10000 - CleanReturnData = 100 - DeleteFromReturnData = 100 - GetPrevTxHash = 10000 - GetCurrentTxHash = 10000 - CreateAsyncCall = 200000 - SetAsyncCallback = 100000 - SetAsyncGroupCallback = 100000 - SetAsyncContextCallback = 100000 - GetCallbackClosure = 10000 - GetCodeMetadata = 10000 - IsBuiltinFunction = 10000 - -[EthAPICost] - UseGas = 100 - GetAddress = 100000 - GetExternalBalance = 70000 - GetBlockHash = 100000 - Call = 160000 - CallDataCopy = 200 - GetCallDataSize = 100 - CallCode = 160000 - CallDelegate = 160000 - CallStatic = 160000 - StorageStore = 250000 - StorageLoad = 100000 - GetCaller = 100 - GetCallValue = 100 - CodeCopy = 1000 - GetCodeSize = 100 - GetBlockCoinbase = 100 - Create = 320000 - GetBlockDifficulty = 100 - ExternalCodeCopy = 3000 - GetExternalCodeSize = 2500 - GetGasLeft = 100 - GetBlockGasLimit = 100000 - GetTxGasPrice = 1000 - Log = 3750 - GetBlockNumber = 100000 - GetTxOrigin = 100000 - Finish = 1 - Revert = 1 - GetReturnDataSize = 200 - ReturnDataCopy = 500 - SelfDestruct = 5000000 - GetBlockTimeStamp = 100000 - -[BigIntAPICost] - BigIntNew = 2000 - BigIntByteLength = 2000 - BigIntUnsignedByteLength = 2000 - BigIntSignedByteLength = 2000 - BigIntGetBytes = 2000 - BigIntGetUnsignedBytes = 2000 - BigIntGetSignedBytes = 2000 - BigIntSetBytes = 2000 - BigIntSetUnsignedBytes = 2000 - BigIntSetSignedBytes = 2000 - BigIntIsInt64 = 2000 - BigIntGetInt64 = 2000 - BigIntSetInt64 = 2000 - BigIntAdd = 2000 - BigIntSub = 2000 - BigIntMul = 6000 - BigIntSqrt = 6000 - BigIntPow = 6000 - BigIntLog = 6000 - BigIntTDiv = 6000 - BigIntTMod = 6000 - BigIntEDiv = 6000 - BigIntEMod = 6000 - BigIntAbs = 2000 - BigIntNeg = 2000 - BigIntSign = 2000 - BigIntCmp = 2000 - BigIntNot = 2000 - BigIntAnd = 2000 - BigIntOr = 2000 - BigIntXor = 2000 - BigIntShr = 2000 - BigIntShl = 2000 - BigIntFinishUnsigned = 1000 - BigIntFinishSigned = 1000 - BigIntStorageLoadUnsigned = 50000 - BigIntStorageStoreUnsigned = 75000 - BigIntGetArgument = 1000 - BigIntGetUnsignedArgument = 1000 - BigIntGetSignedArgument = 1000 - BigIntGetCallValue = 1000 - BigIntGetExternalBalance = 10000 - CopyPerByteForTooBig = 1000 - -[CryptoAPICost] - SHA256 = 1000000 - Keccak256 = 1000000 - Ripemd160 = 1000000 - VerifyBLS = 5000000 - VerifyEd25519 = 2000000 - VerifySecp256k1 = 2000000 - EllipticCurveNew = 10000 - AddECC = 75000 - DoubleECC = 65000 - IsOnCurveECC = 10000 - ScalarMultECC = 400000 - MarshalECC = 13000 - MarshalCompressedECC = 15000 - UnmarshalECC = 20000 - UnmarshalCompressedECC = 270000 - GenerateKeyECC = 7000000 - EncodeDERSig = 10000000 - -[ManagedBufferAPICost] - MBufferNew = 2000 - MBufferNewFromBytes = 2000 - MBufferGetLength = 2000 - MBufferGetBytes = 2000 - MBufferGetByteSlice = 2000 - MBufferCopyByteSlice = 2000 - MBufferSetBytes = 2000 - MBufferAppend = 2000 - MBufferAppendBytes = 2000 - MBufferToBigIntUnsigned = 2000 - MBufferToBigIntSigned = 5000 - MBufferFromBigIntUnsigned = 2000 - MBufferFromBigIntSigned = 5000 - MBufferStorageStore = 75000 - MBufferStorageLoad = 50000 - MBufferGetArgument = 1000 - MBufferFinish = 1000 - MBufferSetRandom = 6000 - MBufferToBigFloat = 2000 - MBufferFromBigFloat = 2000 - -[BigFloatAPICost] - BigFloatNewFromParts = 3000 - BigFloatAdd = 7000 - BigFloatSub = 7000 - BigFloatMul = 7000 - BigFloatDiv = 7000 - BigFloatTruncate = 5000 - BigFloatNeg = 5000 - BigFloatClone = 5000 - BigFloatCmp = 4000 - BigFloatAbs = 5000 - BigFloatSqrt = 7000 - BigFloatPow = 10000 - BigFloatFloor = 5000 - BigFloatCeil = 5000 - BigFloatIsInt = 3000 - BigFloatSetBigInt = 3000 - BigFloatSetInt64 = 1000 - BigFloatGetConst = 1000 - -[WASMOpcodeCost] - Unreachable = 5 - Nop = 5 - Block = 5 - Loop = 5 - If = 5 - Else = 5 - End = 5 - Br = 5 - BrIf = 5 - BrTable = 5 - Return = 5 - Call = 5 - CallIndirect = 5 - Drop = 5 - Select = 5 - TypedSelect = 5 - LocalGet = 5 - LocalSet = 5 - LocalTee = 5 - GlobalGet = 5 - GlobalSet = 5 - I32Load = 5 - I64Load = 5 - F32Load = 6 - F64Load = 6 - I32Load8S = 5 - I32Load8U = 5 - I32Load16S = 5 - I32Load16U = 5 - I64Load8S = 5 - I64Load8U = 5 - I64Load16S = 5 - I64Load16U = 5 - I64Load32S = 5 - I64Load32U = 5 - I32Store = 5 - I64Store = 5 - F32Store = 12 - F64Store = 12 - I32Store8 = 5 - I32Store16 = 5 - I64Store8 = 5 - I64Store16 = 5 - I64Store32 = 5 - MemorySize = 5 - MemoryGrow = 1000000 - I32Const = 5 - I64Const = 5 - F32Const = 5 - F64Const = 5 - RefNull = 5 - RefIsNull = 5 - RefFunc = 5 - I32Eqz = 5 - I32Eq = 5 - I32Ne = 5 - I32LtS = 5 - I32LtU = 5 - I32GtS = 5 - I32GtU = 5 - I32LeS = 5 - I32LeU = 5 - I32GeS = 5 - I32GeU = 5 - I64Eqz = 5 - I64Eq = 5 - I64Ne = 5 - I64LtS = 5 - I64LtU = 5 - I64GtS = 5 - I64GtU = 5 - I64LeS = 5 - I64LeU = 5 - I64GeS = 5 - I64GeU = 5 - F32Eq = 6 - F32Ne = 6 - F32Lt = 6 - F32Gt = 6 - F32Le = 6 - F32Ge = 6 - F64Eq = 6 - F64Ne = 6 - F64Lt = 6 - F64Gt = 6 - F64Le = 6 - F64Ge = 6 - I32Clz = 100 - I32Ctz = 100 - I32Popcnt = 100 - I32Add = 5 - I32Sub = 5 - I32Mul = 5 - I32DivS = 18 - I32DivU = 18 - I32RemS = 18 - I32RemU = 18 - I32And = 5 - I32Or = 5 - I32Xor = 5 - I32Shl = 5 - I32ShrS = 5 - I32ShrU = 5 - I32Rotl = 5 - I32Rotr = 5 - I64Clz = 100 - I64Ctz = 100 - I64Popcnt = 100 - I64Add = 5 - I64Sub = 5 - I64Mul = 5 - I64DivS = 18 - I64DivU = 18 - I64RemS = 18 - I64RemU = 18 - I64And = 5 - I64Or = 5 - I64Xor = 5 - I64Shl = 5 - I64ShrS = 5 - I64ShrU = 5 - I64Rotl = 5 - I64Rotr = 5 - F32Abs = 5 - F32Neg = 5 - F32Ceil = 100 - F32Floor = 100 - F32Trunc = 100 - F32Nearest = 100 - F32Sqrt = 100 - F32Add = 5 - F32Sub = 5 - F32Mul = 15 - F32Div = 100 - F32Min = 15 - F32Max = 15 - F32Copysign = 5 - F64Abs = 5 - F64Neg = 5 - F64Ceil = 100 - F64Floor = 100 - F64Trunc = 100 - F64Nearest = 100 - F64Sqrt = 100 - F64Add = 5 - F64Sub = 5 - F64Mul = 15 - F64Div = 100 - F64Min = 15 - F64Max = 15 - F64Copysign = 5 - I32WrapI64 = 9 - I32TruncF32S = 100 - I32TruncF32U = 100 - I32TruncF64S = 100 - I32TruncF64U = 100 - I64ExtendI32S = 9 - I64ExtendI32U = 9 - I64TruncF32S = 100 - I64TruncF32U = 100 - I64TruncF64S = 100 - I64TruncF64U = 100 - F32ConvertI32S = 100 - F32ConvertI32U = 100 - F32ConvertI64S = 100 - F32ConvertI64U = 100 - F32DemoteF64 = 100 - F64ConvertI32S = 100 - F64ConvertI32U = 100 - F64ConvertI64S = 100 - F64ConvertI64U = 100 - F64PromoteF32 = 100 - I32ReinterpretF32 = 100 - I64ReinterpretF64 = 100 - F32ReinterpretI32 = 100 - F64ReinterpretI64 = 100 - I32Extend8S = 9 - I32Extend16S = 9 - I64Extend8S = 9 - I64Extend16S = 9 - I64Extend32S = 9 - I32TruncSatF32S = 100 - I32TruncSatF32U = 100 - I32TruncSatF64S = 100 - I32TruncSatF64U = 100 - I64TruncSatF32S = 100 - I64TruncSatF32U = 100 - I64TruncSatF64S = 100 - I64TruncSatF64U = 100 - MemoryInit = 5 - DataDrop = 5 - MemoryCopy = 5 - MemoryFill = 5 - TableInit = 10 - ElemDrop = 10 - TableCopy = 10 - TableFill = 10 - TableGet = 10 - TableSet = 10 - TableGrow = 10 - TableSize = 10 - AtomicNotify = 1000000 - I32AtomicWait = 1000000 - I64AtomicWait = 1000000 - AtomicFence = 1000000 - I32AtomicLoad = 1000000 - I64AtomicLoad = 1000000 - I32AtomicLoad8U = 1000000 - I32AtomicLoad16U = 1000000 - I64AtomicLoad8U = 1000000 - I64AtomicLoad16U = 1000000 - I64AtomicLoad32U = 1000000 - I32AtomicStore = 1000000 - I64AtomicStore = 1000000 - I32AtomicStore8 = 1000000 - I32AtomicStore16 = 1000000 - I64AtomicStore8 = 1000000 - I64AtomicStore16 = 1000000 - I64AtomicStore32 = 1000000 - I32AtomicRmwAdd = 1000000 - I64AtomicRmwAdd = 1000000 - I32AtomicRmw8AddU = 1000000 - I32AtomicRmw16AddU = 1000000 - I64AtomicRmw8AddU = 1000000 - I64AtomicRmw16AddU = 1000000 - I64AtomicRmw32AddU = 1000000 - I32AtomicRmwSub = 1000000 - I64AtomicRmwSub = 1000000 - I32AtomicRmw8SubU = 1000000 - I32AtomicRmw16SubU = 1000000 - I64AtomicRmw8SubU = 1000000 - I64AtomicRmw16SubU = 1000000 - I64AtomicRmw32SubU = 1000000 - I32AtomicRmwAnd = 1000000 - I64AtomicRmwAnd = 1000000 - I32AtomicRmw8AndU = 1000000 - I32AtomicRmw16AndU = 1000000 - I64AtomicRmw8AndU = 1000000 - I64AtomicRmw16AndU = 1000000 - I64AtomicRmw32AndU = 1000000 - I32AtomicRmwOr = 1000000 - I64AtomicRmwOr = 1000000 - I32AtomicRmw8OrU = 1000000 - I32AtomicRmw16OrU = 1000000 - I64AtomicRmw8OrU = 1000000 - I64AtomicRmw16OrU = 1000000 - I64AtomicRmw32OrU = 1000000 - I32AtomicRmwXor = 1000000 - I64AtomicRmwXor = 1000000 - I32AtomicRmw8XorU = 1000000 - I32AtomicRmw16XorU = 1000000 - I64AtomicRmw8XorU = 1000000 - I64AtomicRmw16XorU = 1000000 - I64AtomicRmw32XorU = 1000000 - I32AtomicRmwXchg = 1000000 - I64AtomicRmwXchg = 1000000 - I32AtomicRmw8XchgU = 1000000 - I32AtomicRmw16XchgU = 1000000 - I64AtomicRmw8XchgU = 1000000 - I64AtomicRmw16XchgU = 1000000 - I64AtomicRmw32XchgU = 1000000 - I32AtomicRmwCmpxchg = 1000000 - I64AtomicRmwCmpxchg = 1000000 - I32AtomicRmw8CmpxchgU = 1000000 - I32AtomicRmw16CmpxchgU = 1000000 - I64AtomicRmw8CmpxchgU = 1000000 - I64AtomicRmw16CmpxchgU = 1000000 - I64AtomicRmw32CmpxchgU = 1000000 - V128Load = 1000000 - V128Store = 1000000 - V128Const = 1000000 - I8x16Splat = 1000000 - I8x16ExtractLaneS = 1000000 - I8x16ExtractLaneU = 1000000 - I8x16ReplaceLane = 1000000 - I16x8Splat = 1000000 - I16x8ExtractLaneS = 1000000 - I16x8ExtractLaneU = 1000000 - I16x8ReplaceLane = 1000000 - I32x4Splat = 1000000 - I32x4ExtractLane = 1000000 - I32x4ReplaceLane = 1000000 - I64x2Splat = 1000000 - I64x2ExtractLane = 1000000 - I64x2ReplaceLane = 1000000 - F32x4Splat = 1000000 - F32x4ExtractLane = 1000000 - F32x4ReplaceLane = 1000000 - F64x2Splat = 1000000 - F64x2ExtractLane = 1000000 - F64x2ReplaceLane = 1000000 - I8x16Eq = 1000000 - I8x16Ne = 1000000 - I8x16LtS = 1000000 - I8x16LtU = 1000000 - I8x16GtS = 1000000 - I8x16GtU = 1000000 - I8x16LeS = 1000000 - I8x16LeU = 1000000 - I8x16GeS = 1000000 - I8x16GeU = 1000000 - I16x8Eq = 1000000 - I16x8Ne = 1000000 - I16x8LtS = 1000000 - I16x8LtU = 1000000 - I16x8GtS = 1000000 - I16x8GtU = 1000000 - I16x8LeS = 1000000 - I16x8LeU = 1000000 - I16x8GeS = 1000000 - I16x8GeU = 1000000 - I32x4Eq = 1000000 - I32x4Ne = 1000000 - I32x4LtS = 1000000 - I32x4LtU = 1000000 - I32x4GtS = 1000000 - I32x4GtU = 1000000 - I32x4LeS = 1000000 - I32x4LeU = 1000000 - I32x4GeS = 1000000 - I32x4GeU = 1000000 - F32x4Eq = 1000000 - F32x4Ne = 1000000 - F32x4Lt = 1000000 - F32x4Gt = 1000000 - F32x4Le = 1000000 - F32x4Ge = 1000000 - F64x2Eq = 1000000 - F64x2Ne = 1000000 - F64x2Lt = 1000000 - F64x2Gt = 1000000 - F64x2Le = 1000000 - F64x2Ge = 1000000 - V128Not = 1000000 - V128And = 1000000 - V128AndNot = 1000000 - V128Or = 1000000 - V128Xor = 1000000 - V128Bitselect = 1000000 - I8x16Neg = 1000000 - I8x16AnyTrue = 1000000 - I8x16AllTrue = 1000000 - I8x16Shl = 1000000 - I8x16ShrS = 1000000 - I8x16ShrU = 1000000 - I8x16Add = 1000000 - I8x16AddSaturateS = 1000000 - I8x16AddSaturateU = 1000000 - I8x16Sub = 1000000 - I8x16SubSaturateS = 1000000 - I8x16SubSaturateU = 1000000 - I8x16MinS = 1000000 - I8x16MinU = 1000000 - I8x16MaxS = 1000000 - I8x16MaxU = 1000000 - I8x16Mul = 1000000 - I16x8Neg = 1000000 - I16x8AnyTrue = 1000000 - I16x8AllTrue = 1000000 - I16x8Shl = 1000000 - I16x8ShrS = 1000000 - I16x8ShrU = 1000000 - I16x8Add = 1000000 - I16x8AddSaturateS = 1000000 - I16x8AddSaturateU = 1000000 - I16x8Sub = 1000000 - I16x8SubSaturateS = 1000000 - I16x8SubSaturateU = 1000000 - I16x8Mul = 1000000 - I16x8MinS = 1000000 - I16x8MinU = 1000000 - I16x8MaxS = 1000000 - I16x8MaxU = 1000000 - I32x4Neg = 1000000 - I32x4AnyTrue = 1000000 - I32x4AllTrue = 1000000 - I32x4Shl = 1000000 - I32x4ShrS = 1000000 - I32x4ShrU = 1000000 - I32x4Add = 1000000 - I32x4Sub = 1000000 - I32x4Mul = 1000000 - I32x4MinS = 1000000 - I32x4MinU = 1000000 - I32x4MaxS = 1000000 - I32x4MaxU = 1000000 - I64x2Neg = 1000000 - I64x2AnyTrue = 1000000 - I64x2AllTrue = 1000000 - I64x2Shl = 1000000 - I64x2ShrS = 1000000 - I64x2ShrU = 1000000 - I64x2Add = 1000000 - I64x2Sub = 1000000 - I64x2Mul = 1000000 - F32x4Abs = 1000000 - F32x4Neg = 1000000 - F32x4Sqrt = 1000000 - F32x4Add = 1000000 - F32x4Sub = 1000000 - F32x4Mul = 1000000 - F32x4Div = 1000000 - F32x4Min = 1000000 - F32x4Max = 1000000 - F64x2Abs = 1000000 - F64x2Neg = 1000000 - F64x2Sqrt = 1000000 - F64x2Add = 1000000 - F64x2Sub = 1000000 - F64x2Mul = 1000000 - F64x2Div = 1000000 - F64x2Min = 1000000 - F64x2Max = 1000000 - I32x4TruncSatF32x4S = 1000000 - I32x4TruncSatF32x4U = 1000000 - I64x2TruncSatF64x2S = 1000000 - I64x2TruncSatF64x2U = 1000000 - F32x4ConvertI32x4S = 1000000 - F32x4ConvertI32x4U = 1000000 - F64x2ConvertI64x2S = 1000000 - F64x2ConvertI64x2U = 1000000 - V8x16Swizzle = 1000000 - V8x16Shuffle = 1000000 - V8x16LoadSplat = 1000000 - V16x8LoadSplat = 1000000 - V32x4LoadSplat = 1000000 - V64x2LoadSplat = 1000000 - I8x16NarrowI16x8S = 1000000 - I8x16NarrowI16x8U = 1000000 - I16x8NarrowI32x4S = 1000000 - I16x8NarrowI32x4U = 1000000 - I16x8WidenLowI8x16S = 1000000 - I16x8WidenHighI8x16S = 1000000 - I16x8WidenLowI8x16U = 1000000 - I16x8WidenHighI8x16U = 1000000 - I32x4WidenLowI16x8S = 1000000 - I32x4WidenHighI16x8S = 1000000 - I32x4WidenLowI16x8U = 1000000 - I32x4WidenHighI16x8U = 1000000 - I16x8Load8x8S = 1000000 - I16x8Load8x8U = 1000000 - I32x4Load16x4S = 1000000 - I32x4Load16x4U = 1000000 - I64x2Load32x2S = 1000000 - I64x2Load32x2U = 1000000 - I8x16RoundingAverageU = 1000000 - I16x8RoundingAverageU = 1000000 - LocalAllocate = 5 - LocalsUnmetered = 100 - MaxMemoryGrowDelta = 1 - MaxMemoryGrow = 10 - Catch = 10 - CatchAll = 10 - Delegate = 10 - Rethrow = 10 - ReturnCall = 10 - ReturnCallIndirect = 10 - Throw = 10 - Try = 10 - Unwind = 10 - F32x4Ceil = 1000000 - F32x4DemoteF64x2Zero = 1000000 - F32x4Floor = 1000000 - F32x4Nearest = 1000000 - F32x4PMax = 1000000 - F32x4PMin = 1000000 - F32x4Trunc = 1000000 - F64x2Ceil = 1000000 - F64x2ConvertLowI32x4S = 1000000 - F64x2ConvertLowI32x4U = 1000000 - F64x2Floor = 1000000 - F64x2Nearest = 1000000 - F64x2PMax = 1000000 - F64x2PMin = 1000000 - F64x2PromoteLowF32x4 = 1000000 - F64x2Trunc = 1000000 - I16x8Abs = 1000000 - I16x8AddSatS = 1000000 - I16x8AddSatU = 1000000 - I16x8Bitmask = 1000000 - I16x8ExtAddPairwiseI8x16S = 1000000 - I16x8ExtAddPairwiseI8x16U = 1000000 - I16x8ExtMulHighI8x16S = 1000000 - I16x8ExtMulHighI8x16U = 1000000 - I16x8ExtMulLowI8x16S = 1000000 - I16x8ExtMulLowI8x16U = 1000000 - I16x8ExtendHighI8x16S = 1000000 - I16x8ExtendHighI8x16U = 1000000 - I16x8ExtendLowI8x16S = 1000000 - I16x8ExtendLowI8x16U = 1000000 - I16x8Q15MulrSatS = 1000000 - I16x8SubSatS = 1000000 - I16x8SubSatU = 1000000 - I32x4Abs = 1000000 - I32x4Bitmask = 1000000 - I32x4DotI16x8S = 1000000 - I32x4ExtAddPairwiseI16x8S = 1000000 - I32x4ExtAddPairwiseI16x8U = 1000000 - I32x4ExtMulHighI16x8S = 1000000 - I32x4ExtMulHighI16x8U = 1000000 - I32x4ExtMulLowI16x8S = 1000000 - I32x4ExtMulLowI16x8U = 1000000 - I32x4ExtendHighI16x8S = 1000000 - I32x4ExtendHighI16x8U = 1000000 - I32x4ExtendLowI16x8S = 1000000 - I32x4ExtendLowI16x8U = 1000000 - I32x4TruncSatF64x2SZero = 1000000 - I32x4TruncSatF64x2UZero = 1000000 - I64x2Abs = 1000000 - I64x2Bitmask = 1000000 - I64x2Eq = 1000000 - I64x2ExtMulHighI32x4S = 1000000 - I64x2ExtMulHighI32x4U = 1000000 - I64x2ExtMulLowI32x4S = 1000000 - I64x2ExtMulLowI32x4U = 1000000 - I64x2ExtendHighI32x4S = 1000000 - I64x2ExtendHighI32x4U = 1000000 - I64x2ExtendLowI32x4S = 1000000 - I64x2ExtendLowI32x4U = 1000000 - I64x2GeS = 1000000 - I64x2GtS = 1000000 - I64x2LeS = 1000000 - I64x2LtS = 1000000 - I64x2Ne = 1000000 - I8x16Abs = 1000000 - I8x16AddSatS = 1000000 - I8x16AddSatU = 1000000 - I8x16Bitmask = 1000000 - I8x16Popcnt = 1000000 - I8x16Shuffle = 1000000 - I8x16SubSatS = 1000000 - I8x16SubSatU = 1000000 - I8x16Swizzle = 1000000 - MemoryAtomicNotify = 1000000 - MemoryAtomicWait32 = 1000000 - MemoryAtomicWait64 = 1000000 - V128AnyTrue = 1000000 - V128Load16Lane = 1000000 - V128Load16Splat = 1000000 - V128Load16x4S = 1000000 - V128Load16x4U = 1000000 - V128Load32Lane = 1000000 - V128Load32Splat = 1000000 - V128Load32Zero = 1000000 - V128Load32x2S = 1000000 - V128Load32x2U = 1000000 - V128Load64Lane = 1000000 - V128Load64Splat = 1000000 - V128Load64Zero = 1000000 - V128Load8Lane = 1000000 - V128Load8Splat = 1000000 - V128Load8x8S = 1000000 - V128Load8x8U = 1000000 - V128Store16Lane = 1000000 - V128Store32Lane = 1000000 - V128Store64Lane = 1000000 - V128Store8Lane = 1000000 - -[MaxPerTransaction] - MaxBuiltInCallsPerTx = 100 - MaxNumberOfTransfersPerTx = 250 - MaxNumberOfTrieReadsPerTx = 1500 - -# Quadratic, Linear and Constant are the coefficients for a quadratic func. Separate variables are used for the -# sign of each coefficient, 0 meaning positive and 1 meaning negative -# The current values for the coefficients were computed based on benchmarking. -# For the given coefficients, the minimum of the function must not be lower than MinimumGasCost -[DynamicStorageLoad] - QuadraticCoefficient = 688 - SignOfQuadratic = 0 - LinearCoefficient = 31858 - SignOfLinear = 0 - ConstantCoefficient = 15287 - SignOfConstant = 0 - MinimumGasCost = 10000 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/genesis.json b/integrationTests/relayers/testdata/config/nodeConfig/genesis.json deleted file mode 100644 index 27f74229..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/genesis.json +++ /dev/null @@ -1,497 +0,0 @@ -[ - { - "info": "delegator1 for legacy delegation", - "address": "erd1z48u9l275l2uy4augfytpp2355wvdnc4gwc9ms9gdhdqru3fz9eq5wqe3e", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator2 for legacy delegation", - "address": "erd1qm5erxm0va3hcw9jfxtp2gl3u9q9p4k242pk9xx3vezefkgj2vhs0wk8cx", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator3 for legacy delegation", - "address": "erd1rqwt9vpfn072tahtcvup2dxz4nvqfs3n5p9eh0jnypkppxmdheaqpcqfzz", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator4 for legacy delegation", - "address": "erd17uygg7qq05mjhectgymj6fwq59ysr4p92cy0yz3jrxxj6253p40sj77wr6", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator5 for legacy delegation", - "address": "erd1qslr87nj5gkv2396js3fa2za5kqgwugqnz4j4qqh22mxpnse2lws8srsq6", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator6 for legacy delegation", - "address": "erd17pjlqg55c6v3fjvpqec8peefk74g8neygr84ymw7cqzudmzaw7lqnln7sz", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator7 for legacy delegation", - "address": "erd19ztfuew6ejrwq5mpax4xztjwh5j63u9vge4dum9vlyy7hg3pc86qgmt6nm", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator8 for legacy delegation", - "address": "erd1age5t5qfrke4vm47vaq9a4yewllh6227qm4fcy3rc7g5ktmzyatsgf4wcw", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator9 for legacy delegation", - "address": "erd1jt0vv29trqs3nddzkxsf950xx0t5uvyncmuamwryneh9wsee5wpsgue96d", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "delegator10 for legacy delegation", - "address": "erd1c83rmk3n8ys4g9dkg3q70thx3v787qtpfmk23epu4xsadpyd3dnsejf2r7", - "supply": "1001000000000000000000", - "balance": "1000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "erd1qqqqqqqqqqqqqpgqrchxzx5uu8sv3ceg8nx8cxc0gesezure5awqn46gtd", - "value": "1000000000000000000000" - } - }, - { - "info": "wallet1 2500*8 staked + 10000 initial balance", - "address": "erd19ptzdk7zvs3csjjf8u04j5kxzn5jck409sefdyx6x9afkjg4wunsfw7rj7", - "supply": "30000000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "20000000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet2 2500*6 staked + 10000 initial balance", - "address": "erd1qz9gp38g4238r3077wq4tpc0jxaq0f87c0t2n2hr3x6fef85t3lshq2ejk", - "supply": "25000000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "15000000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet3 2500*4 staked + 10000 initial balance", - "address": "erd1tp2af4jvdh7p79myu5h6srtchh42p5e3pchqre3ejyyn9mqhwa3shpgj35", - "supply": "20000000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "10000000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet4 2500*4 staked + 10000 initial balance", - "address": "erd1e2ftj4hj43lkduwps9xdmtgjnmugkh9mndph4n2cxfmf6ufvn4ks0zut84", - "supply": "20000000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "10000000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet5 2500*3 staked + 10000 initial balance", - "address": "erd1dzjes5c6a8ru45clgla3q0k3ezm06svefjz7vzs8pjfnrqa8tcasl4j8hs", - "supply": "17500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "7500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet6 2500*3 staked + 10000 initial balance", - "address": "erd14gg3v6j4505ucx7t2wtl98tgupmyp748aq92jefmp5ha6e3pccgq9clwe9", - "supply": "17500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "7500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet7 2500*2 staked + 10000 initial balance", - "address": "erd1xdfc44mk4ut5cv6l3mq0py6h88cty9ykacskm8xv3tvrp893kmxqppcefg", - "supply": "15000000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "5000000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet8 2500*2 staked + 10000 initial balance", - "address": "erd1997jfwzrum4rrk59ar5supcyge9rpa73xgv2p45h3unt880v399svt8c9g", - "supply": "15000000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "5000000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet9 2500 staked + 10000 initial balance", - "address": "erd1e9cg9ys8fh77n9eaxpg47sxaes4fe9g2nvy6a65qpxykcx8grg9sv45lss", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet10 2500 staked + 10000 initial balance", - "address": "erd1xdrltsygywhmtxzsmrgjlsxsxrf4y2ayv0z50y666dgsp66trxwqzajk96", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet11 2500 staked + 10000 initial balance", - "address": "erd1lytewufjflpwl6gtf0faazjr59nd2fhfwlk7ew72hkpgdkmunl8qfrpywg", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet12 2500 staked + 10000 initial balance", - "address": "erd1s8tqztm4u4gw23489lps97qxe8vck8eln3a424y9c6yujsc96nas0l968d", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet13 2500 staked + 10000 initial balance", - "address": "erd1p7p0f3n8dxtj08hsp9hccqg932pd4f94rq3adg6g55etx8g4z8tsmg5e0g", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet14 2500 staked + 10000 initial balance", - "address": "erd1uyeel03ea837dphrx2ak77hdvlhjdcqdwgyg6k99gqn602ymsn7qptmedj", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet15 2500 staked + 10000 initial balance", - "address": "erd1ftyzkdhl7rl782mrzrdc2jck3egydp0ydzhcjm9gc8s2jym5egrqadl4h6", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet16 2500*3 staked + 10000 initial balance", - "address": "erd1rsl2sj5g87ltfq0hvrmgm35mlg4lzfs29p4gzxh0lh4vj2e8ykuqh69lha", - "supply": "17500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "7500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet17 2500*2 staked + 10000 initial balance", - "address": "erd19yrjty2l4ytl6d3jynp5mqfekq4uf2x93akz60w7l3cp6qzny3psnfyerw", - "supply": "15000000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "5000000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet18 2500 staked + 10000 initial balance", - "address": "erd148lq42zdzz34y0yr8avldsy7gw0rmuvj4lmstzug77v08z3q0ncszfk8w9", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet19 2500 staked + 10000 initial balance", - "address": "erd1k2v4h3805gnxf78c22g7lfe4pgq2lmr4ezmkk2rqkej6yjd7g5ssu88fme", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet20 2500 staked + 10000 initial balance", - "address": "erd1nzjyj2ykpway04pczl42fgrlza2f0eaf97fxgnuuw39vyee36xlqccc3qz", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet21 2500 staked + 10000 initial balance", - "address": "erd1yp0nvml5c45us3qzreqxkjxaakxn744t3gdva9s8xndcakzawutstepmm5", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet22 2500 staked + 10000 initial balance", - "address": "erd1qyg80tr4rd65ur3hedm9h4yv3fcwmm6vnyrypnm972nd80889hxqdfgwrc", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet23 2500 staked + 10000 initial balance", - "address": "erd14x6d48q59zjh5p909fyw7e46czftgdawyf734cnmgk5e63ghrvvsqp254t", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet24 2500 staked + 10000 initial balance", - "address": "erd1wyxylus33e476h5kta7e0caeqvgvcgrxh0az33e7szya6g7mh2ws0n27sa", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet25 2500 staked + 10000 initial balance", - "address": "erd1v3ylw7t6vzjzs06xjf6ccmf576ud38g2ws45tjkjg48s38jefpzqlwms9w", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet26 2500 staked + 10000 initial balance", - "address": "erd1twel4azu6uptw878y063p93mjr84y5m4kpsww2aeqj4pg5jeplgst04rhg", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet27 2500 staked + 10000 initial balance", - "address": "erd1q2se75ucl9as9j7e48v00jrnj6hvtk5vqxa4a3ag5729vctsdkasm20cyc", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet28 2500 staked + 10000 initial balance", - "address": "erd18cc6cm35xhv7kzwsm79l4ma6jpz3ee5l0yjxuc66kh6rcgtawtuq6lzp9f", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet29 2500 staked + 10000 initial balance", - "address": "erd1psux99h4jljyt3nkw8pruv3spw5r0unqe4wk8837mm9my88gl28qj6mml5", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet30 2500 staked + 10000 initial balance", - "address": "erd1vgm89ngmv2ghzsyq8xjtt45crekkxnhsq30yxzlq86uc3ra3r57qa3mw2p", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet31 2500 staked + 10000 initial balance", - "address": "erd1k767vmmn8vg8xvuny32ppwr4dxrlgmpykn0u7nm92evlag3wkukqdgsf5u", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet32 2500 staked + 10000 initial balance", - "address": "erd1hwe8lskmzsdpuy3f6hldamvn0zrhzldec8m4tt8hupq58d7gyrequy8wsp", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet33 2500 staked + 10000 initial balance", - "address": "erd125eyrjk99zadr04gm9z2p4nckmnegexs5nyk7ek85rut2665t75sql3w88", - "supply": "12500000000000000000000", - "balance": "10000000000000000000000", - "stakingvalue": "2500000000000000000000", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet34 no staking, initial funds - 10 million EGLD", - "address": "erd17ndrqg38lqf2zjgeqvle90rsn9ejrd9upx8evkyvh8e0m5xlph5scv9l6n", - "supply": "10000000000000000000000000", - "balance": "10000000000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "", - "value": "0" - } - }, - { - "info": "wallet35 no staking, initial funds - 9509990 EGLD", - "address": "erd1zed89c8226rs7f59zh2xea39qk9ym9tsmt4s0sg2uw7u9nvtzt3q8fdj2e", - "supply": "9509990000000000000000000", - "balance": "9509990000000000000000000", - "stakingvalue": "0", - "delegation": { - "address": "", - "value": "0" - } - } -] diff --git a/integrationTests/relayers/testdata/config/nodeConfig/genesisContracts/delegation.wasm b/integrationTests/relayers/testdata/config/nodeConfig/genesisContracts/delegation.wasm deleted file mode 100644 index d00f3f7d065089bb08570e007ad77955e2455555..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 57293 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 yt$ij~I(PDq1+^1$>O&A4$~cVUD0t&Wud diff --git a/integrationTests/relayers/testdata/config/nodeConfig/genesisContracts/dns.wasm b/integrationTests/relayers/testdata/config/nodeConfig/genesisContracts/dns.wasm deleted file mode 100644 index ce692a1260bf44b86b79f8ad1095ff015c8e9ae8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9740 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.Enabled to remain true all the time during upgrades, while the default - # configuration of the node has the false value) - # The Path indicates what value to change, while Value represents the new value in string format. The node operator must make sure - # to follow the same type of the original value (ex: uint32: "37", float32: "37.0", bool: "true") - # File represents the file name that holds the configuration. Currently, the supported files are: config.toml, external.toml, p2p.toml and enableEpochs.toml - # ------------------------------- - # Un-comment and update the following section in order to enable config values overloading - # ------------------------------- - # OverridableConfigTomlValues = [ - # { File = "config.toml", Path = "StoragePruning.NumEpochsToKeep", Value = "4" }, - # { File = "config.toml", Path = "MiniBlocksStorage.Cache.Name", Value = "MiniBlocksStorage" }, - # { File = "external.toml", Path = "ElasticSearchConnector.Enabled", Value = "true" } - #] - -# BlockProcessingCutoff can be used to stop processing blocks at a certain round, nonce or epoch. -# This can be useful for snapshotting different stuff and also for debugging purposes. -[BlockProcessingCutoff] - # If set to true, the node will stop at the given coordinate - Enabled = false - - # Mode represents the cutoff mode. possible values: "pause" or "process-error". - # "pause" mode will halt the processing at the block with the given coordinates. Useful for snapshots/analytics - # "process-error" will return an error when processing the block with the given coordinates. Useful for debugging - Mode = "pause" - - # CutoffTrigger represents the kind of coordinate to look after when cutting off the processing. - # Possible values: "round", "nonce", or "epoch" - CutoffTrigger = "round" - - # The minimum value of the cutoff. For example, if CutoffType is set to "round", and Value to 20, then the node will stop processing at round 20+ - Value = 0 - -# NamedIdentity represents an identity that runs nodes on the multikey -# There can be multiple identities set on the same node, each one of them having different bls keys, just by duplicating the NamedIdentity -[[NamedIdentity]] - # Identity represents the GitHub identity for the current NamedIdentity - Identity = "" - # NodeName represents the name that will be given to the names of the current identity - NodeName = "" - # BLSKeys represents the BLS keys assigned to the current NamedIdentity - BLSKeys = [ - "", - "" - ] diff --git a/integrationTests/relayers/testdata/config/nodeConfig/ratings.toml b/integrationTests/relayers/testdata/config/nodeConfig/ratings.toml deleted file mode 100644 index 13edfff9..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/ratings.toml +++ /dev/null @@ -1,53 +0,0 @@ -#Ratings configuration - -# proposer-validator importanceRatio = 1 => -# 50% rating increase from proposer and 50% rating increase from validator - -# ProposerIncreaseRatingStep = 1/2 * (maxRating - startRating)/(nrTimesProposerPerHour * hoursToGetToMaxRating) -# ValidatorIncreaseRatingStep = 1/2 * (maxRating - startRating)/(nrTimeValidatorPerHour * hoursToGetToMaxRating) -# ProposerDecreaseRatingStep = -4 * ProposerIncreaseRatingStep -# ValidatorDecreaseRatingStep = -4 * ValidatorIncreaseRatingStep - - -[General] - StartRating = 5000001 - MaxRating = 10000000 - MinRating = 1 - SignedBlocksThreshold = 0.01 - SelectionChances = [ - { MaxThreshold = 0, ChancePercent = 5}, - { MaxThreshold = 1000000,ChancePercent = 0}, - { MaxThreshold = 2000000,ChancePercent = 16}, - { MaxThreshold = 3000000,ChancePercent = 17}, - { MaxThreshold = 4000000,ChancePercent = 18}, - { MaxThreshold = 5000000,ChancePercent = 19}, - { MaxThreshold = 6000000,ChancePercent = 20}, - { MaxThreshold = 7000000,ChancePercent = 21}, - { MaxThreshold = 8000000,ChancePercent = 22}, - { MaxThreshold = 9000000,ChancePercent = 23}, - { MaxThreshold = 10000000,ChancePercent = 24}, - ] - -[ShardChain.RatingSteps] - HoursToMaxRatingFromStartRating = 72 - ProposerValidatorImportance = 1.0 - ProposerDecreaseFactor = -4.0 - ValidatorDecreaseFactor = -4.0 - ConsecutiveMissedBlocksPenalty = 1.50 - -[MetaChain.RatingSteps] - HoursToMaxRatingFromStartRating = 55 - ProposerValidatorImportance = 1.0 - ProposerDecreaseFactor = -4.0 - ValidatorDecreaseFactor = -4.0 - ConsecutiveMissedBlocksPenalty = 1.50 - -[PeerHonesty] - #this value will be multiplied with the current value for a public key each DecayUpdateIntervalInSeconds seconds - #for the current settings, a pk will reach to value 0 after maximum 2h (if it stopped misbehaving or stopped sending good messages) - DecayCoefficient = 0.9779 - DecayUpdateIntervalInSeconds = 10 - MaxScore = 100.0 - MinScore = -100.0 - BadPeerThreshold = -80.0 - UnitValue = 1.0 diff --git a/integrationTests/relayers/testdata/config/nodeConfig/systemSmartContractsConfig.toml b/integrationTests/relayers/testdata/config/nodeConfig/systemSmartContractsConfig.toml deleted file mode 100644 index fc898335..00000000 --- a/integrationTests/relayers/testdata/config/nodeConfig/systemSmartContractsConfig.toml +++ /dev/null @@ -1,41 +0,0 @@ -[StakingSystemSCConfig] - GenesisNodePrice = "2500000000000000000000" #2.5K eGLD - MinStakeValue = "100000000000000000000" #100 eGLD - MinUnstakeTokensValue = "10000000000000000000" #10eGLD - UnBondPeriod = 250 - UnBondPeriodInEpochs = 1 - MinStepValue = "100000000000000000000" - NumRoundsWithoutBleed = 100 - MaximumPercentageToBleed = 0.5 - BleedPercentagePerRound = 0.00001 - MaxNumberOfNodesForStake = 64 - UnJailValue = "2500000000000000000" #0.1% of genesis node price - ActivateBLSPubKeyMessageVerification = false - -[ESDTSystemSCConfig] - BaseIssuingCost = "5000000000000000000" #5 eGLD - OwnerAddress = "erd1fpkcgel4gcmh8zqqdt043yfcn5tyx8373kg6q2qmkxzu4dqamc0swts65c" - -[GovernanceSystemSCConfig] - OwnerAddress = "erd1vxy22x0fj4zv6hktmydg8vpfh6euv02cz4yg0aaws6rrad5a5awqgqky80" #should use a multisign contract instead of a wallet address - [GovernanceSystemSCConfig.V1] - NumNodes = 500 - ProposalCost = "5000000000000000000" #5 eGLD - MinQuorum = 400 - MinPassThreshold = 300 - MinVetoThreshold = 50 - [GovernanceSystemSCConfig.Active] - ProposalCost = "1000000000000000000000" #1000 eGLD - LostProposalFee = "10000000000000000000" #10 eGLD - MinQuorum = 0.2 #fraction of value 0.2 - 20% - MinPassThreshold = 0.5 #fraction of value 0.5 - 50% - MinVetoThreshold = 0.33 #fraction of value 0.33 - 33% - -[DelegationManagerSystemSCConfig] - MinCreationDeposit = "1250000000000000000000" #1.25K eGLD - MinStakeAmount = "10000000000000000000" #10 eGLD - ConfigChangeAddress = "erd1vxy22x0fj4zv6hktmydg8vpfh6euv02cz4yg0aaws6rrad5a5awqgqky80" #should use a multisign contract instead of a wallet address - -[DelegationSystemSCConfig] - MinServiceFee = 0 - MaxServiceFee = 10000 diff --git a/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/credentials.toml b/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/credentials.toml deleted file mode 100644 index 72ea04bf..00000000 --- a/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/credentials.toml +++ /dev/null @@ -1,11 +0,0 @@ -# Credentials holds the list of username-pair pairs that allow access to certain endpoints. -# The password represents the hashed value. In this examples, the password are the hashed usernames. -# Please change these example values as they are just placeholders. -# Example credentials: -# Credentials = [ -# { Username = "example", Password = "hashed password" }, -# { Username = "example2", Password = "hashed password" } -# ] - -[Hasher] -Type = "sha256" diff --git a/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v1_0.toml b/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v1_0.toml deleted file mode 100644 index b8cea0ed..00000000 --- a/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v1_0.toml +++ /dev/null @@ -1,146 +0,0 @@ -# API routes configuration for version v1.0 -[APIPackages] - -# Each endpoint has configurable fields. These are: -# Name: the full path of the endpoint in a gin server based format -# Open: if set to false, the endpoint will not be enabled -# Secured: if set to true, then requests to this route have to be made using Basic Authentication using credentials -# from credentials.toml file -# RateLimit: if set to 0, then the endpoint won't be limited. Otherwise, a given IP address can only make a number of -# requests in a given time stamp, configurable in config.toml - -[APIPackages.about] -Routes = [ - { Name = "", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/nodes-versions", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.actions] -Routes = [ - { Name = "/reload-observers", Open = true, Secured = true, RateLimit = 0 }, - { Name = "/reload-full-history-observers", Open = true, Secured = true, RateLimit = 0 } -] - -[APIPackages.node] -Routes = [ - { Name = "/heartbeatstatus", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/old-storage-token/:token/nonce/:nonce", Open = true, Secured = false, RateLimit = 0} -] - -[APIPackages.address] -Routes = [ - { Name = "/:address", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/balance", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/nonce", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/username", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/code-hash", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/keys", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/key/:key", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdt", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdts/roles", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdt/:tokenIdentifier", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdts-with-role/:role", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/registered-nfts", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/nft/:tokenIdentifier/nonce/:nonce", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/shard", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/transactions", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/guardian-data", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/is-data-trie-migrated", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.hyperblock] -Routes = [ - { Name = "/by-hash/:hash", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/by-nonce/:nonce", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.network] -Routes = [ - { Name = "/status/:shard", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/economics", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/config", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdts", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/fungible-tokens", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/semi-fungible-tokens", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/non-fungible-tokens", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/supply/:token", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/direct-staked-info", Open = true, Secured = true, RateLimit = 0 }, - { Name = "/delegated-info", Open = true, Secured = true, RateLimit = 0 }, - { Name = "/enable-epochs", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/ratings", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/genesis-nodes", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/gas-configs", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/trie-statistics/:shard", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/epoch-start/:shard/by-epoch/:epoch", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.validator] -Routes = [ - { Name = "/statistics", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.vm-values] -Routes = [ - { Name = "/hex", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/string", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/int", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/query", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.transaction] -Routes = [ - { Name = "/send", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/simulate", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/send-multiple", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/send-user-funds", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/cost", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:txhash", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:txhash/status", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:txhash/process-status", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/pool", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.block] -Routes = [ - { Name = "/:shard/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/altered-accounts/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/altered-accounts/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 } -] - -[APIPackages.blocks] -Routes = [ - { Name = "/by-round/:round", Secured = false, Open = true, RateLimit = 0 }, -] - -[APIPackages.block-atlas] -Routes = [ - { Name = "/:shard/:nonce", Secured = false, Open = true, RateLimit = 0 } -] - -[APIPackages.proof] -Routes = [ - { Name = "/root-hash/:roothash/address/:address", Secured = false, Open = false, RateLimit = 0 }, - { Name = "/root-hash/:roothash/address/:address/key/:key", Secured = false, Open = false, RateLimit = 0 }, - { Name = "/address/:address", Secured = false, Open = false, RateLimit = 0 }, - { Name = "/verify", Secured = false, Open = false, RateLimit = 0 } -] - -[APIPackages.internal] -Routes = [ - { Name = "/:shard/raw/block/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/raw/block/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/json/block/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/json/block/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/raw/miniblock/by-hash/:hash/epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/json/miniblock/by-hash/:hash/epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/raw/startofepoch/metablock/by-epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/json/startofepoch/metablock/by-epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/json/startofepoch/validators/by-epoch/:epoch", Secured = false, Open = true, RateLimit = 0 } -] - -[APIPackages.status] -Routes = [ - { Name = "/metrics", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/prometheus-metrics", Secured = false, Open = true, RateLimit = 0 } -] diff --git a/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v_next.toml b/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v_next.toml deleted file mode 100644 index c1e6a0e6..00000000 --- a/integrationTests/relayers/testdata/config/proxyConfig/apiConfig/v_next.toml +++ /dev/null @@ -1,146 +0,0 @@ -# API routes configuration for version v.next -[APIPackages] - -# Each endpoint has configurable fields. These are: -# Name: the full path of the endpoint in a gin server based format -# Open: if set to false, the endpoint will not be enabled -# Secured: if set to true, then requests to this route have to be made using Basic Authentication using credentials -# from credentials.toml file -# RateLimit: if set to 0, then the endpoint won't be limited. Otherwise, a given IP address can only make a number of -# requests in a given time stamp, configurable in config.toml - -[APIPackages.about] -Routes = [ - { Name = "", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/nodes-versions", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.actions] -Routes = [ - { Name = "/reload-observers", Open = true, Secured = true, RateLimit = 0 }, - { Name = "/reload-full-history-observers", Open = true, Secured = true, RateLimit = 0 } -] - -[APIPackages.node] -Routes = [ - { Name = "/heartbeatstatus", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/old-storage-token/:token/nonce/:nonce", Open = true, Secured = false, RateLimit = 0} -] - -[APIPackages.address] -Routes = [ - { Name = "/:address", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/balance", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/nonce", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/username", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/code-hash", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/keys", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/key/:key", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdt", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdts/roles", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdt/:tokenIdentifier", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/esdts-with-role/:role", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/registered-nfts", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/nft/:tokenIdentifier/nonce/:nonce", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/shard", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/transactions", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/guardian-data", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:address/is-data-trie-migrated", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.hyperblock] -Routes = [ - { Name = "/by-hash/:hash", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/by-nonce/:nonce", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.network] -Routes = [ - { Name = "/status/:shard", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/economics", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/config", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdts", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/fungible-tokens", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/semi-fungible-tokens", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/non-fungible-tokens", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/esdt/supply/:token", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/direct-staked-info", Open = true, Secured = true, RateLimit = 0 }, - { Name = "/delegated-info", Open = true, Secured = true, RateLimit = 0 }, - { Name = "/enable-epochs", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/ratings", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/genesis-nodes", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/gas-configs", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/trie-statistics/:shard", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/epoch-start/:shard/by-epoch/:epoch", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.validator] -Routes = [ - { Name = "/statistics", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.vm-values] -Routes = [ - { Name = "/hex", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/string", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/int", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/query", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.transaction] -Routes = [ - { Name = "/send", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/simulate", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/send-multiple", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/send-user-funds", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/cost", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:txhash", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:txhash/status", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/:txhash/process-status", Open = true, Secured = false, RateLimit = 0 }, - { Name = "/pool", Open = true, Secured = false, RateLimit = 0 } -] - -[APIPackages.block] -Routes = [ - { Name = "/:shard/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/altered-accounts/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/altered-accounts/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 } -] - -[APIPackages.blocks] -Routes = [ - { Name = "/by-round/:round", Secured = false, Open = true, RateLimit = 0 }, -] - -[APIPackages.block-atlas] -Routes = [ - { Name = "/:shard/:nonce", Secured = false, Open = true, RateLimit = 0 } -] - -[APIPackages.proof] -Routes = [ - { Name = "/root-hash/:roothash/address/:address", Secured = false, Open = false, RateLimit = 0 }, - { Name = "/root-hash/:roothash/address/:address/key/:key", Secured = false, Open = false, RateLimit = 0 }, - { Name = "/address/:address", Secured = false, Open = false, RateLimit = 0 }, - { Name = "/verify", Secured = false, Open = false, RateLimit = 0 } -] - -[APIPackages.internal] -Routes = [ - { Name = "/:shard/raw/block/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/raw/block/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/json/block/by-nonce/:nonce", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/json/block/by-hash/:hash", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/raw/miniblock/by-hash/:hash/epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/:shard/json/miniblock/by-hash/:hash/epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/raw/startofepoch/metablock/by-epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/json/startofepoch/metablock/by-epoch/:epoch", Secured = false, Open = true, RateLimit = 0 }, - { Name = "/json/startofepoch/validators/by-epoch/:epoch", Secured = false, Open = true, RateLimit = 0 } -] - -[APIPackages.status] -Routes = [ - { Name = "/metrics", Secured = false, Open = false, RateLimit = 0 }, - { Name = "/prometheus-metrics", Secured = false, Open = false, RateLimit = 0 } -] diff --git a/integrationTests/relayers/testdata/config/proxyConfig/config.toml b/integrationTests/relayers/testdata/config/proxyConfig/config.toml deleted file mode 100644 index da7b6c19..00000000 --- a/integrationTests/relayers/testdata/config/proxyConfig/config.toml +++ /dev/null @@ -1,79 +0,0 @@ -# GeneralSettings section of the proxy server -[GeneralSettings] - # ServerPort is the port used for the web server. The frontend will connect to this port - ServerPort = 8080 - - # RequestTimeoutSec represents the maximum number of seconds a request can last until throwing an error - RequestTimeoutSec = 80 - - # HeartbeatCacheValidityDurationSec represents the maximum number of seconds the heartbeat cache data is valid before it - # should be updated - HeartbeatCacheValidityDurationSec = 25 - - # ValStatsCacheValidityDurationSec represents the maximum number of seconds the validator statistics cache data is valid - # before it should be updated - ValStatsCacheValidityDurationSec = 60 - - # EconomicsMetricsCacheValidityDurationSec represents the maximum number of seconds the economics metrics cache data is valid - # before it should be updated - EconomicsMetricsCacheValidityDurationSec = 600 # 10 minutes - - # BalancedObservers - if this flag is set to true, then the requests will be distributed equally between observers. - # Otherwise, there are chances that only one observer from a shard will process the requests - BalancedObservers = true - - # BalancedFullHistoryNodes - if this flag is set to true, then the requests will be distributed equally between full history nodes. - # Otherwise, there are chances that only one full history node from a shard will process the requests - BalancedFullHistoryNodes = true - - # FaucetValue represents the default value for a faucet transaction. If set to "0", the faucet feature will be disabled - FaucetValue = "0" - - # RateLimitWindowsDurationSeconds represents the time window for limiting the number of requests to a given API endpoint - # For example, if RateLimitDurationSeconds = 60 and the endpoint /address/:address/nonce is rate-limited to 5, - # then after 5 requests in a 60 seconds window, a 'Too many requests' response will be returned. There is a clean-up - # mechanism so after RateLimitDurationSeconds seconds, the restrictions will be reset. - RateLimitWindowDurationSeconds = 60 - - # AllowEntireTxPoolFetch represents the flag that enables the transactions pool API - # With this flag disabled, /transaction/pool route will return an error - AllowEntireTxPoolFetch = false - -[AddressPubkeyConverter] - #Length specifies the length in bytes of an address - Length = 32 - - # Type specifies the type of public keys: hex or bech32 - Type = "bech32" - -[Marshalizer] - Type = "gogo protobuf" - -[Hasher] - Type = "blake2b" - -# ApiLogging holds settings related to api requests logging -[ApiLogging] - # LoggingEnabled - if this flag is set to true, then if a requests exceeds a threshold or it is unsuccessful, then - # a log will be printed - LoggingEnabled = true - - # ThresholdInMicroSeconds represents the maximum duration to consider a request as normal. Above this, if the LoggingEnabled - # flag is set to true, then a log will be printed - ThresholdInMicroSeconds = 50000 # 50ms - -# List of Observers. If you want to define a metachain observer (needed for validator statistics route) use -# shard id 4294967295 -# Fallback observers which are only used when regular ones are offline should have IsFallback = true -[[Observers]] - ShardId = 0 - Address = "http://127.0.0.1:8081" - -[[Observers]] - ShardId = 1 - Address = "http://127.0.0.1:8082" - -[[Observers]] - ShardId = 4294967295 - Address = "http://127.0.0.1:8083" - IsFallback = false diff --git a/integrationTests/relayers/testdata/config/proxyConfig/external.toml b/integrationTests/relayers/testdata/config/proxyConfig/external.toml deleted file mode 100644 index 9bc54b1a..00000000 --- a/integrationTests/relayers/testdata/config/proxyConfig/external.toml +++ /dev/null @@ -1,4 +0,0 @@ -# ElasticSearchConnector defines settings related to ElasticSearch such as login information or URL -[ElasticSearchConnector] - Enabled = false - URL = "" diff --git a/integrationTests/relayers/testdata/wallets/mvxReceiver.pem b/integrationTests/relayers/testdata/wallets/mvxReceiver.pem deleted file mode 100644 index db1233b0..00000000 --- a/integrationTests/relayers/testdata/wallets/mvxReceiver.pem +++ /dev/null @@ -1,6 +0,0 @@ ------BEGIN PRIVATE KEY for erd1mzuyleayzt9shdfurlrcsypv7hctc6n66cjq0vx088a2mv3pj8sqdt0sdz----- -NjE5MTk1ZWRiNDU0YWE5ZDhhNzcxNTBiZWExM2NlY2UxNWJiZjNmMWI2OTAwOGM2 -NWI5ZmU1YTBiYWI1YjJiNGQ4Yjg0ZmU3YTQxMmNiMGJiNTNjMWZjNzg4MTAyY2Y1 -ZjBiYzZhN2FkNjI0MDdiMGNmMzlmYWFkYjIyMTkxZTA= ------END PRIVATE KEY for erd1mzuyleayzt9shdfurlrcsypv7hctc6n66cjq0vx088a2mv3pj8sqdt0sdz----- -; \ No newline at end of file diff --git a/integrationTests/relayers/testdata/wallets/owner.pem b/integrationTests/relayers/testdata/wallets/owner.pem deleted file mode 100644 index 17dc27e3..00000000 --- a/integrationTests/relayers/testdata/wallets/owner.pem +++ /dev/null @@ -1,5 +0,0 @@ ------BEGIN PRIVATE KEY for erd17g9splt634xppt782cktfyyfmhdqlya9vqlqjeclpk65ckuxkcwqxu78wy----- -NzhkOGI1ZDYxOWVkNzkyY2U5ZWE1YTk5YjZkYjA4NzgwMDA1MzE3OTRlYmVhNzFk -NWRhYWUwODdlNDE4MGZmZGYyMGIwMGZkN2E4ZDRjMTBhZmM3NTYyY2I0OTA4OWRk -ZGEwZjkzYTU2MDNlMDk2NzFmMGRiNTRjNWI4NmI2MWM= ------END PRIVATE KEY for erd17g9splt634xppt782cktfyyfmhdqlya9vqlqjeclpk65ckuxkcwqxu78wy----- From 8e4881fbbe4729af38d1fd481d3c5f981976b049 Mon Sep 17 00:00:00 2001 From: Iulian Pascalau Date: Wed, 5 Jun 2024 10:42:27 +0300 Subject: [PATCH 3/5] - renamed workflow --- .github/workflows/slow-tests.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/slow-tests.yml b/.github/workflows/slow-tests.yml index c21ad938..90abc341 100644 --- a/.github/workflows/slow-tests.yml +++ b/.github/workflows/slow-tests.yml @@ -8,7 +8,7 @@ on: jobs: test: - name: Unit + name: Slow runs-on: ubuntu-latest steps: - name: Set up Go 1.x From 41575c7fe78767e29c7a3613ae490242e662ec04 Mon Sep 17 00:00:00 2001 From: Iulian Pascalau Date: Wed, 5 Jun 2024 10:43:09 +0300 Subject: [PATCH 4/5] - renamed the initial workflow --- .github/workflows/pr-tests.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pr-tests.yml b/.github/workflows/pr-tests.yml index fcebecb8..fd7a003a 100644 --- a/.github/workflows/pr-tests.yml +++ b/.github/workflows/pr-tests.yml @@ -8,7 +8,7 @@ on: jobs: test: - name: Unit + name: Unit & Integration runs-on: ubuntu-latest steps: - name: Set up Go 1.x From 2c680026ecc8d4dd47136958f363171844a1360b Mon Sep 17 00:00:00 2001 From: Iulian Pascalau Date: Wed, 5 Jun 2024 10:48:49 +0300 Subject: [PATCH 5/5] - added empty line --- docker/docker-compose.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml index 0f03f76b..ae7a2c78 100644 --- a/docker/docker-compose.yml +++ b/docker/docker-compose.yml @@ -8,4 +8,4 @@ services: - 8085:8085 volumes: - "../scripts:/docker/scripts" - entrypoint: "./chainsimulator" \ No newline at end of file + entrypoint: "./chainsimulator"