From 29db180725c852d1c3453b1470b8747ff2378ed8 Mon Sep 17 00:00:00 2001 From: cheatfate Date: Fri, 4 Aug 2023 02:09:13 +0300 Subject: [PATCH 1/4] Refactor keymanager-api test. --- tests/test_keymanager_api.nim | 208 +++++++++++++++++++++++++--------- vendor/nim-chronos | 2 +- vendor/nim-presto | 2 +- 3 files changed, 156 insertions(+), 56 deletions(-) diff --git a/tests/test_keymanager_api.nim b/tests/test_keymanager_api.nim index 222e509372..228da9cf0c 100644 --- a/tests/test_keymanager_api.nim +++ b/tests/test_keymanager_api.nim @@ -10,7 +10,7 @@ import std/[typetraits, os, options, json, sequtils, uri, algorithm], testutils/unittests, chronicles, stint, json_serialization, confutils, - chronos, blscurve, libp2p/crypto/crypto as lcrypto, + chronos, chronos/asyncproc, blscurve, libp2p/crypto/crypto as lcrypto, stew/[byteutils, io2], stew/shims/net, ../beacon_chain/spec/[crypto, keystore, eth2_merkleization], @@ -19,11 +19,7 @@ import ../beacon_chain/validators/[keystore_management, slashing_protection_common], ../beacon_chain/networking/network_metadata, ../beacon_chain/rpc/rest_key_management_api, - ../beacon_chain/[conf, filepath, beacon_node, - nimbus_beacon_node, beacon_node_status, - nimbus_validator_client], - ../beacon_chain/validator_client/common, - ../ncli/ncli_testnet, + ../beacon_chain/[conf, filepath, beacon_node], ./testutil type @@ -40,6 +36,10 @@ type KeymanagerBN, KeymanagerVC + TestProcess = object + process: AsyncProcessRef + reader: Future[seq[byte]] + const simulationDepositsCount = 128 dataDir = "./test_keymanager_api" @@ -119,7 +119,7 @@ func contains*(keylist: openArray[KeystoreInfo], key: string): bool = let pubkey = ValidatorPubKey.fromHex(key).tryGet() contains(keylist, pubkey) -proc prepareNetwork = +proc prepareNetwork() {.async.} = let rng = HmacDrbgContext.new() mnemonic = generateMnemonic(rng[]) @@ -158,10 +158,8 @@ proc prepareNetwork = Json.saveFile(depositsFile, launchPadDeposits) notice "Deposit data written", filename = depositsFile - let runtimeConfigWritten = secureWriteFile(runtimeConfigFile, """ -ALTAIR_FORK_EPOCH: 0 -BELLATRIX_FORK_EPOCH: 0 -""") + let runtimeConfigWritten = secureWriteFile(runtimeConfigFile, + "ALTAIR_FORK_EPOCH: 0\nBELLATRIX_FORK_EPOCH: 0\n") if runtimeConfigWritten.isOk: notice "Run-time config written", filename = runtimeConfigFile @@ -169,7 +167,7 @@ BELLATRIX_FORK_EPOCH: 0 fatal "Failed to write run-time config", filename = runtimeConfigFile quit 1 - let createTestnetConf = try: ncli_testnet.CliConfig.load(cmdLine = mapIt([ + let arguments = @[ "createTestnet", "--data-dir=" & dataDir, "--total-validators=" & $simulationDepositsCount, @@ -179,11 +177,25 @@ BELLATRIX_FORK_EPOCH: 0 "--output-bootstrap-file=" & bootstrapEnrFile, "--netkey-file=network_key.json", "--insecure-netkey-password=true", - "--genesis-offset=0"], it)) - except Exception as exc: # TODO Fix confutils exceptions - raiseAssert exc.msg + "--genesis-offset=0" + ] - doCreateTestnet(createTestnetConf, rng[]) + let process = + await startProcess("build/ncli_testnet", + arguments = arguments, + options = {AsyncProcessOption.StdErrToStdOut}, + stdoutHandle = AsyncProcess.Pipe) + + try: + let rescode = await process.waitForExit(1.minutes) + if rescode == 0: + notice "Testnet was successfully created" + else: + notice "Unable to create testnet", rescode = rescode + let res = await process.stdoutStream.read() + echo bytesToString(res) + finally: + await process.closeWait() let tokenFileRes = secureWriteFile(tokenFilePath, correctTokenValue) if tokenFileRes.isErr: @@ -270,13 +282,57 @@ proc addPreTestRemoteKeystores(validatorsDir: string) = err = res.error quit 1 -proc startBeaconNode(basePort: int) {.raises: [Defect, CatchableError].} = - let rng = HmacDrbgContext.new() +proc waitForPortOpen*(address: TransportAddress, ident: static[string], + duration: Duration = InfiniteDuration, + maxAttempts: int = high(int)): Future[bool] {.async.} = + let waitFut = + if duration == InfiniteDuration: + newFuture[void]("waitForPortOpen") + else: + sleepAsync(duration) + + var attemptsCount = 0 + while attemptsCount < maxAttempts: + let transpFut = connect(address) + + try: + discard await race(FutureBase(transpFut), FutureBase(waitFut)) + except CancelledError as exc: + var pending: seq[Future[void]] + if not(waitFut.finished()): pending.add(waitFut.cancelAndWait()) + if not(transpFut.finished()): pending.add(transpFut.cancelAndWait()) + await allFutures(pending) + raise exc + + if transpFut.finished(): + if transpFut.failed() or transpFut.cancelled(): + let + exc = transpFut.readError() + reason = "[" & $exc.name & "] " & $exc.msg + debug "Could not connect to remote " & ident, remote_host = address, + attempt = attemptsCount + 1, reason = reason + else: + let transp = transpFut.read() + await closeWait(transp) + if not(waitFut.finished()): + await cancelAndWait(waitFut) + return true + + if waitFut.finished(): + if not(transpFut.finished()): + await transpFut.cancelAndWait() + return false + + inc(attemptsCount) + + false + +proc startBeaconNode(basePort: int): Future[TestProcess] {.async.} = copyHalfValidators(nodeDataDir, true) addPreTestRemoteKeystores(nodeValidatorsDir) - let runNodeConf = try: BeaconNodeConf.load(cmdLine = mapIt([ + let arguments = @[ "--tcp-port=" & $(basePort + PortKind.PeerToPeer.ord), "--udp-port=" & $(basePort + PortKind.PeerToPeer.ord), "--discv5=off", @@ -295,26 +351,43 @@ proc startBeaconNode(basePort: int) {.raises: [Defect, CatchableError].} = "--keymanager-port=" & $(basePort + PortKind.KeymanagerBN.ord), "--keymanager-token-file=" & tokenFilePath, "--suggested-fee-recipient=" & $defaultFeeRecipient, - "--doppelganger-detection=off"], it)) - except Exception as exc: # TODO fix confutils exceptions - raiseAssert exc.msg - - let - metadata = loadEth2NetworkMetadata(dataDir) - node = BeaconNode.init(rng, runNodeConf, metadata) - - node.start() # This will run until the node is terminated by - # setting its `bnStatus` to `Stopping`. + "--doppelganger-detection=off" + ] - # os.removeDir dataDir + let res = + await startProcess("build/nimbus_beacon_node", + arguments = arguments, + options = {AsyncProcessOption.StdErrToStdOut}, + stdoutHandle = AsyncProcess.Pipe) + let tp = TestProcess( + process: res, reader: res.stdoutStream.read() + ) -proc startValidatorClient(basePort: int) {.async, thread.} = - let rng = HmacDrbgContext.new() + notice "Beacon node process has been started", + process_id = tp.process.pid() + let + address = initTAddress("127.0.0.1:" & + $(basePort + PortKind.KeymanagerBN.ord)) + flag = await waitForPortOpen(address, "beacon_node", 30.seconds) + + if not(flag): + notice "Unable to establish connection with `nimbus_beacon_node` process", + process_id = tp.process.pid() + let exitCode = await killAndWaitForExit(tp.process, 5.seconds) + echo "\n===== `nimbus_beacon_node` [", exitCode, "], logs =====" + let output = await tp.reader + echo bytesToString(output) + await tp.process.closeWait() + raiseAssert "Unable to continue test" + + return tp + +proc startValidatorClient(basePort: int): Future[TestProcess] {.async.} = copyHalfValidators(vcDataDir, false) addPreTestRemoteKeystores(vcValidatorsDir) - let runValidatorClientConf = try: ValidatorClientConf.load(cmdLine = mapIt([ + let arguments = @[ "--beacon-node=http://127.0.0.1:" & $(basePort + PortKind.KeymanagerBN.ord), "--data-dir=" & vcDataDir, "--validators-dir=" & vcValidatorsDir, @@ -323,11 +396,37 @@ proc startValidatorClient(basePort: int) {.async, thread.} = "--keymanager=true", "--keymanager-address=127.0.0.1", "--keymanager-port=" & $(basePort + PortKind.KeymanagerVC.ord), - "--keymanager-token-file=" & tokenFilePath], it)) - except: - quit 1 + "--keymanager-token-file=" & tokenFilePath + ] + + let res = + await startProcess("build/nimbus_validator_client", + arguments = arguments, + options = {AsyncProcessOption.StdErrToStdOut}, + stdoutHandle = AsyncProcess.Pipe) + let tp = TestProcess( + process: res, reader: res.stdoutStream.read() + ) - await runValidatorClient(runValidatorClientConf, rng) + notice "Validator client process has been started", + process_id = tp.process.pid() + + let + address = initTAddress("127.0.0.1:" & + $(basePort + PortKind.KeymanagerVC.ord)) + flag = await waitForPortOpen(address, "validator_client", 30.seconds) + + if not(flag): + notice "Unable to establish connection with `nimbus_validator_client` " & + "process", process_id = tp.process.pid() + discard await killAndWaitForExit(tp.process, 5.seconds) + echo "\n===== `nimbus_validator_client` logs =====" + let output = await tp.reader + echo bytesToString(output) + await tp.process.closeWait() + raiseAssert "Unable to continue test" + + return tp const password = "7465737470617373776f7264f09f9491" @@ -1453,31 +1552,32 @@ proc delayedTests(basePort: int) {.async.} = validatorsDir: vcValidatorsDir, secretsDir: vcSecretsDir) - while bnStatus != BeaconNodeStatus.Running: - await sleepAsync(1.seconds) - - asyncSpawn startValidatorClient(basePort) - - await sleepAsync(2.seconds) - let deadline = sleepAsync(10.minutes) await runTests(beaconNodeKeymanager) or deadline - - # TODO - # This tests showed flaky behavior on a single Windows CI host - # Re-enable it in a follow-up PR - # await runTests(validatorClientKeymanager) - - bnStatus = BeaconNodeStatus.Stopping + await runTests(validatorClientKeymanager) or deadline proc main(basePort: int) {.async.} = if dirExists(dataDir): os.removeDir dataDir - asyncSpawn delayedTests(basePort) + await prepareNetwork() + + let + bnProcess = await startBeaconNode(basePort) + vcProcess = await startValidatorClient(basePort) - prepareNetwork() - startBeaconNode(basePort) + try: + await delayedTests(basePort) + finally: + echo "" + await allFutures( + killAndWaitForExit(bnProcess.process, 5.seconds), + killAndWaitForExit(vcProcess.process, 5.seconds) + ) + await allFutures( + bnProcess.process.closeWait(), + vcProcess.process.closeWait() + ) let basePortStr = os.getEnv("NIMBUS_TEST_KEYMANAGER_BASE_PORT", $defaultBasePort) diff --git a/vendor/nim-chronos b/vendor/nim-chronos index 6b4f5a1d23..c546a4329c 160000 --- a/vendor/nim-chronos +++ b/vendor/nim-chronos @@ -1 +1 @@ -Subproject commit 6b4f5a1d23b1583b2b0ccee409e2e7c6dc6fff93 +Subproject commit c546a4329cad426fc1deb32f3a7bca6ead4c2b2c diff --git a/vendor/nim-presto b/vendor/nim-presto index 42552611cf..c40e4a7eb4 160000 --- a/vendor/nim-presto +++ b/vendor/nim-presto @@ -1 +1 @@ -Subproject commit 42552611cfe04ca7838243d0a0e88fb9a5e9701a +Subproject commit c40e4a7eb4bb2a9d8c8773b7a4d719827b049b9d From 7e15be653a731e2099f0c3c6f20fe9148cd299da Mon Sep 17 00:00:00 2001 From: cheatfate Date: Fri, 4 Aug 2023 02:16:16 +0300 Subject: [PATCH 2/4] Fix presto. --- vendor/nim-presto | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vendor/nim-presto b/vendor/nim-presto index c40e4a7eb4..dceac3f5cc 160000 --- a/vendor/nim-presto +++ b/vendor/nim-presto @@ -1 +1 @@ -Subproject commit c40e4a7eb4bb2a9d8c8773b7a4d719827b049b9d +Subproject commit dceac3f5cc1876052a303e7f0cecc261e3858996 From 12415220f1a1d73bc4eb2dffdff480d1b2084797 Mon Sep 17 00:00:00 2001 From: cheatfate Date: Fri, 4 Aug 2023 04:59:14 +0300 Subject: [PATCH 3/4] Update Makefile. Improve logging on failure. --- Makefile | 2 +- tests/test_keymanager_api.nim | 43 +++++++++++++++++++++++------------ 2 files changed, 29 insertions(+), 16 deletions(-) diff --git a/Makefile b/Makefile index 951285084f..2bc4dcd0c6 100644 --- a/Makefile +++ b/Makefile @@ -354,7 +354,7 @@ FORCE_BUILD_ALONE_ALL_TESTS_DEPS := endif force_build_alone_all_tests: | $(FORCE_BUILD_ALONE_ALL_TESTS_DEPS) -all_tests: | build deps nimbus_signing_node force_build_alone_all_tests +all_tests: | build deps nimbus_beacon_node nimbus_signing_node ncli_testnet nimbus_validator_client force_build_alone_all_tests + echo -e $(BUILD_MSG) "build/$@" && \ MAKE="$(MAKE)" V="$(V)" $(ENV_SCRIPT) scripts/compile_nim_program.sh \ $@ \ diff --git a/tests/test_keymanager_api.nim b/tests/test_keymanager_api.nim index 228da9cf0c..d2489f284e 100644 --- a/tests/test_keymanager_api.nim +++ b/tests/test_keymanager_api.nim @@ -179,9 +179,10 @@ proc prepareNetwork() {.async.} = "--insecure-netkey-password=true", "--genesis-offset=0" ] + let binaryPath = absolutePath("build/ncli_testnet") let process = - await startProcess("build/ncli_testnet", + await startProcess(binaryPath, arguments = arguments, options = {AsyncProcessOption.StdErrToStdOut}, stdoutHandle = AsyncProcess.Pipe) @@ -193,7 +194,9 @@ proc prepareNetwork() {.async.} = else: notice "Unable to create testnet", rescode = rescode let res = await process.stdoutStream.read() + echo "===== [", binaryPath, "] exited with [", rescode, "] =====" echo bytesToString(res) + echo "=====" finally: await process.closeWait() @@ -354,8 +357,10 @@ proc startBeaconNode(basePort: int): Future[TestProcess] {.async.} = "--doppelganger-detection=off" ] + let binaryPath = absolutePath("build/nimbus_beacon_node") + let res = - await startProcess("build/nimbus_beacon_node", + await startProcess(binaryPath, arguments = arguments, options = {AsyncProcessOption.StdErrToStdOut}, stdoutHandle = AsyncProcess.Pipe) @@ -364,7 +369,7 @@ proc startBeaconNode(basePort: int): Future[TestProcess] {.async.} = ) notice "Beacon node process has been started", - process_id = tp.process.pid() + process_id = tp.process.pid(), binary_path = binaryPath let address = initTAddress("127.0.0.1:" & @@ -373,12 +378,15 @@ proc startBeaconNode(basePort: int): Future[TestProcess] {.async.} = if not(flag): notice "Unable to establish connection with `nimbus_beacon_node` process", - process_id = tp.process.pid() - let exitCode = await killAndWaitForExit(tp.process, 5.seconds) - echo "\n===== `nimbus_beacon_node` [", exitCode, "], logs =====" - let output = await tp.reader - echo bytesToString(output) + process_id = tp.process.pid(), binary_path = binaryPath + let + exitCode = await killAndWaitForExit(tp.process, 5.seconds) + output = await tp.reader + await tp.process.closeWait() + echo "===== [", binaryPath, "] exited with [", exitCode, "] =====" + echo bytesToString(output) + echo "=====" raiseAssert "Unable to continue test" return tp @@ -399,8 +407,10 @@ proc startValidatorClient(basePort: int): Future[TestProcess] {.async.} = "--keymanager-token-file=" & tokenFilePath ] + let binaryPath = absolutePath("build/nimbus_validator_client") + let res = - await startProcess("build/nimbus_validator_client", + await startProcess(binaryPath, arguments = arguments, options = {AsyncProcessOption.StdErrToStdOut}, stdoutHandle = AsyncProcess.Pipe) @@ -409,7 +419,7 @@ proc startValidatorClient(basePort: int): Future[TestProcess] {.async.} = ) notice "Validator client process has been started", - process_id = tp.process.pid() + process_id = tp.process.pid(), binary_path = binaryPath let address = initTAddress("127.0.0.1:" & @@ -418,12 +428,15 @@ proc startValidatorClient(basePort: int): Future[TestProcess] {.async.} = if not(flag): notice "Unable to establish connection with `nimbus_validator_client` " & - "process", process_id = tp.process.pid() - discard await killAndWaitForExit(tp.process, 5.seconds) - echo "\n===== `nimbus_validator_client` logs =====" - let output = await tp.reader - echo bytesToString(output) + "process", process_id = tp.process.pid(), binary_path = binaryPath + let + exitCode = await killAndWaitForExit(tp.process, 5.seconds) + output = await tp.reader + await tp.process.closeWait() + echo "===== [", binaryPath, "] exited with [", exitCode, "] =====" + echo bytesToString(output) + echo "=====" raiseAssert "Unable to continue test" return tp From d16f993bc2b3d56ecb20388d58b1bfc1b37e9089 Mon Sep 17 00:00:00 2001 From: cheatfate Date: Fri, 4 Aug 2023 12:12:36 +0300 Subject: [PATCH 4/4] Update Alltests. --- AllTests-mainnet.md | 78 ++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 77 insertions(+), 1 deletion(-) diff --git a/AllTests-mainnet.md b/AllTests-mainnet.md index d5014c7290..133e572e85 100644 --- a/AllTests-mainnet.md +++ b/AllTests-mainnet.md @@ -123,6 +123,14 @@ OK: 2/2 Fail: 0/2 Skip: 0/2 + Missing Authorization header [Beacon Node] [Preset: mainnet] OK ``` OK: 4/4 Fail: 0/4 Skip: 0/4 +## DeleteKeys requests [Validator Client] [Preset: mainnet] +```diff ++ Deleting not existing key [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK +``` +OK: 4/4 Fail: 0/4 Skip: 0/4 ## DeleteRemoteKeys requests [Beacon Node] [Preset: mainnet] ```diff + Deleting existing local key and remote key [Beacon Node] [Preset: mainnet] OK @@ -132,6 +140,15 @@ OK: 4/4 Fail: 0/4 Skip: 0/4 + Missing Authorization header [Beacon Node] [Preset: mainnet] OK ``` OK: 5/5 Fail: 0/5 Skip: 0/5 +## DeleteRemoteKeys requests [Validator Client] [Preset: mainnet] +```diff ++ Deleting existing local key and remote key [Validator Client] [Preset: mainnet] OK ++ Deleting not existing key [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK +``` +OK: 5/5 Fail: 0/5 Skip: 0/5 ## DepositTreeSnapshot ```diff + Migration OK @@ -203,6 +220,17 @@ OK: 3/3 Fail: 0/3 Skip: 0/3 + Setting the fee recipient on a missing validator creates a record for it [Beacon Node] [Pr OK ``` OK: 7/7 Fail: 0/7 Skip: 0/7 +## Fee recipient management [Validator Client] [Preset: mainnet] +```diff ++ Configuring the fee recipient [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK ++ Obtaining the fee recipient of a missing validator returns 404 [Validator Client] [Preset: OK ++ Obtaining the fee recipient of an unconfigured validator returns the suggested default [Va OK ++ Setting the fee recipient on a missing validator creates a record for it [Validator Client OK +``` +OK: 7/7 Fail: 0/7 Skip: 0/7 ## FinalizedBlocks [Preset: mainnet] ```diff + Basic ops [Preset: mainnet] OK @@ -241,6 +269,17 @@ OK: 11/11 Fail: 0/11 Skip: 0/11 + Setting the gas limit on a missing validator creates a record for it [Beacon Node] [Preset OK ``` OK: 7/7 Fail: 0/7 Skip: 0/7 +## Gas limit management [Validator Client] [Preset: mainnet] +```diff ++ Configuring the gas limit [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK ++ Obtaining the gas limit of a missing validator returns 404 [Validator Client] [Preset: mai OK ++ Obtaining the gas limit of an unconfigured validator returns the suggested default [Valida OK ++ Setting the gas limit on a missing validator creates a record for it [Validator Client] [P OK +``` +OK: 7/7 Fail: 0/7 Skip: 0/7 ## Gossip fork transition ```diff + Gossip fork transition OK @@ -275,6 +314,14 @@ OK: 6/6 Fail: 0/6 Skip: 0/6 + Missing Authorization header [Beacon Node] [Preset: mainnet] OK ``` OK: 4/4 Fail: 0/4 Skip: 0/4 +## ImportKeystores requests [Validator Client] [Preset: mainnet] +```diff ++ ImportKeystores/ListKeystores/DeleteKeystores [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK +``` +OK: 4/4 Fail: 0/4 Skip: 0/4 ## ImportRemoteKeys/ListRemoteKeys/DeleteRemoteKeys [Beacon Node] [Preset: mainnet] ```diff + Importing list of remote keys [Beacon Node] [Preset: mainnet] OK @@ -283,6 +330,14 @@ OK: 4/4 Fail: 0/4 Skip: 0/4 + Missing Authorization header [Beacon Node] [Preset: mainnet] OK ``` OK: 4/4 Fail: 0/4 Skip: 0/4 +## ImportRemoteKeys/ListRemoteKeys/DeleteRemoteKeys [Validator Client] [Preset: mainnet] +```diff ++ Importing list of remote keys [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK +``` +OK: 4/4 Fail: 0/4 Skip: 0/4 ## Key spliting ```diff + k < n OK @@ -343,6 +398,14 @@ OK: 12/12 Fail: 0/12 Skip: 0/12 + Missing Authorization header [Beacon Node] [Preset: mainnet] OK ``` OK: 4/4 Fail: 0/4 Skip: 0/4 +## ListKeys requests [Validator Client] [Preset: mainnet] +```diff ++ Correct token provided [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK +``` +OK: 4/4 Fail: 0/4 Skip: 0/4 ## ListRemoteKeys requests [Beacon Node] [Preset: mainnet] ```diff + Correct token provided [Beacon Node] [Preset: mainnet] OK @@ -351,6 +414,14 @@ OK: 4/4 Fail: 0/4 Skip: 0/4 + Missing Authorization header [Beacon Node] [Preset: mainnet] OK ``` OK: 4/4 Fail: 0/4 Skip: 0/4 +## ListRemoteKeys requests [Validator Client] [Preset: mainnet] +```diff ++ Correct token provided [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Header [Validator Client] [Preset: mainnet] OK ++ Invalid Authorization Token [Validator Client] [Preset: mainnet] OK ++ Missing Authorization header [Validator Client] [Preset: mainnet] OK +``` +OK: 4/4 Fail: 0/4 Skip: 0/4 ## Message signatures ```diff + Aggregate and proof signatures OK @@ -440,6 +511,11 @@ OK: 5/5 Fail: 0/5 Skip: 0/5 + Deserialization test vectors OK ``` OK: 1/1 Fail: 0/1 Skip: 0/1 +## Serialization/deserialization [Validator Client] [Preset: mainnet] +```diff ++ Deserialization test vectors OK +``` +OK: 1/1 Fail: 0/1 Skip: 0/1 ## Serialization/deserialization test suite ```diff + RestErrorMessage parser tests OK @@ -698,4 +774,4 @@ OK: 2/2 Fail: 0/2 Skip: 0/2 OK: 9/9 Fail: 0/9 Skip: 0/9 ---TOTAL--- -OK: 391/396 Fail: 0/396 Skip: 5/396 +OK: 431/436 Fail: 0/436 Skip: 5/436