fix engine api test

This commit is contained in:
jangko 2022-07-04 12:35:03 +07:00
parent 1509dea39d
commit ce098bf88f
No known key found for this signature in database
GPG Key ID: 31702AE10541E6B9
2 changed files with 38 additions and 33 deletions

View File

@ -42,13 +42,13 @@ proc `$`(x: Option[Hash256]): string =
if x.isNone: if x.isNone:
"none" "none"
else: else:
x.get().data.toHex $x.get()
proc `$`(x: Option[BlockHash]): string = proc `$`(x: Option[BlockHash]): string =
if x.isNone: if x.isNone:
"none" "none"
else: else:
x.get().toHex $x.get()
proc `$`(x: Option[PayloadID]): string = proc `$`(x: Option[PayloadID]): string =
if x.isNone: if x.isNone:
@ -57,9 +57,10 @@ proc `$`(x: Option[PayloadID]): string =
x.get().toHex x.get().toHex
proc `==`(a: Option[BlockHash], b: Option[Hash256]): bool = proc `==`(a: Option[BlockHash], b: Option[Hash256]): bool =
if a.isNone or b.isNone: if a.isNone and b.isNone:
return false return true
a.get() == b.get().data.BlockHash if a.isSome and b.isSome:
return a.get() == b.get().data.BlockHash
template testFCU(res, cond: untyped, validHash: Option[Hash256], id = none(PayloadID)) = template testFCU(res, cond: untyped, validHash: Option[Hash256], id = none(PayloadID)) =
testCond res.isOk testCond res.isOk
@ -103,8 +104,8 @@ template testLatestHeader(client: untyped, expectedHash: BlockHash) =
# Latest block header available via Eth RPC should not have changed at this point # Latest block header available via Eth RPC should not have changed at this point
testCond lastHash == expectedHash: testCond lastHash == expectedHash:
error "latest block header incorrect", error "latest block header incorrect",
expect = expectedHash.toHex, expect = expectedHash,
get = lastHash.toHex get = lastHash
proc sendTx(t: TestEnv, recipient: EthAddress, val: UInt256, data: openArray[byte] = []): bool = proc sendTx(t: TestEnv, recipient: EthAddress, val: UInt256, data: openArray[byte] = []): bool =
t.tx = t.makeNextTransaction(recipient, val, data) t.tx = t.makeNextTransaction(recipient, val, data)
@ -741,7 +742,7 @@ template invalidPayloadTestCaseGen(procName: untyped, payloadField: InvalidPaylo
let latestValidHash = s.latestValidHash.get let latestValidHash = s.latestValidHash.get
if latestValidHash != alteredPayload.parentHash: if latestValidHash != alteredPayload.parentHash:
error "latestValidHash is not the same with parentHash", error "latestValidHash is not the same with parentHash",
expected = alteredPayload.parentHash.toHex, get = latestValidHash.toHex expected = alteredPayload.parentHash, get = latestValidHash
return false return false
# Send the forkchoiceUpdated with a reference to the invalid payload. # Send the forkchoiceUpdated with a reference to the invalid payload.
@ -787,7 +788,7 @@ template invalidPayloadTestCaseGen(procName: untyped, payloadField: InvalidPaylo
)) ))
info "Sending customized NewPayload: ParentHash", info "Sending customized NewPayload: ParentHash",
fromHash=clMock.latestPayloadBuilt.parentHash.toHex, toHash=invalidPayload.hash.toHex fromHash=clMock.latestPayloadBuilt.parentHash, toHash=invalidPayload.hash
# Response status can be ACCEPTED (since parent payload could have been thrown out by the client) # Response status can be ACCEPTED (since parent payload could have been thrown out by the client)
# or SYNCING (parent payload is thrown out and also client assumes that the parent is part of canonical chain) # or SYNCING (parent payload is thrown out and also client assumes that the parent is part of canonical chain)
# or INVALID (client still has the payload and can verify that this payload is incorrectly building on top of it), # or INVALID (client still has the payload and can verify that this payload is incorrectly building on top of it),
@ -955,9 +956,9 @@ template invalidMissingAncestorReOrgGen(procName: untyped,
payloadValidStr = "VALID with INVALID ancestor" payloadValidStr = "VALID with INVALID ancestor"
info "Invalid chain payload", info "Invalid chain payload",
i, i = i,
payloadValidStr, payloadValidStr = payloadValidStr,
hash = shadow.altChainPayloads[i].blockHash.toHex hash = shadow.altChainPayloads[i].blockHash
let rr = client.newPayloadV1(shadow.altChainPayloads[i]) let rr = client.newPayloadV1(shadow.altChainPayloads[i])
testCond rr.isOk testCond rr.isOk
@ -976,16 +977,18 @@ template invalidMissingAncestorReOrgGen(procName: untyped,
# In reality the CL will not get to this point because it will have already received the `INVALID` # In reality the CL will not get to this point because it will have already received the `INVALID`
# response from the previous payload. # response from the previous payload.
let cond = {PayloadExecutionStatus.accepted, PayloadExecutionStatus.syncing, PayloadExecutionStatus.invalid} let cond = {PayloadExecutionStatus.accepted, PayloadExecutionStatus.syncing, PayloadExecutionStatus.invalid}
testNPEither(rr, cond, some(Hash256())) testNPEither(rr, cond)
else: else:
# This is one of the payloads before the invalid one, therefore is valid. # This is one of the payloads before the invalid one, therefore is valid.
testNP(rr, valid) let latestValidHash = some(shadow.altChainPayloads[i].blockHash.hash256)
testFCU(rs, valid, some(shadow.altChainPayloads[i].blockHash.hash256)) testNP(rr, valid, latestValidHash)
testFCU(rs, valid, latestValidHash)
# Resend the latest correct fcU # Resend the latest correct fcU
let rx = client.forkchoiceUpdatedV1(clMock.latestForkchoice) let rx = client.forkchoiceUpdatedV1(clMock.latestForkchoice)
testCond rx.isOk testCond rx.isOk:
error "Unexpected error ", msg=rx.error
# After this point, the CL Mock will send the next payload of the canonical chain # After this point, the CL Mock will send the next payload of the canonical chain
return true return true
@ -1126,7 +1129,7 @@ proc blockStatusReorg(t: TestEnv): TestStatus =
if currHash != clMock.latestForkchoice.headBlockHash or if currHash != clMock.latestForkchoice.headBlockHash or
currHash == clMock.latestForkchoice.safeBlockHash or currHash == clMock.latestForkchoice.safeBlockHash or
currHash == clMock.latestForkchoice.finalizedBlockHash: currHash == clMock.latestForkchoice.finalizedBlockHash:
error "latest block header doesn't match HeadBlock hash", hash=currHash.toHex error "latest block header doesn't match HeadBlock hash", hash=currHash
return false return false
# Reorg back to the previous block (FinalizedBlock) # Reorg back to the previous block (FinalizedBlock)
@ -1153,8 +1156,8 @@ proc blockStatusReorg(t: TestEnv): TestStatus =
var latestValidHash = s.payloadStatus.latestValidHash.get var latestValidHash = s.payloadStatus.latestValidHash.get
if latestValidHash != reorgForkchoice.headBlockHash: if latestValidHash != reorgForkchoice.headBlockHash:
error "Incorrect latestValidHash returned after a HeadBlockHash reorg", error "Incorrect latestValidHash returned after a HeadBlockHash reorg",
expected=reorgForkchoice.headBlockHash.toHex, expected=reorgForkchoice.headBlockHash,
get=latestValidHash.toHex get=latestValidHash
return false return false
# testCond that we reorg to the previous block # testCond that we reorg to the previous block
@ -1179,8 +1182,8 @@ proc blockStatusReorg(t: TestEnv): TestStatus =
latestValidHash = s.payloadStatus.latestValidHash.get latestValidHash = s.payloadStatus.latestValidHash.get
if latestValidHash != clMock.latestForkchoice.headBlockHash: if latestValidHash != clMock.latestForkchoice.headBlockHash:
error "Incorrect latestValidHash returned after a HeadBlockHash reorg", error "Incorrect latestValidHash returned after a HeadBlockHash reorg",
expected=clMock.latestForkchoice.headBlockHash.toHex, expected=clMock.latestForkchoice.headBlockHash,
get=latestValidHash.toHex get=latestValidHash
return false return false
return true return true
)) ))
@ -1492,14 +1495,14 @@ proc transactionReorg(t: TestEnv): TestStatus =
if shadow.noTxnPayload.parentHash != clMock.latestPayloadBuilt.parentHash: if shadow.noTxnPayload.parentHash != clMock.latestPayloadBuilt.parentHash:
error "Incorrect parent hash for payloads", error "Incorrect parent hash for payloads",
get = shadow.noTxnPayload.parentHash.toHex, get = shadow.noTxnPayload.parentHash,
expect = clMock.latestPayloadBuilt.parentHash.toHex expect = clMock.latestPayloadBuilt.parentHash
return false return false
if shadow.noTxnPayload.blockHash == clMock.latestPayloadBuilt.blockHash: if shadow.noTxnPayload.blockHash == clMock.latestPayloadBuilt.blockHash:
error "Incorrect hash for payloads", error "Incorrect hash for payloads",
get = shadow.noTxnPayload.blockHash.toHex, get = shadow.noTxnPayload.blockHash,
expect = clMock.latestPayloadBuilt.blockHash.toHex expect = clMock.latestPayloadBuilt.blockHash
return false return false
let rz = client.newPayloadV1(shadow.noTxnPayload) let rz = client.newPayloadV1(shadow.noTxnPayload)
@ -1538,8 +1541,8 @@ proc testCondPrevRandaoValue(t: TestEnv, expectedPrevRandao: Hash256, blockNumbe
let opcodeValueAtBlock = Hash256(data: res.get().toBytesBE) let opcodeValueAtBlock = Hash256(data: res.get().toBytesBE)
if opcodeValueAtBlock != expectedPrevRandao: if opcodeValueAtBlock != expectedPrevRandao:
error "Storage does not match prevRandao", error "Storage does not match prevRandao",
expected=expectedPrevRandao.data.toHex, expected=expectedPrevRandao.data,
get=opcodeValueAtBlock.data.toHex get=opcodeValueAtBlock
return false return false
true true
@ -1674,8 +1677,8 @@ proc suggestedFeeRecipient(t: TestEnv): TestStatus =
testCond blockIncluded.header.coinbase == feeRecipient: testCond blockIncluded.header.coinbase == feeRecipient:
error "feeRecipient was not set as coinbase", error "feeRecipient was not set as coinbase",
expected=feeRecipient.toHex, expected=feeRecipient,
get=blockIncluded.header.coinbase.toHex get=blockIncluded.header.coinbase
var feeRecipientFees = 0.u256 var feeRecipientFees = 0.u256
for tx in blockIncluded.txs: for tx in blockIncluded.txs:
@ -1797,7 +1800,7 @@ proc prevRandaoOpcodeTx(t: TestEnv): TestStatus =
let storage = rz.get() let storage = rz.get()
testCond storage == expectedPrevRandao: testCond storage == expectedPrevRandao:
error "Unexpected storage", expected=expectedPrevRandao.toHex, get=storage.toHex error "Unexpected storage", expected=expectedPrevRandao, get=storage
proc postMergeSync(t: TestEnv): TestStatus = proc postMergeSync(t: TestEnv): TestStatus =
result = TestStatus.SKIPPED result = TestStatus.SKIPPED

View File

@ -32,9 +32,11 @@ proc inc*(stat: var SimStat, name: string, status: TestStatus) =
stat.failingCases.add name stat.failingCases.add name
proc `$`*(stat: SimStat): string = proc `$`*(stat: SimStat): string =
result.add "Failing Cases:\n" if stat.failingCases.len > 0:
for c in stat.failingCases: result.add " - Failing Cases:\n"
result.add "- $1 \n" % [c] for c in stat.failingCases:
result.add " - $1 \n" % [c]
result.add "ok: $1, skipped: $2, failed: $3" % [$stat.ok, $stat.skipped, $stat.failed] result.add "ok: $1, skipped: $2, failed: $3" % [$stat.ok, $stat.skipped, $stat.failed]
proc print*(stat: SimStat, dur: Duration, name: string) = proc print*(stat: SimStat, dur: Duration, name: string) =