Releases for the tests library follow semantic versioning:
- Major number updates every time there is a backwards incompatibility for test runners, e.g.
- New fork rules
- Backwards-incompatible format changes
- Minor number updates when new tests are added that are backwards compatible
- Patch number updates if an existing test is bugfixed
Here is an example how a follow-up release line could look like:
- v6-alpha - starting to implement EIPs, but not all EIPs are finalized
- v6-beta - all EIPs finalized, but some tests still in progress
- v6.0.0 - all desired coverage for Constantinople tests to be considered "done enough"
- v6.1.0 - more coverage added
- v6.2.0 - more coverage added
- v6.2.1 - bugfix on one of the tests
- v7.0.0 - change in test format output (if backwards incompatible)
This is the first Ethereum
tests release with broader Istanbul
support,
see the "Istanbul support" section for a list with relevant PRs.
This release also comes with some structural changes to the test folder layout,
the most important ones being the introduction of a new separate LegacyTests
test suite for state tests up to Constantinople
, a new sub folder structure
for BlockchainTests
and a new separate suite GeneralStateTests/stTimeConsuming/
for time consuming tests. For further details please have a look at the
"Test Format Changes" section.
- EIP-152: Blake2b
F
precompile,CALL
andCALLCODE
tests added for the standard unit test vectors for Blake2bF
, PR #619 - EIP-1344: ChainID opcode, state tests added in PR #627
- EIP-1884: Repricing for
trie-size-dependent opcodes,
SELFBALANCE
andSLOAD
gas cost tests added in PR #627
- Regeneration of
BlockchainTests/GeneralStateTests
(hive
tests), PR #632 - Updated
TransactionTests/
toIstanbul
, PR #633 - Updated state tests with latest
lllc
, PR #635 - Updated
GeneralStateTests
toIstanbul
, PR #639
The following tests touching Constantinople/Petersburg behavior have been added or updated since the last release:
- Added
ConstantinopleFix
(akaPetersburg
) tests, PR #582 - Updated
ByzantiumToConstantinople
transition test toByzantiumToConstantinopleFix
(seeBlockchainTests/TransitionTests
), PR #583, PR #588 - New
SAR
,SHL
,SHR
combinations, PR #574
- New
LegacyTests
suite forBlockchainTests/GeneralStateTests
andGeneralStateTests
for HFs up toConstantinople
(so not:ConstantinopleFix
akaPetersburg
), PR #623 - New subfolder structure for
BlockchainTests
with added folders forInvalidBlocks
andValidBlocks
, PR #605 - New separate suite
GeneralStateTests/stTimeConsuming/
for time consuming tests, PR #595 - Moved blockchain specific tests from
GeneralStateTests
toBlockchainTests
, PR #590 - Old unmaintained RPC test scripts in
RPCTests
have been removed, PR #573
- Added
Istanbul
toRetesteth
configuration, PR #638 - Updated
Retesteth
configurations, PR #634 - Default
Retesteth
genesis configurations, PR #625 - Added
Retesteth
configuration forPantheon
client, PR #622 - Autokill
Geth
threads instartGethThreads.sh
, PR #613 - Added fork configurations to
Geth
config, PR #602 - Fixed
BlockchainTests
RPC
issues, PR #594
- More
RLP
invalid tests for non-optimal lengths (seeRLPTests/
), PR #612 - More tests on touching precompiles along
REVERT
usage (seeGeneralStateTests/stRevertTest/*Touch*.json
), PR #580, PR #610 - New
sStore
test with non-zero nonce on collision (seeGeneralStateTests/stSStoreTest/InitCollisionNonZeroNonce.json
), PR #578
- Corrected tests with a missing
expect
section, PR #624 - Refill of all
BlockchainTests/GeneralStateTests/
, PR #621 - Removed post sections with no post conditions, PR #618
- Corrected huge expect sections in state tests
(see
stAttackTest/
, 'stQuadraticComplexity/'), PR #617 - Compressed huge state data in
bcExploitTest
tests, PR #616 - Removed ambiguous test in
BlockchainTests/ValidBlocks/bcMultiChainTest/ChainAtoChainB_blockorder2.json
, PR #615 - Fixed
RevertPrecompiledTouch
test, PR #609 - Converted blockchain specific state tests into
BlockchainTests
, PR #607 - Various test fixes, PR #603
- Fixes and updates to various state tests, PR #599
- Fixed
0x
missing intransaction
->data
inGeneralStateTests
, PR #598 - Removed a test case from
badOpcodes
state tests (seeGeneralStateTests/stBadOpcode/
), PR #592 - Fixed
gasLimit
issue inGeneralStateTests
, PR #590 - Consistently use
0x
prefixes inRLPTests
, PR #587 - Removed underspecified
lotsOfBranches
test (seeBlockchainTests/bcTotalDifficultyTest/lotsOfBranches.json
), PR #579 - Changed
gasUsed
to 0 ingenesisBlockHeader
fordataTx
tests (seeBlockchainTests/bcValidBlockTest/dataTx.json
anddataTx2.json
), PR #577
-
#547 requires your integration to understand the network
ByzantiumToConstantinopleAt5
, which is analogous to existing pseudo networks such asFrontierToHomesteadAt5
andEIP158ToByzantiumAt5
. -
#557 changes the format of the rlp tests, byte strings are now prefixed with "0x"
- #547 added a test for the difficulty changes. This adds the network
ByzantiumToConstantinopleAt5
, which is analogous to existing networks such asFrontierToHomesteadAt5
andEIP158ToByzantiumAt5
.
- #548 Added a test for EXTCODEHASH called on an account created in the same transaction
- #549 added a few more tests for EXTCODEHASH and EXTCODESIZE on accounts created in the same transaction
- #550 Checks that changes to an account's nonce, balance, or storage do not change the result of calling EXTCODEHASH
- #552 Added another EXTCODEHASH test, what if it's run on accounts which have self-destructed?
- #563 Another spectacularly detailed test case of EXTCODEHASH involving recursive calls and oog-induced revert
- #566 checks that EXTCODEHASH returns a different result when the code changes
- #568 adds a test for EXTCODEHASH; what if the contract being hashed self destructed while in the middle of a delegate call?
- #569 calls EXTCODEHASH on an empty contract
- #551 tests for a Constantinople bug the fuzzer found in geth
- #544 adds an RLP test, courtesy of the mana team
- #557 changes the format of the rlp tests, byte strings are now prefixed with "0x"
- #561 changed some of the tests. There were some changes to
testeth
which made the previous tests impossible to regenerate. They were refactored but not in a way which should break any client. - #567 adds a Constantinople test Mana found when they failed to sync with Ropsten
- Added initial test cases for
EXTCODEHASH
EIP-1052, see PR #484 - More
EXTCODEHASH
tests, see PR #544 - New
SSTORE
state tests and blockchain tests where an external call is overwriting/colliding with newSSTORE
gas calculation rules, see PR #535
- New tests to cover cases where the result of an EVM opcode is written to a specified memory range and the result is shorter than the specified range, see PR #538
- Added
.idea
to.gitignore
, see PR #546
Test generation docs have been consolidated and integrated in the central ReadTheDocs testing documentation.
We also updated outdated parts on this doc section (see PR #539), so it should in principle now be possible to follow the guide and end up with a working test creation setup. There might still be some glitches, please let us know or submit a PR on ethereum/tests to if you stumble over something.
Other changes:
- New list with clients using the library in README, see PR #537
EIP-145
(Bitwise shifting): Tests forSAR
,SHL
andSHR
in GeneralStateTests/stShift directory, blockchain tests analogueEIP-1014
(CREATE2
): Various cases covered in GeneralStateTests/stCreate2 directory, blockchain tests analogueEIP-1052
(EXTCODEHASH
): Tests not merged yet, open PR #484EIP-1283
(SSTORE
): Dedicated tests in GeneralStateTests/stSStoreTest directory also covering Ropsten consensus issue cases, blockchain tests analogue, generally refilled state tests with newSSTORE
gas metering rules in PR #511EIP-1234
(difficulty): NewdifficultyConstantinople.json
file and regenerateddifficultyRopsten.json
files in the BasicTests directory, see PR #518
Be aware that the format of BlockchainTests recently changed with the introduction of a new field sealEngine
(values: NoProof
| Ethash
), see related JSON Schema change or BlockchainTest format docs for reference.
This means that you can faster-execute NoProof
based tests skipping block validation. These tests nevertheless doesn't provide reliable values for PoW
-based block header fields any more (mixHash
, nonce
), so make sure that you don't rely on the correctness of these values for the tests to pass.