-
Notifications
You must be signed in to change notification settings - Fork 323
Creating a GeneralStateTest (Yoichi's attempt, rough record)
I was going to test "RETURNDATACOPY" in the beginning should copy zero's into the memory.
I checked out https://github.com/ethereum/cpp-ethereum/pull/4062 at ~/src/cpp-ethereum
, and
mkdir -p ~/src/cpp-ethereum/build
cd ~/src/cpp-ethereum/build
cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=ON -DCMAKE_BUILD_TYPE=Debug -DCMAKE_CXX_COMPILER_LAUNCHER=ccache -DVMTRACE=1 ..
make
This PR was still work in progress, but I thought it would perform correctly for this particular test case.
I also checked out https://github.com/ethereum/tests in ~/src/tests
(develop
branch).
I looked at ~/src/tests/src/GeneralStateTestsFilter
.
stAttackTest/ stChangedEIP150/ stEIP158Specific/ stMemoryStressTest/ stRecursiveCreate/ stSystemOperationsTest/
stBoundsTest/ stCodeSizeLimit/ stExample/ stMemoryTest/ stRefundTest/ stTransactionTest/
stCallCodes/ stCreateTest/ stHomesteadSpecific/ stNonZeroCallsTest/ stRevertTest/ stTransitionTest/
stCallCreateCallCodeTest/ stDelegatecallTestHomestead/ stInitCodeTest/ stPreCompiledContracts/ stSolidityTest/ stWalletTest/
stCallDelegateCodesCallCodeHomestead/ stEIP150singleCodeGasPrices/ stLogTests/ stQuadraticComplexityTest/ stSpecialTest/ stZeroCallsRevert/
stCallDelegateCodesHomestead/ stEIP150Specific/ stMemExpandingEIP150Calls/ stRandom/ stStackTests/ stZeroCallsTest/
Maybe I need a new directory stReturnDataTest
.
I created a file ~/src/tests/src/GeneralTestsFilter/stReturnDataTest/returndatacopy_initialFilter.json
.
I took a test filter mstore_dejavu.json
and started working from there.
I thought I should fill the memory with some random data first, and then perform "RETURNDATACOPY". Also, the result of the RETURNDATACOPY should be visible somewhere in the state, so I have to MLOAD and SSTORE the result of the RETURNDATACOPY.
The program looks like this
; hex description
;; store some non-zero word into memory [0..31]
30 ADDRESS
6000 PUSH1 [0]
52 MSTORE
;; RETURNDATACOPY should copy the first word into memory [0..31]
6020 PUSH1 [32]
6000 PUSH1 [0]
6000 PUSH1 [0]
0e RETURNDATACOPY
;; load memory[0..31] onto stack
6000 PUSH1 [0]
51 MLOAD
;; store the topmost stack into storage [0]
6000 PUSH1 [0]
55 SSTORE
;; an implicit `STOP` follows.
So, the callee should contain the code
0x306000526020600060000e600051600055
And then I was told to use LLL and the code became
(MSTORE 0 0x112233445566778899aabbccddeeff) (RETURNDATACOPY 32 0 0) (SSTORE 0 (MLOAD 0))
I expect the storage index 0 to be changed into zero. So, in the pre-state, the storage index 0 should contain something non-zero.
So, this account should be called.
"0x0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : {
"balance" : "0x0de0b6b3a7640000",
"code" : "0x306000526020600060000e600051600055",
"nonce" : "0x00",
"storage" : {
"0x00" : "0x01"
}
},
The expectation is that: if it's metropolis, the storage at index 0 should change into zero. If it's before metropolis, the storage at index 0 should remain 1.
"expect" : [
{ "indexes" : {
"data" : -1,
"gas" : -1,
"value" : -1
},
"network" : ["EIP150", "EIP158", "Frontier", "Homestead"],
"result" : {
"0x0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : {
"storage" : {
"0x00" : "0x01"
}
}
}
},
{ "indexes" : {
"data" : -1,
"gas" : -1,
"value" : -1
},
"network" : ["Metropolis"],
"result" : {
"0x0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : {
"storage" : {
"0x00" : "0x00"
}
}
}
}
],
Above resulted in a filter file in this commit https://github.com/pirapira/tests/commit/b9b9141b3cdd9f72dc5b59bd00f04339290df10c
I created a branch returndata_test
from returndata
in cpp-ethereum
.
I added a line after https://github.com/ethereum/cpp-ethereum/blob/develop/test/tools/jsontests/StateTests.cpp#L180
Compiled cpp-ethereum, and ran
ETHEREUM_TEST_PATH="../../tests" test/testeth -t StateTestsGeneral/stReturnDataTest -- --filltests --checkstate
file a PR to cpp-ethereum?
file a PR to test? or this is not necessary?