-
Notifications
You must be signed in to change notification settings - Fork 65
[SSZ] test vectors #115
Comments
An alternative organization ---
title: Sample SSZ (De)serialization test
summary: Test (de)serialization
test_suite: Simple_Serialization
fork: Istanbul # Versioning
test_cases:
- type0:
- fields: {field0: "uint32"}
- deserialized: {field0: 260}
- serialized: [0, 0, 1, 4]
- int8:
- deserialized: 5
- serialized: [5]
- type1:
- fields: {
field0: "uint8",
field1: "uint32",
field2: "address",
field3: "hash32",
field4: "bytes"
}
- deserialized: {
field0: 5,
field1: 4294967293, # 2^32 - 3
field2: "0x0101...0101",
field3: "0X0202...0202",
field4: "0x03030303"
}
- serialized: [
5, # 5'u8 as an array of bytes
255, 255, 255, 253, # 4294967293'u32 as an array of bytes
1, 1, ..., 1, 1, # address "0x0101...0101"
2, 2, ..., 2, 2, # hash32 "0X0202...0202"
4, 3, 3, 3, 3 # length prefix + bytes sequence [3, 3, 3, 3]
] Edit: assuming we want to test multiple values per type: ---
title: Sample SSZ (De)serialization test
summary: Test (de)serialization
test_suite: Simple_Serialization
fork: Istanbul # Versioning
test_cases:
- type0:
- fields: {field0: "uint32"}
- tests:
- test1:
deserialized: {field0: 260}
serialized: [0, 0, 1, 4]
- test2:
deserialized: {field0: 0}
serialized: [0, 0, 0, 0] |
The YAML spec and libraries provide support for custom type annotations, so the simplest possible format is the following: test case 1:
in:
field0: !int32 10
field1: !address 0x2234781...
field2: "text"
out: "0x243242..."
test case 2:
in: 10
out: "0x0A" In Python, for example, these type annotations are handled with custom functions registered in the import yaml
def yaml_address_constructor(loader, node):
return parse_address(node.value)
yaml.add_constructor("!address", yaml_address_constructor)
test_case = yaml.load(...) |
Although we would forgo some built-in support, I personally prefer @mratsim's format due to the ability to define a multi-field type and test multiple values per type. Also, adding |
@mratsim I modified the chain test format to conform to your proposed format with I think it generally makes sense to support multiple |
Would be nice to share and put all the test vectors for SSZ and fork choice under one repo |
That is the intention @terenc3t. It will probably live at ethereum/eth2.0-tests and you will be able to add it into your repo as a submodule (just like eth1.0 clients do with the eth1.0 unified testing repo) |
Here's the repo, but we don't have anything to put it in until we decide on some testing formats :) |
This looks good to me. I have been generating some tests for the shuffling algorithm:
The code is a bit scrappy, I didn't want to spend too much time on it until the spec is finalized. Apologies to the reader. When the format is more final, I'll complete and submit these shuffling vectors for PR :) I have one suggestion: Add a "version" fieldI imagine I'm guessing the identity of the spec file would be: |
@mratsim, Paul and I were discussing that in light of the tests he has generated, maybe all test cases don't deserve a name. Instead make the test cases a list and have an optional "name" and "description" field for any test case in any of the test_suites. This ensures that we don't have to spend time writing names for self explanatory tests and keeps the nesting a little more manageable. This would change your example format to the following (with the option of leaving out the "name" field or adding a "description" field). title: Sample SSZ (De)serialization test
summary: Test (de)serialization
test_suite: Simple_Serialization
fork: Istanbul # Versioning
test_cases:
- name: type0
fields: {field0: "uint32"}
tests:
- test1:
deserialized: {field0: 260}
serialized: [0, 0, 1, 4]
- test2:
deserialized: {field0: 0}
serialized: [0, 0, 0, 0] Thoughts? |
described the general format in more detail in this PR |
I think it would be useful to have language agnostic test-vectors. We can probably reuse yaml like what is proposed in #58 and https://notes.ethereum.org/s/r11GVSBuQ
Example (note: this is completely untested and may not be valid YAML, it's just to provide a first direction)
Those can be stored alongside the spec in the https://github.com/ethereum/eth2.0-specs repo.
The text was updated successfully, but these errors were encountered: