mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-09 20:06:52 +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)
85 lines
2.2 KiB
Nim
85 lines
2.2 KiB
Nim
import
|
|
std/[json],
|
|
eth/p2p as eth_p2p,
|
|
eth/trie/trie_defs,
|
|
stew/[byteutils],
|
|
json_rpc/[rpcserver, rpcclient],
|
|
../../../nimbus/[
|
|
config,
|
|
constants,
|
|
transaction,
|
|
db/accounts_cache,
|
|
core/sealer,
|
|
core/chain,
|
|
core/tx_pool,
|
|
rpc,
|
|
sync/protocol,
|
|
rpc/merge/merger,
|
|
common
|
|
],
|
|
../../../tests/test_helpers,
|
|
../../../tools/evmstate/helpers
|
|
|
|
type
|
|
TestEnv* = ref object
|
|
conf*: NimbusConf
|
|
ctx: EthContext
|
|
ethNode: EthereumNode
|
|
com: CommonRef
|
|
chainRef: ChainRef
|
|
rpcServer: RpcHttpServer
|
|
sealingEngine: SealingEngineRef
|
|
rpcClient*: RpcHttpClient
|
|
|
|
const
|
|
engineSigner = hexToByteArray[20]("0x658bdf435d810c91414ec09147daa6db62406379")
|
|
|
|
proc genesisHeader(node: JsonNode): BlockHeader =
|
|
let genesisRLP = hexToSeqByte(node["genesisRLP"].getStr)
|
|
rlp.decode(genesisRLP, EthBlock).header
|
|
|
|
proc setupELClient*(t: TestEnv, conf: ChainConfig, node: JsonNode) =
|
|
let memDB = newCoreDbRef LegacyDbMemory
|
|
t.ctx = newEthContext()
|
|
t.ethNode = setupEthNode(t.conf, t.ctx, eth)
|
|
t.com = CommonRef.new(
|
|
memDB,
|
|
conf,
|
|
t.conf.pruneMode == PruneMode.Full
|
|
)
|
|
t.chainRef = newChain(t.com)
|
|
let
|
|
stateDB = AccountsCache.init(memDB, emptyRlpHash, t.conf.pruneMode == PruneMode.Full)
|
|
genesisHeader = node.genesisHeader
|
|
|
|
setupStateDB(node["pre"], stateDB)
|
|
stateDB.persist()
|
|
|
|
doAssert stateDB.rootHash == genesisHeader.stateRoot
|
|
|
|
discard t.com.db.persistHeaderToDb(genesisHeader,
|
|
t.com.consensus == ConsensusType.POS)
|
|
doAssert(t.com.db.getCanonicalHead().blockHash == genesisHeader.blockHash)
|
|
|
|
let txPool = TxPoolRef.new(t.com, engineSigner)
|
|
t.rpcServer = newRpcHttpServer(["127.0.0.1:8545"])
|
|
t.sealingEngine = SealingEngineRef.new(
|
|
t.chainRef, t.ctx, engineSigner,
|
|
txPool, EngineStopped
|
|
)
|
|
|
|
let merger = MergerRef.new(t.com.db)
|
|
setupEthRpc(t.ethNode, t.ctx, t.com, txPool, t.rpcServer)
|
|
setupEngineAPI(t.sealingEngine, t.rpcServer, merger)
|
|
#setupDebugRpc(t.com, t.rpcServer)
|
|
|
|
t.rpcServer.start()
|
|
|
|
t.rpcClient = newRpcHttpClient()
|
|
waitFor t.rpcClient.connect("127.0.0.1", 8545.Port, false)
|
|
|
|
proc stopELClient*(t: TestEnv) =
|
|
waitFor t.rpcClient.close()
|
|
waitFor t.sealingEngine.stop()
|
|
waitFor t.rpcServer.closeWait()
|