Add state and history content key tests (#916)

This commit is contained in:
Kim De Mey 2021-12-20 09:53:00 +01:00 committed by GitHub
parent 092d946c72
commit 796787e0e5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 177 additions and 19 deletions

View File

@ -11,17 +11,20 @@ import
unittest2, stew/byteutils, unittest2, stew/byteutils,
../network/history/history_content ../network/history/history_content
# According to test vectors:
# TODO: Add link once test vectors are merged
suite "History ContentKey Encodings": suite "History ContentKey Encodings":
test "ContentKey": test "BlockHeader":
var blockHash: BlockHash var blockHash: BlockHash
blockHash.data = hexToByteArray[sizeof(BlockHash)]( blockHash.data = hexToByteArray[sizeof(BlockHash)](
"0x0100000000000000000000000000000000000000000000000000000000000000") "0xd1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d")
let contentKey = let contentKey =
ContentKey(chainId: 1'u16, contentType: BlockBody, blockHash: blockHash) ContentKey(chainId: 15'u16, contentType: BlockHeader, blockHash: blockHash)
let encoded = encode(contentKey) let encoded = encode(contentKey)
check encoded.asSeq.toHex == check encoded.asSeq.toHex ==
"0100020100000000000000000000000000000000000000000000000000000000000000" "0f0001d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
# "010f00d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
let decoded = decode(encoded) let decoded = decode(encoded)
check decoded.isSome() check decoded.isSome()
@ -32,4 +35,50 @@ suite "History ContentKey Encodings":
contentKeyDecoded.blockHash == contentKey.blockHash contentKeyDecoded.blockHash == contentKey.blockHash
toContentId(contentKey).toHex() == toContentId(contentKey).toHex() ==
"36a55e9aa5125c5fecc16bcb0234d9d3d6065eabc890c0d3b24d413d6ae9f9da" "9a310df5e6135cbd834041011be1b350e589ba013f11584ed527583bc39d3c27"
test "BlockBody":
var blockHash: BlockHash
blockHash.data = hexToByteArray[sizeof(BlockHash)](
"0xd1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d")
let contentKey =
ContentKey(chainId: 20'u16, contentType: BlockBody, blockHash: blockHash)
let encoded = encode(contentKey)
check encoded.asSeq.toHex ==
"140002d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
# "021400d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
let decoded = decode(encoded)
check decoded.isSome()
let contentKeyDecoded = decoded.get()
check:
contentKeyDecoded.chainId == contentKey.chainId
contentKeyDecoded.contentType == contentKey.contentType
contentKeyDecoded.blockHash == contentKey.blockHash
toContentId(contentKey).toHex() ==
"42a9bb9fd974f4d3020fe81aa584277010a9e344bed52bf1610e9d360203380a"
test "Receipts":
var blockHash: BlockHash
blockHash.data = hexToByteArray[sizeof(BlockHash)](
"0xd1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d")
let contentKey =
ContentKey(chainId: 4'u16, contentType: Receipts, blockHash: blockHash)
let encoded = encode(contentKey)
check encoded.asSeq.toHex ==
"040003d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
# "030400d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
let decoded = decode(encoded)
check decoded.isSome()
let contentKeyDecoded = decoded.get()
check:
contentKeyDecoded.chainId == contentKey.chainId
contentKeyDecoded.contentType == contentKey.contentType
contentKeyDecoded.blockHash == contentKey.blockHash
toContentId(contentKey).toHex() ==
"4b92510bafa02f62811ce6d0e27d2424ba34d41fbe38abc3ea4e274d6c76fa3e"

View File

@ -11,6 +11,9 @@ import
unittest2, stint, stew/[byteutils, results], eth/p2p/discoveryv5/enr, unittest2, stint, stew/[byteutils, results], eth/p2p/discoveryv5/enr,
../network/wire/messages ../network/wire/messages
# According to test vectors:
# https://github.com/ethereum/portal-network-specs/blob/master/portal-wire-test-vectors.md
suite "Portal Wire Protocol Message Encodings": suite "Portal Wire Protocol Message Encodings":
test "Ping Request": test "Ping Request":
let let

View File

@ -11,23 +11,31 @@ import
unittest2, stew/byteutils, unittest2, stew/byteutils,
../network/state/state_content ../network/state/state_content
# According to test vectors:
# TODO: Add link once test vectors are merged
suite "State ContentKey Encodings": suite "State ContentKey Encodings":
test "ContentKey - accountTrieNode": const
let path = ByteList.init(hexToSeqByte("0x0304")) stateRoot = hexToByteArray[sizeof(Bytes32)](
"0xd1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d")
address = hexToByteArray[sizeof(Address)](
"0x829bd824b016326a401d083b33d092293333a830")
test "AccountTrieNode":
var nodeHash: NodeHash var nodeHash: NodeHash
nodeHash.data = hexToByteArray[sizeof(NodeHash)]( nodeHash.data = hexToByteArray[sizeof(NodeHash)](
"0x0100000000000000000000000000000000000000000000000000000000000000") "0xb8be7903aee73b8f6a59cd44a1f52c62148e1f376c0dfa1f5f773a98666efc2b")
let stateRoot = hexToByteArray[sizeof(Bytes32)]( let path = ByteList.init(@[byte 1, 2, 0, 1])
"0x0200000000000000000000000000000000000000000000000000000000000000")
let accountTrieNodeKey = AccountTrieNodeKey( let
path: path, nodeHash: nodeHash, stateRoot: stateRoot) accountTrieNodeKey = AccountTrieNodeKey(
let contentKey = ContentKey( path: path, nodeHash: nodeHash, stateRoot: stateRoot)
contentType: accountTrieNode, accountTrieNodeKey: accountTrieNodeKey) contentKey = ContentKey(
contentType: accountTrieNode, accountTrieNodeKey: accountTrieNodeKey)
let encoded = encode(contentKey) let encoded = encode(contentKey)
check encoded.asSeq.toHex == check encoded.asSeq.toHex ==
"0044000000010000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000304" "0044000000b8be7903aee73b8f6a59cd44a1f52c62148e1f376c0dfa1f5f773a98666efc2bd1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d01020001"
let decoded = decode(encoded) let decoded = decode(encoded)
check decoded.isSome() check decoded.isSome()
@ -37,7 +45,105 @@ suite "State ContentKey Encodings":
contentKeyDecoded.accountTrieNodeKey == contentKey.accountTrieNodeKey contentKeyDecoded.accountTrieNodeKey == contentKey.accountTrieNodeKey
toContentId(contentKey).toHex() == toContentId(contentKey).toHex() ==
"17cc73bd15072a4f62fbec6e4dd0fa99bdc103e73b90143f01bb4079955ba74c" "5b2b5ea9a7384491010c1aa459a0f967dcf8b69988adbfe7e0bed513e9bb8305"
# TODO: Add test for each ContentType, perhaps when path is specced out and test "ContractStorageTrieNode":
# test vectors exist. var nodeHash: NodeHash
nodeHash.data = hexToByteArray[sizeof(NodeHash)](
"0x3e190b68719aecbcb28ed2271014dd25f2aa633184988eb414189ce0899cade5")
let path = ByteList.init(@[byte 1, 0, 15, 14, 12, 0])
let
contractStorageTrieNodeKey = ContractStorageTrieNodeKey(
address: address, path: path, nodeHash: nodeHash, stateRoot: stateRoot)
contentKey = ContentKey(
contentType: contractStorageTrieNode,
contractStorageTrieNodeKey: contractStorageTrieNodeKey)
let encoded = encode(contentKey)
check encoded.asSeq.toHex ==
"01829bd824b016326a401d083b33d092293333a830580000003e190b68719aecbcb28ed2271014dd25f2aa633184988eb414189ce0899cade5d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d01000f0e0c00"
let decoded = decode(encoded)
check decoded.isSome()
let contentKeyDecoded = decoded.get()
check:
contentKeyDecoded.contentType == contentKey.contentType
contentKeyDecoded.contractStorageTrieNodeKey ==
contentKey.contractStorageTrieNodeKey
toContentId(contentKey).toHex() ==
"603cbe7902925ce359822378a4cb1b4b53e1bf19d003de2c26e55812d76956c1"
test "AccountTrieProof":
let
accountTrieProofKey = AccountTrieProofKey(
address: address, stateRoot: stateRoot)
contentKey = ContentKey(
contentType: accountTrieProof,
accountTrieProofKey: accountTrieProofKey)
let encoded = encode(contentKey)
check encoded.asSeq.toHex ==
"02829bd824b016326a401d083b33d092293333a830d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
let decoded = decode(encoded)
check decoded.isSome()
let contentKeyDecoded = decoded.get()
check:
contentKeyDecoded.contentType == contentKey.contentType
contentKeyDecoded.accountTrieProofKey == contentKey.accountTrieProofKey
toContentId(contentKey).toHex() ==
"6427c4c8d42db15c2aca8dfc7dff7ce2c8c835441b566424fa3377dd031cc60d"
test "ContractStorageTrieProof":
let slot = 239304.stuint(256)
let
contractStorageTrieProofKey = ContractStorageTrieProofKey(
address: address, slot: slot, stateRoot: stateRoot)
contentKey = ContentKey(
contentType: contractStorageTrieProof,
contractStorageTrieProofKey: contractStorageTrieProofKey)
let encoded = encode(contentKey)
check encoded.asSeq.toHex ==
"03829bd824b016326a401d083b33d092293333a830c8a6030000000000000000000000000000000000000000000000000000000000d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
let decoded = decode(encoded)
check decoded.isSome()
let contentKeyDecoded = decoded.get()
check:
contentKeyDecoded.contentType == contentKey.contentType
contentKeyDecoded.contractStorageTrieProofKey ==
contentKey.contractStorageTrieProofKey
toContentId(contentKey).toHex() ==
"ce5a3a6bc958561da0015d92f2f6b4f5a2cf6a4ae3f6a75c97f05e9e2a6f4387"
test "ContractBytecode":
var codeHash: CodeHash
codeHash.data = hexToByteArray[sizeof(CodeHash)](
"0xd1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d")
let
contractBytecodeKey = ContractBytecodeKey(
address: address, codeHash: codeHash)
contentKey = ContentKey(
contentType: contractBytecode,
contractBytecodeKey: contractBytecodeKey)
let encoded = encode(contentKey)
check encoded.asSeq.toHex ==
"04829bd824b016326a401d083b33d092293333a830d1c390624d3bd4e409a61a858e5dcc5517729a9170d014a6c96530d64dd8621d"
let decoded = decode(encoded)
check decoded.isSome()
let contentKeyDecoded = decoded.get()
check:
contentKeyDecoded.contentType == contentKey.contentType
contentKeyDecoded.contractBytecodeKey == contentKey.contractBytecodeKey
toContentId(contentKey).toHex() ==
"146fb937afe42bcf11d25ad57d67734b9a7138677d59eeec3f402908f54dafb0"