diff options
author | Yoichi Hirai <i@yoichihirai.com> | 2018-04-23 16:36:18 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-04-23 16:36:18 +0800 |
commit | 93d8efee5da17e95d88f816e40666c04a8bff636 (patch) | |
tree | 68eb3978c5ddc0c88b5a41ca6e4759c0e13d113c /src/GeneralStateTestsFiller | |
parent | c7cbda682c4fd9a259c2e561a38196bdbb275073 (diff) | |
parent | 4e8bc0fce050185a0dca0404481e7a93ca26558b (diff) | |
download | tangerine-tests-93d8efee5da17e95d88f816e40666c04a8bff636.tar tangerine-tests-93d8efee5da17e95d88f816e40666c04a8bff636.tar.gz tangerine-tests-93d8efee5da17e95d88f816e40666c04a8bff636.tar.bz2 tangerine-tests-93d8efee5da17e95d88f816e40666c04a8bff636.tar.lz tangerine-tests-93d8efee5da17e95d88f816e40666c04a8bff636.tar.xz tangerine-tests-93d8efee5da17e95d88f816e40666c04a8bff636.tar.zst tangerine-tests-93d8efee5da17e95d88f816e40666c04a8bff636.zip |
Merge pull request #455 from pirapira/self-destruct-case2
The same contract performs selfdestruct twice (part 2/3)
Diffstat (limited to 'src/GeneralStateTestsFiller')
-rw-r--r-- | src/GeneralStateTestsFiller/stSystemOperationsTest/doubleSelfdestructTest2Filler.yml | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/src/GeneralStateTestsFiller/stSystemOperationsTest/doubleSelfdestructTest2Filler.yml b/src/GeneralStateTestsFiller/stSystemOperationsTest/doubleSelfdestructTest2Filler.yml new file mode 100644 index 000000000..38cb3d96a --- /dev/null +++ b/src/GeneralStateTestsFiller/stSystemOperationsTest/doubleSelfdestructTest2Filler.yml @@ -0,0 +1,67 @@ +doubleSelfdestructTest2: + _info: + comment: | + The second test case requested here https://github.com/ethereum/tests/issues/431#issue-306081539 . + Invoked Solidity 0.4.21 with solc --bin-runtime --optimize + contract DoubleSelfdestructTest2 { + address constant B = 0x3; + function remoteSelfdestruct() external { + selfdestruct(this); + } + function() external payable { + this.remoteSelfdestruct(); + selfdestruct(B); + } + } + The version of Solidity emits code that always enter OOG for Homestead and Frontier. So no new accounts + are created for Homestead and Frontier. EIP158 changes the behavior of zero-amount transfer so that no new accounts are created. + This leaves EIP150 as a special case. + env: + currentCoinbase: 2adc25665018aa1fe0e6bc666dac8fc2697ff9ba + currentDifficulty: '0x20000' + currentGasLimit: '10000000000' + currentNumber: '1' + currentTimestamp: '1000' + previousHash: 5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6 + expect: + - indexes: + data: !!int -1 + gas: !!int -1 + value: !!int -1 + network: + - '<EIP150' + - '>EIP150' + result: + '0000000000000000000000000000000000000003': + shouldnotexist: '1' + - indexes: + data: !!int -1 + gas: !!int -1 + value: !!int -1 + network: + - 'EIP150' + result: + '0000000000000000000000000000000000000003': + balance: '0' + pre: + 095e7baea6a6c7c4c2dfeb977efac326af552d87: + balance: '1000000000000000000' + code: '0x606060405260043610603e5763ffffffff7c01000000000000000000000000000000000000000000000000000000006000350416632c3f2bf3811460b4575b3073ffffffffffffffffffffffffffffffffffffffff16632c3f2bf36040518163ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401600060405180830381600087803b151560a057600080fd5b5af1151560ac57600080fd5b506003915050ff5b341560be57600080fd5b60c460c6565b005b3073ffffffffffffffffffffffffffffffffffffffff16ff00a165627a7a7230582004c215a78ad0add6ec7f9e2488a74efe60734d3dfe25da652ef8ac9dae892c4a0029' + nonce: '0' + storage: {} + a94f5374fce5edbc8e2a8697c15331677e6ebf0b: + balance: '1000000000000000000' + code: '' + nonce: '0' + storage: {} + transaction: + data: + - '' + gasLimit: + - '1000000000' + gasPrice: '0' + nonce: '0' + secretKey: 45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8 + to: 095e7baea6a6c7c4c2dfeb977efac326af552d87 + value: + - '100000' |