mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-12 21:34:33 +00:00
221e6c9e2f
* Nimbus folder environment update details: * Integrated `CoreDbRef` for the sources in the `nimbus` sub-folder. * The `nimbus` program does not compile yet as it needs the updates in the parallel `stateless` sub-folder. * Stateless environment update details: * Integrated `CoreDbRef` for the sources in the `stateless` sub-folder. * The `nimbus` program compiles now. * Premix environment update details: * Integrated `CoreDbRef` for the sources in the `premix` sub-folder. * Fluffy environment update details: * Integrated `CoreDbRef` for the sources in the `fluffy` sub-folder. * Tools environment update details: * Integrated `CoreDbRef` for the sources in the `tools` sub-folder. * Nodocker environment update details: * Integrated `CoreDbRef` for the sources in the `hive_integration/nodocker` sub-folder. * Tests environment update details: * Integrated `CoreDbRef` for the sources in the `tests` sub-folder. * The unit tests compile and run cleanly now. * Generalise `CoreDbRef` to any `select_backend` supported database why: Generalisation was just missed due to overcoming some compiler oddity which was tied to rocksdb for testing. * Suppress compiler warning for `newChainDB()` why: Warning was added to this function which must be wrapped so that any `CatchableError` is re-raised as `Defect`. * Split off persistent `CoreDbRef` constructor into separate file why: This allows to compile a memory only database version without linking the backend library. * Use memory `CoreDbRef` database by default detail: Persistent DB constructor needs to import `db/core_db/persistent why: Most tests use memory DB anyway. This avoids linking `-lrocksdb` or any other backend by default. * fix `toLegacyBackend()` availability check why: got garbled after memory/persistent split. * Clarify raw access to MPT for snap sync handler why: Logically, `kvt` is not the raw access for the hexary trie (although this holds for the legacy database)
107 lines
4.5 KiB
Nim
107 lines
4.5 KiB
Nim
import
|
|
std/[os],
|
|
unittest2,
|
|
../nimbus/config,
|
|
../nimbus/common/common
|
|
|
|
const
|
|
baseDir = [".", "tests", ".."/"tests", $DirSep] # path containg repo
|
|
repoDir = [".", "customgenesis"] # alternative repo paths
|
|
|
|
proc findFilePath(file: string): string =
|
|
result = "?unknown?" / file
|
|
for dir in baseDir:
|
|
for repo in repoDir:
|
|
let path = dir / repo / file
|
|
if path.fileExists:
|
|
return path
|
|
|
|
proc makeGenesis(networkId: NetworkId): BlockHeader =
|
|
let com = CommonRef.new(newCoreDbRef LegacyDbMemory, params = networkParams(networkId))
|
|
com.genesisHeader
|
|
|
|
proc genesisTest() =
|
|
suite "Genesis":
|
|
test "Correct mainnet hash":
|
|
let b = makeGenesis(MainNet)
|
|
check(b.blockHash == "D4E56740F876AEF8C010B86A40D5F56745A118D0906A34E69AEC8C0DB1CB8FA3".toDigest)
|
|
|
|
test "Correct ropstennet hash":
|
|
let b = makeGenesis(RopstenNet)
|
|
check(b.blockHash == "41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d".toDigest)
|
|
|
|
test "Correct rinkebynet hash":
|
|
let b = makeGenesis(RinkebyNet)
|
|
check(b.blockHash == "6341fd3daf94b748c72ced5a5b26028f2474f5f00d824504e4fa37a75767e177".toDigest)
|
|
|
|
test "Correct goerlinet hash":
|
|
let b = makeGenesis(GoerliNet)
|
|
check(b.blockHash == "bf7e331f7f7c1dd2e05159666b3bf8bc7a8a3a9eb1d518969eab529dd9b88c1a".toDigest)
|
|
|
|
test "Correct sepolia hash":
|
|
let b = makeGenesis(SepoliaNet)
|
|
check b.blockHash == "25a5cc106eea7138acab33231d7160d69cb777ee0c2c553fcddf5138993e6dd9".toDigest
|
|
|
|
proc customGenesisTest() =
|
|
suite "Custom Genesis":
|
|
test "loadCustomGenesis":
|
|
var cga, cgb, cgc: NetworkParams
|
|
check loadNetworkParams("berlin2000.json".findFilePath, cga)
|
|
check loadNetworkParams("chainid7.json".findFilePath, cgb)
|
|
check loadNetworkParams("noconfig.json".findFilePath, cgc)
|
|
check cga.config.consensusType == ConsensusType.POW
|
|
check cgb.config.consensusType == ConsensusType.POW
|
|
check cgc.config.consensusType == ConsensusType.POW
|
|
|
|
test "calaveras.json":
|
|
var cg: NetworkParams
|
|
check loadNetworkParams("calaveras.json".findFilePath, cg)
|
|
let com = CommonRef.new(newCoreDbRef LegacyDbMemory, params = cg)
|
|
let stateRoot = "664c93de37eb4a72953ea42b8c046cdb64c9f0b0bca5505ade8d970d49ebdb8c".toDigest
|
|
let genesisHash = "eb9233d066c275efcdfed8037f4fc082770176aefdbcb7691c71da412a5670f2".toDigest
|
|
check com.genesisHeader.stateRoot == stateRoot
|
|
check com.genesisHeader.blockHash == genesisHash
|
|
check com.consensus == ConsensusType.POA
|
|
check com.cliquePeriod == 30
|
|
check com.cliqueEpoch == 30000
|
|
|
|
test "Devnet4.json (aka Kintsugi in all but chainId)":
|
|
var cg: NetworkParams
|
|
check loadNetworkParams("devnet4.json".findFilePath, cg)
|
|
let com = CommonRef.new(newCoreDbRef LegacyDbMemory, params = cg)
|
|
let stateRoot = "3b84f313bfd49c03cc94729ade2e0de220688f813c0c895a99bd46ecc9f45e1e".toDigest
|
|
let genesisHash = "a28d8d73e087a01d09d8cb806f60863652f30b6b6dfa4e0157501ff07d422399".toDigest
|
|
check com.genesisHeader.stateRoot == stateRoot
|
|
check com.genesisHeader.blockHash == genesisHash
|
|
check com.consensus == ConsensusType.POW
|
|
|
|
test "Devnet5.json (aka Kiln in all but chainId and TTD)":
|
|
var cg: NetworkParams
|
|
check loadNetworkParams("devnet5.json".findFilePath, cg)
|
|
let com = CommonRef.new(newCoreDbRef LegacyDbMemory, params = cg)
|
|
let stateRoot = "52e628c7f35996ba5a0402d02b34535993c89ff7fc4c430b2763ada8554bee62".toDigest
|
|
let genesisHash = "51c7fe41be669f69c45c33a56982cbde405313342d9e2b00d7c91a7b284dd4f8".toDigest
|
|
check com.genesisHeader.stateRoot == stateRoot
|
|
check com.genesisHeader.blockHash == genesisHash
|
|
check com.consensus == ConsensusType.POW
|
|
|
|
test "Mainnet shadow fork 1":
|
|
var cg: NetworkParams
|
|
check loadNetworkParams("mainshadow1.json".findFilePath, cg)
|
|
let com = CommonRef.new(newCoreDbRef LegacyDbMemory, params = cg)
|
|
let stateRoot = "d7f8974fb5ac78d9ac099b9ad5018bedc2ce0a72dad1827a1709da30580f0544".toDigest
|
|
let genesisHash = "d4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3".toDigest
|
|
let ttd = "46_089_003_871_917_200_000_000".parse(Uint256)
|
|
check com.genesisHeader.stateRoot == stateRoot
|
|
check com.genesisHeader.blockHash == genesisHash
|
|
check com.ttd.get == ttd
|
|
check com.consensus == ConsensusType.POW
|
|
|
|
proc genesisMain*() =
|
|
genesisTest()
|
|
customGenesisTest()
|
|
|
|
when isMainModule:
|
|
genesisTest()
|
|
customGenesisTest()
|