mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-12 15:24:14 +00:00
commit
e2885d3445
23
Jenkinsfile
vendored
23
Jenkinsfile
vendored
@ -11,9 +11,12 @@ def runStages() {
|
|||||||
[$class: "ArbitraryFileCache", excludes: "", includes: "**/*", path: "${WORKSPACE}/jsonTestsCache"]
|
[$class: "ArbitraryFileCache", excludes: "", includes: "**/*", path: "${WORKSPACE}/jsonTestsCache"]
|
||||||
]) {
|
]) {
|
||||||
stage("Build") {
|
stage("Build") {
|
||||||
sh "make -j${env.NPROC} update" /* to allow a newer Nim version to be detected */
|
sh """#!/bin/bash
|
||||||
sh "make -j${env.NPROC} deps" /* to allow the following parallel stages */
|
set -e
|
||||||
sh "V=1 ./scripts/setup_official_tests.sh jsonTestsCache"
|
make -j${env.NPROC} update # to allow a newer Nim version to be detected
|
||||||
|
make -j${env.NPROC} deps # to allow the following parallel stages
|
||||||
|
V=1 ./scripts/setup_official_tests.sh jsonTestsCache
|
||||||
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -21,8 +24,11 @@ def runStages() {
|
|||||||
parallel(
|
parallel(
|
||||||
"tools": {
|
"tools": {
|
||||||
stage("Tools") {
|
stage("Tools") {
|
||||||
sh "make -j${env.NPROC}"
|
sh """#!/bin/bash
|
||||||
sh "make -j${env.NPROC} LOG_LEVEL=TRACE NIMFLAGS='-d:testnet_servers_image'"
|
set -e
|
||||||
|
make -j${env.NPROC}
|
||||||
|
make -j${env.NPROC} LOG_LEVEL=TRACE NIMFLAGS='-d:testnet_servers_image'
|
||||||
|
"""
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"test suite": {
|
"test suite": {
|
||||||
@ -32,8 +38,11 @@ def runStages() {
|
|||||||
if ("${NODE_NAME}" ==~ /linux.*/) {
|
if ("${NODE_NAME}" ==~ /linux.*/) {
|
||||||
stage("testnet finalization") {
|
stage("testnet finalization") {
|
||||||
// EXECUTOR_NUMBER will be 0 or 1, since we have 2 executors per Jenkins node
|
// EXECUTOR_NUMBER will be 0 or 1, since we have 2 executors per Jenkins node
|
||||||
sh "timeout -k 20s 10m ./scripts/launch_local_testnet.sh --testnet 0 --nodes 4 --log-level INFO --disable-htop --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization --stop-at-epoch=5"
|
sh """#!/bin/bash
|
||||||
sh "timeout -k 20s 40m ./scripts/launch_local_testnet.sh --testnet 1 --nodes 4 --log-level INFO --disable-htop --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization --stop-at-epoch=5"
|
set -e
|
||||||
|
timeout -k 20s 10m ./scripts/launch_local_testnet.sh --testnet 0 --nodes 4 --log-level INFO --disable-htop --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization --stop-at-epoch=5
|
||||||
|
timeout -k 20s 40m ./scripts/launch_local_testnet.sh --testnet 1 --nodes 4 --log-level INFO --disable-htop --base-port \$(( 9000 + EXECUTOR_NUMBER * 100 )) --base-metrics-port \$(( 8008 + EXECUTOR_NUMBER * 100 )) -- --verify-finalization --stop-at-epoch=5
|
||||||
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,8 +4,9 @@ import
|
|||||||
options as stdOptions, net as stdNet,
|
options as stdOptions, net as stdNet,
|
||||||
|
|
||||||
# Status libs
|
# Status libs
|
||||||
stew/[varints, base58, bitseqs, results], stew/shims/[macros, tables],
|
stew/[varints, base58, bitseqs, endians2, results],
|
||||||
stint, faststreams/[inputs, outputs, buffers], snappy, snappy/framing,
|
stew/shims/[macros, tables],
|
||||||
|
faststreams/[inputs, outputs, buffers], snappy, snappy/framing,
|
||||||
json_serialization, json_serialization/std/[net, options],
|
json_serialization, json_serialization/std/[net, options],
|
||||||
chronos, chronicles, metrics,
|
chronos, chronicles, metrics,
|
||||||
# TODO: create simpler to use libp2p modules that use re-exports
|
# TODO: create simpler to use libp2p modules that use re-exports
|
||||||
@ -719,11 +720,14 @@ proc start*(node: Eth2Node) {.async.} =
|
|||||||
traceAsyncErrors node.discoveryLoop
|
traceAsyncErrors node.discoveryLoop
|
||||||
|
|
||||||
proc stop*(node: Eth2Node) {.async.} =
|
proc stop*(node: Eth2Node) {.async.} =
|
||||||
# ignore errors in futures, since we're shutting down
|
# Ignore errors in futures, since we're shutting down.
|
||||||
await allFutures(@[
|
# Use a timer to avoid hangups.
|
||||||
node.discovery.closeWait(),
|
discard await one(sleepAsync(5.seconds),
|
||||||
node.switch.stop(),
|
allFutures(@[
|
||||||
])
|
node.discovery.closeWait(),
|
||||||
|
node.switch.stop(),
|
||||||
|
])
|
||||||
|
)
|
||||||
|
|
||||||
proc init*(T: type Peer, network: Eth2Node, info: PeerInfo): Peer =
|
proc init*(T: type Peer, network: Eth2Node, info: PeerInfo): Peer =
|
||||||
new result
|
new result
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
import
|
import
|
||||||
options, algorithm, options, strformat, typetraits,
|
options, algorithm, options, strformat, typetraits,
|
||||||
stint, stew/[bitops2, bitseqs, objects, varints, ptrops],
|
stew/[bitops2, bitseqs, endians2, objects, varints, ptrops],
|
||||||
stew/ranges/[ptr_arith, stackarrays], stew/shims/macros,
|
stew/ranges/[ptr_arith, stackarrays], stew/shims/macros,
|
||||||
faststreams/[inputs, outputs, buffers],
|
faststreams/[inputs, outputs, buffers],
|
||||||
serialization, serialization/testing/tracing,
|
serialization, serialization/testing/tracing,
|
||||||
@ -44,7 +44,7 @@ type
|
|||||||
SszWriter* = object
|
SszWriter* = object
|
||||||
stream: OutputStream
|
stream: OutputStream
|
||||||
|
|
||||||
BasicType = byte|char|bool|SomeUnsignedInt|StUint
|
BasicType = byte|char|bool|SomeUnsignedInt
|
||||||
|
|
||||||
SszChunksMerkleizer = object
|
SszChunksMerkleizer = object
|
||||||
combinedChunks: StackArray[Eth2Digest]
|
combinedChunks: StackArray[Eth2Digest]
|
||||||
@ -105,7 +105,7 @@ proc writeFixedSized(s: var (OutputStream|WriteCursor), x: auto) {.raises: [Defe
|
|||||||
s.write x
|
s.write x
|
||||||
elif x is bool|char:
|
elif x is bool|char:
|
||||||
s.write byte(ord(x))
|
s.write byte(ord(x))
|
||||||
elif x is SomeUnsignedInt|StUint:
|
elif x is SomeUnsignedInt:
|
||||||
when cpuEndian == bigEndian:
|
when cpuEndian == bigEndian:
|
||||||
s.write toBytesLE(x)
|
s.write toBytesLE(x)
|
||||||
else:
|
else:
|
||||||
@ -418,7 +418,7 @@ template merkleizeFields(totalElements: int, body: untyped): Eth2Digest =
|
|||||||
getFinalHash(merkleizer)
|
getFinalHash(merkleizer)
|
||||||
|
|
||||||
template writeBytesLE(chunk: var array[bytesPerChunk, byte], atParam: int,
|
template writeBytesLE(chunk: var array[bytesPerChunk, byte], atParam: int,
|
||||||
val: SomeUnsignedInt|StUint) =
|
val: SomeUnsignedInt) =
|
||||||
let at = atParam
|
let at = atParam
|
||||||
chunk[at ..< at + sizeof(val)] = toBytesLE(val)
|
chunk[at ..< at + sizeof(val)] = toBytesLE(val)
|
||||||
|
|
||||||
@ -448,7 +448,7 @@ func chunkedHashTreeRootForBasicTypes[T](merkleizer: var SszChunksMerkleizer,
|
|||||||
|
|
||||||
else:
|
else:
|
||||||
static:
|
static:
|
||||||
assert T is SomeUnsignedInt|StUInt
|
assert T is SomeUnsignedInt
|
||||||
assert bytesPerChunk mod sizeof(Т) == 0
|
assert bytesPerChunk mod sizeof(Т) == 0
|
||||||
|
|
||||||
const valuesPerChunk = bytesPerChunk div sizeof(Т)
|
const valuesPerChunk = bytesPerChunk div sizeof(Т)
|
||||||
@ -539,7 +539,7 @@ func hashTreeRootAux[T](x: T): Eth2Digest =
|
|||||||
unsupported T # Blocks are identified by htr(BeaconBlock) so we avoid these
|
unsupported T # Blocks are identified by htr(BeaconBlock) so we avoid these
|
||||||
elif T is bool|char:
|
elif T is bool|char:
|
||||||
result.data[0] = byte(x)
|
result.data[0] = byte(x)
|
||||||
elif T is SomeUnsignedInt|StUint:
|
elif T is SomeUnsignedInt:
|
||||||
when cpuEndian == bigEndian:
|
when cpuEndian == bigEndian:
|
||||||
result.data[0..<sizeof(x)] = toBytesLE(x)
|
result.data[0..<sizeof(x)] = toBytesLE(x)
|
||||||
else:
|
else:
|
||||||
|
@ -1,82 +0,0 @@
|
|||||||
# beacon_chain
|
|
||||||
# Copyright (c) 2018-Present Status Research & Development GmbH
|
|
||||||
# Licensed and distributed under either of
|
|
||||||
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
|
||||||
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
|
||||||
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
||||||
|
|
||||||
import
|
|
||||||
# Standard library
|
|
||||||
os, unittest, strutils, streams,
|
|
||||||
# Status libraries
|
|
||||||
stint, stew/bitseqs,
|
|
||||||
# Third-party
|
|
||||||
yaml,
|
|
||||||
# Beacon chain internals
|
|
||||||
../../beacon_chain/spec/[datatypes, digest, crypto],
|
|
||||||
../../beacon_chain/ssz
|
|
||||||
|
|
||||||
# Config
|
|
||||||
# ---------------------------------------------
|
|
||||||
|
|
||||||
const
|
|
||||||
FixturesDir = currentSourcePath.rsplit(DirSep, 1)[0] / ".." / "official"/"fixtures"
|
|
||||||
SSZDir = FixturesDir/"tests-v0.9.1"/const_preset/"phase0"/"ssz_static"
|
|
||||||
UnitTestDir = SSZDir/"Validator"/"ssz_zero"/"case_0"
|
|
||||||
|
|
||||||
type
|
|
||||||
SSZHashTreeRoot = object
|
|
||||||
# The test files have the values at the "root"
|
|
||||||
# so we **must** use "root" as a field name
|
|
||||||
root: string
|
|
||||||
# Some have a signing_root field
|
|
||||||
signing_root: string
|
|
||||||
|
|
||||||
# Make signing root optional
|
|
||||||
setDefaultValue(SSZHashTreeRoot, signing_root, "")
|
|
||||||
|
|
||||||
# Parsing + Test
|
|
||||||
# ---------------------------------------------
|
|
||||||
|
|
||||||
type Skip = enum
|
|
||||||
SkipNone
|
|
||||||
SkipHashTreeRoot
|
|
||||||
SkipSigningRoot
|
|
||||||
|
|
||||||
proc checkSSZ(T: typedesc, dir: string, expectedHash: SSZHashTreeRoot, skip = SkipNone) =
|
|
||||||
# Deserialize into a ref object to not fill Nim stack
|
|
||||||
var deserialized: ref T
|
|
||||||
new deserialized
|
|
||||||
deserialized[] = SSZ.loadFile(dir/"serialized.ssz", T)
|
|
||||||
|
|
||||||
echo "\n\nObject: ", T
|
|
||||||
echo "---------------------------------------"
|
|
||||||
echo deserialized[]
|
|
||||||
|
|
||||||
if not(skip == SkipHashTreeRoot):
|
|
||||||
check: expectedHash.root == "0x" & toLowerASCII($deserialized.hashTreeRoot())
|
|
||||||
if expectedHash.signing_root != "" and not(skip == SkipSigningRoot):
|
|
||||||
check: expectedHash.signing_root == "0x" & toLowerASCII($deserialized[].signingRoot())
|
|
||||||
|
|
||||||
proc loadExpectedHashTreeRoot(dir: string): SSZHashTreeRoot =
|
|
||||||
var s = openFileStream(dir/"roots.yaml")
|
|
||||||
yaml.load(s, result)
|
|
||||||
s.close()
|
|
||||||
|
|
||||||
# Manual checks
|
|
||||||
# ---------------------------------------------
|
|
||||||
|
|
||||||
# Compile with -d:ssz_testing for consensus objects
|
|
||||||
# as they are always an Opaque Blob even if they might seem like a valid BLS signature
|
|
||||||
|
|
||||||
echo "Current preset: ", const_preset
|
|
||||||
|
|
||||||
let hash = loadExpectedHashTreeRoot(UnitTestDir)
|
|
||||||
checkSSZ(Validator, UnitTestDir, hash)
|
|
||||||
|
|
||||||
echo "\n\n"
|
|
||||||
var deserialized: ref Validator
|
|
||||||
new deserialized
|
|
||||||
deserialized[] = SSZ.loadFile(UnitTestDir/"serialized.ssz", Validator)
|
|
||||||
|
|
||||||
echo deserialized[].hashTreeRoot()
|
|
@ -10,7 +10,7 @@ import
|
|||||||
os, unittest, strutils, streams, strformat,
|
os, unittest, strutils, streams, strformat,
|
||||||
macros, sets,
|
macros, sets,
|
||||||
# Status libraries
|
# Status libraries
|
||||||
stint, stew/bitseqs,
|
stew/bitseqs,
|
||||||
# Third-party
|
# Third-party
|
||||||
yaml,
|
yaml,
|
||||||
# Beacon chain internals
|
# Beacon chain internals
|
||||||
|
@ -10,7 +10,7 @@ import
|
|||||||
os, unittest, strutils, streams, strformat, strscans,
|
os, unittest, strutils, streams, strformat, strscans,
|
||||||
macros, typetraits,
|
macros, typetraits,
|
||||||
# Status libraries
|
# Status libraries
|
||||||
faststreams, stint, stew/bitseqs, ../testutil,
|
faststreams, stew/bitseqs, ../testutil,
|
||||||
# Third-party
|
# Third-party
|
||||||
yaml,
|
yaml,
|
||||||
# Beacon chain internals
|
# Beacon chain internals
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{.used.}
|
{.used.}
|
||||||
|
|
||||||
import
|
import
|
||||||
unittest, stint, ./testutil,
|
unittest, ./testutil,
|
||||||
../beacon_chain/spec/[datatypes, network]
|
../beacon_chain/spec/[datatypes, network]
|
||||||
|
|
||||||
suiteReport "Honest validator":
|
suiteReport "Honest validator":
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
import
|
import
|
||||||
unittest, options, json_serialization,
|
unittest, options, json_serialization,
|
||||||
stint, nimcrypto, eth/common, serialization/testing/generic_suite,
|
nimcrypto, eth/common, serialization/testing/generic_suite,
|
||||||
./testutil,
|
./testutil,
|
||||||
../beacon_chain/spec/[datatypes, digest],
|
../beacon_chain/spec/[datatypes, digest],
|
||||||
../beacon_chain/ssz, ../beacon_chain/ssz/[navigator, dynamic_navigator]
|
../beacon_chain/ssz, ../beacon_chain/ssz/[navigator, dynamic_navigator]
|
||||||
@ -20,7 +20,6 @@ type
|
|||||||
|
|
||||||
Simple = object
|
Simple = object
|
||||||
flag: bool
|
flag: bool
|
||||||
# count: StUint[256]
|
|
||||||
# ignored {.dontSerialize.}: string
|
# ignored {.dontSerialize.}: string
|
||||||
# data: array[256, bool]
|
# data: array[256, bool]
|
||||||
|
|
||||||
|
2
vendor/nimbus-build-system
vendored
2
vendor/nimbus-build-system
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 1c9feb0d66fbd8e55560543aee96d3e0d33c6c0f
|
Subproject commit 252af3e779416c627158ba39b1df97cde51e5981
|
Loading…
x
Reference in New Issue
Block a user