aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCJentzsch <jentzsch.software@gmail.com>2015-02-14 01:25:47 +0800
committerCJentzsch <jentzsch.software@gmail.com>2015-02-14 01:25:47 +0800
commit7e0e2bb196d3e4139f3221aa44218fd895b6b67f (patch)
treea5395e3fa66e02fc88b51f8d1fa9c3cd042e61e8
parente4eeb566ce2786d88a0ad85a59f63f830bda093a (diff)
downloaddexon-solidity-7e0e2bb196d3e4139f3221aa44218fd895b6b67f.tar.gz
dexon-solidity-7e0e2bb196d3e4139f3221aa44218fd895b6b67f.tar.zst
dexon-solidity-7e0e2bb196d3e4139f3221aa44218fd895b6b67f.zip
add possibility to create bad blocks in fillers
-rw-r--r--blValidBlockTestFiller.json228
-rw-r--r--block.cpp231
-rw-r--r--stSystemOperationsTestFiller.json4
3 files changed, 186 insertions, 277 deletions
diff --git a/blValidBlockTestFiller.json b/blValidBlockTestFiller.json
index d19c8104..db7138b5 100644
--- a/blValidBlockTestFiller.json
+++ b/blValidBlockTestFiller.json
@@ -1,85 +1,8 @@
{
- "diffTooLow" : {
- "genesisBlockHeader" : {
- "bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
- "coinbase" : "0x8888f1f195afa192cfee860698584c030f4c9db1",
- "difficulty" : "1023",
- "extraData" : "42",
- "gasLimit" : "100000",
- "gasUsed" : "0",
- "nonce" : "0x498e88f5c14b0b60d6e14ce9c6cc958cbe16a1df8dd90210e50d2d77562a348d",
- "number" : "0",
- "parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
- "receiptTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "stateRoot" : "0xf99eb1626cfa6db435c0836235942d7ccaa935f1ae247d3f1c21e495685f903a",
- "timestamp" : "0x54c98c81",
- "transactionsTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "uncleHash" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347"
- },
- "pre" : {
- "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
- "balance" : "10000000000",
- "nonce" : "0",
- "code" : "",
- "storage": {}
- }
- },
- "transactions" : [
- {
- "data" : "",
- "gasLimit" : "850",
- "gasPrice" : "1",
- "nonce" : "0",
- "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
- "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
- "value" : "10"
- }
- ],
- "uncleHeaders" : [
- ]
- },
-
- "diff1024" : {
- "genesisBlockHeader" : {
- "bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
- "coinbase" : "0x8888f1f195afa192cfee860698584c030f4c9db1",
- "difficulty" : "1024",
- "extraData" : "42",
- "gasLimit" : "100000",
- "gasUsed" : "0",
- "nonce" : "0x498e88f5c14b0b60d6e14ce9c6cc958cbe16a1df8dd90210e50d2d77562a348d",
- "number" : "0",
- "parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
- "receiptTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "stateRoot" : "0xf99eb1626cfa6db435c0836235942d7ccaa935f1ae247d3f1c21e495685f903a",
- "timestamp" : "0x54c98c81",
- "transactionsTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "uncleHash" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347"
- },
- "pre" : {
- "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
- "balance" : "10000000000",
- "nonce" : "0",
- "code" : "",
- "storage": {}
- }
- },
- "transactions" : [
- {
- "data" : "",
- "gasLimit" : "850",
- "gasPrice" : "1",
- "nonce" : "0",
- "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
- "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
- "value" : "10"
- }
- ],
- "uncleHeaders" : [
- ]
- },
-
- "gasPrice0" : {
+ "log1" : {
+ "blockHeader" : {
+ "number" : "2"
+ },
"genesisBlockHeader" : {
"bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"coinbase" : "0x8888f1f195afa192cfee860698584c030f4c9db1",
@@ -102,162 +25,27 @@
"nonce" : "0",
"code" : "",
"storage": {}
- }
- },
- "transactions" : [
- {
- "data" : "",
- "gasLimit" : "850",
- "gasPrice" : "0",
- "nonce" : "0",
- "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
- "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
- "value" : "10"
- }
- ],
- "uncleHeaders" : [
- ]
- },
-
- "tx" : {
- "genesisBlockHeader" : {
- "bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
- "coinbase" : "0x8888f1f195afa192cfee860698584c030f4c9db1",
- "difficulty" : "10000",
- "extraData" : "42",
- "gasLimit" : "100000",
- "gasUsed" : "0",
- "nonce" : "0x498e88f5c14b0b60d6e14ce9c6cc958cbe16a1df8dd90210e50d2d77562a348d",
- "number" : "0",
- "parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
- "receiptTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "stateRoot" : "0xf99eb1626cfa6db435c0836235942d7ccaa935f1ae247d3f1c21e495685f903a",
- "timestamp" : "0x54c98c81",
- "transactionsTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "uncleHash" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347"
- },
- "pre" : {
- "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
- "balance" : "10000000000",
- "nonce" : "0",
- "code" : "",
- "storage": {}
- }
- },
- "transactions" : [
- {
- "data" : "",
- "gasLimit" : "500",
- "gasPrice" : "10",
- "nonce" : "0",
- "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
- "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
- "value" : "10"
- }
- ],
- "uncleHeaders" : [
- ]
- },
-
- "txOrder" : {
- "genesisBlockHeader" : {
- "bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
- "coinbase" : "0x8888f1f195afa192cfee860698584c030f4c9db1",
- "difficulty" : "10000",
- "extraData" : "42",
- "gasLimit" : "100000",
- "gasUsed" : "0",
- "nonce" : "0x498e88f5c14b0b60d6e14ce9c6cc958cbe16a1df8dd90210e50d2d77562a348d",
- "number" : "0",
- "parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
- "receiptTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "stateRoot" : "0xf99eb1626cfa6db435c0836235942d7ccaa935f1ae247d3f1c21e495685f903a",
- "timestamp" : "0x54c98c81",
- "transactionsTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "uncleHash" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347"
- },
- "pre" : {
- "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
- "balance" : "10000000000",
- "nonce" : "0",
- "code" : "",
- "storage": {}
- }
- },
- "transactions" : [
- {
- "data" : "",
- "gasLimit" : "500",
- "gasPrice" : "10",
- "nonce" : "0",
- "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
- "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
- "value" : "7000000000"
},
- {
- "data" : "",
- "gasLimit" : "500",
- "gasPrice" : "10",
+ "095e7baea6a6c7c4c2dfeb977efac326af552d87" : {
+ "balance" : "100",
"nonce" : "0",
- "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
- "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
- "value" : "8000000000"
- }
- ],
- "uncleHeaders" : [
- ]
- },
-
- "txEqualValue" : {
- "genesisBlockHeader" : {
- "bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
- "coinbase" : "0x8888f1f195afa192cfee860698584c030f4c9db1",
- "difficulty" : "10000",
- "extraData" : "42",
- "gasLimit" : "100000",
- "gasUsed" : "0",
- "nonce" : "0x498e88f5c14b0b60d6e14ce9c6cc958cbe16a1df8dd90210e50d2d77562a348d",
- "number" : "0",
- "parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
- "receiptTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "stateRoot" : "0xf99eb1626cfa6db435c0836235942d7ccaa935f1ae247d3f1c21e495685f903a",
- "timestamp" : "0x54c98c81",
- "transactionsTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
- "uncleHash" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347"
- },
- "pre" : {
- "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
- "balance" : "10000000000",
- "nonce" : "0",
- "code" : "",
+ "code" : "{ (MSTORE 0 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff) (LOG1 0 32 0) }",
"storage": {}
}
},
"transactions" : [
{
"data" : "",
- "gasLimit" : "500",
+ "gasLimit" : "5000",
"gasPrice" : "10",
"nonce" : "0",
"secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
"to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
"value" : "5000000000"
- },
- {
- "data" : "",
- "gasLimit" : "500",
- "gasPrice" : "9",
- "nonce" : "0",
- "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
- "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
- "value" : "5000000000"
}
],
"uncleHeaders" : [
]
}
-
-
-
}
diff --git a/block.cpp b/block.cpp
index 2d44e8d7..4d1f5acc 100644
--- a/block.cpp
+++ b/block.cpp
@@ -1,18 +1,18 @@
/*
- This file is part of cpp-ethereum.
+ This file is part of cpp-ethereum.
- cpp-ethereum is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
+ cpp-ethereum is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
- cpp-ethereum is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
+ cpp-ethereum is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>.
+ You should have received a copy of the GNU General Public License
+ along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>.
*/
/** @file block.cpp
* @author Christoph Jentzsch <cj@ethdev.com>
@@ -32,60 +32,60 @@ namespace dev { namespace test {
bytes createBlockRLPFromFields(mObject& _tObj)
{
- RLPStream rlpStream;
- rlpStream.appendList(_tObj.size());
+ RLPStream rlpStream;
+ rlpStream.appendList(_tObj.size());
- if (_tObj.count("parentHash") > 0)
- rlpStream << importByteArray(_tObj["parentHash"].get_str());
+ if (_tObj.count("parentHash") > 0)
+ rlpStream << importByteArray(_tObj["parentHash"].get_str());
- if (_tObj.count("uncleHash") > 0)
- rlpStream << importByteArray(_tObj["uncleHash"].get_str());
+ if (_tObj.count("uncleHash") > 0)
+ rlpStream << importByteArray(_tObj["uncleHash"].get_str());
- if (_tObj.count("coinbase") > 0)
- rlpStream << importByteArray(_tObj["coinbase"].get_str());
+ if (_tObj.count("coinbase") > 0)
+ rlpStream << importByteArray(_tObj["coinbase"].get_str());
- if (_tObj.count("stateRoot") > 0)
- rlpStream << importByteArray(_tObj["stateRoot"].get_str());
+ if (_tObj.count("stateRoot") > 0)
+ rlpStream << importByteArray(_tObj["stateRoot"].get_str());
- if (_tObj.count("transactionsTrie") > 0)
- rlpStream << importByteArray(_tObj["transactionsTrie"].get_str());
+ if (_tObj.count("transactionsTrie") > 0)
+ rlpStream << importByteArray(_tObj["transactionsTrie"].get_str());
- if (_tObj.count("receiptTrie") > 0)
- rlpStream << importByteArray(_tObj["receiptTrie"].get_str());
+ if (_tObj.count("receiptTrie") > 0)
+ rlpStream << importByteArray(_tObj["receiptTrie"].get_str());
- if (_tObj.count("bloom") > 0)
- rlpStream << importByteArray(_tObj["bloom"].get_str());
+ if (_tObj.count("bloom") > 0)
+ rlpStream << importByteArray(_tObj["bloom"].get_str());
- if (_tObj.count("difficulty") > 0)
- rlpStream << bigint(_tObj["difficulty"].get_str());
+ if (_tObj.count("difficulty") > 0)
+ rlpStream << bigint(_tObj["difficulty"].get_str());
- if (_tObj.count("number") > 0)
- rlpStream << bigint(_tObj["number"].get_str());
+ if (_tObj.count("number") > 0)
+ rlpStream << bigint(_tObj["number"].get_str());
- if (_tObj.count("gasLimit") > 0)
- rlpStream << bigint(_tObj["gasLimit"].get_str());
+ if (_tObj.count("gasLimit") > 0)
+ rlpStream << bigint(_tObj["gasLimit"].get_str());
- if (_tObj.count("gasUsed") > 0)
- rlpStream << bigint(_tObj["gasUsed"].get_str());
+ if (_tObj.count("gasUsed") > 0)
+ rlpStream << bigint(_tObj["gasUsed"].get_str());
- if (_tObj.count("timestamp") > 0)
- rlpStream << bigint(_tObj["timestamp"].get_str());
+ if (_tObj.count("timestamp") > 0)
+ rlpStream << bigint(_tObj["timestamp"].get_str());
- if (_tObj.count("extraData") > 0)
- rlpStream << importByteArray(_tObj["extraData"].get_str());
+ if (_tObj.count("extraData") > 0)
+ rlpStream << importByteArray(_tObj["extraData"].get_str());
- if (_tObj.count("nonce") > 0)
- rlpStream << importByteArray(_tObj["nonce"].get_str());
+ if (_tObj.count("nonce") > 0)
+ rlpStream << importByteArray(_tObj["nonce"].get_str());
- return rlpStream.out();
+ return rlpStream.out();
}
void doBlockTests(json_spirit::mValue& _v, bool _fillin)
{
- for (auto& i: _v.get_obj())
- {
- cerr << i.first << endl;
- mObject& o = i.second.get_obj();
+ for (auto& i: _v.get_obj())
+ {
+ cerr << i.first << endl;
+ mObject& o = i.second.get_obj();
BOOST_REQUIRE(o.count("genesisBlockHeader") > 0);
cout << "construc genesis\n";
@@ -197,9 +197,12 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
// write valid txs
cout << "number of valid txs: " << txs.transactions().size();
mArray txArray;
+ Transactions txList;
for (auto const& txi: txs.transactions())
{
+ cout << "AHA0" << endl;
Transaction tx(txi.second, CheckSignature::Sender);
+ txList.push_back(tx);
mObject txObject;
txObject["nonce"] = toString(tx.nonce());
txObject["data"] = toHex(tx.data());
@@ -210,10 +213,11 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
txObject["v"] = to_string(tx.signature().v + 27);
txObject["to"] = toString(tx.receiveAddress());
txObject["value"] = toString(tx.value());
+ cout << "AHA0.5" << endl;
txArray.push_back(txObject);
}
-
+ cout << "AHA1" << endl;
o["transactions"] = txArray;
o["rlp"] = "0x" + toHex(state.blockData());
@@ -237,12 +241,125 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
oBlockHeader["extraData"] = toHex(current_BlockHeader.extraData);
oBlockHeader["nonce"] = toString(current_BlockHeader.nonce);
- o["blockHeader"] = oBlockHeader;
- // write uncle list
- mArray aUncleList; // as of now, our parent is always the genesis block, so we can not have uncles.
- o["uncleHeaders"] = aUncleList;
+ // overwrite (wrong) data from blockheader in filler" << endl;
+
+ if (o.count("blockHeader") > 0)
+ {
+ if (o["blockHeader"].get_obj().size() != 14)
+ {
+
+ BlockInfo tmp = current_BlockHeader;
+
+ if (o["blockHeader"].get_obj().count("parentHash") > 0)
+ tmp.parentHash = h256(o["blockHeader"].get_obj()["parentHash"].get_str());
+
+ if (o["blockHeader"].get_obj().count("sha3Uncles") > 0)
+ tmp.sha3Uncles = h256(o["blockHeader"].get_obj()["uncleHash"].get_str());
+
+ if (o["blockHeader"].get_obj().count("coinbase") > 0)
+ tmp.coinbaseAddress = Address(o["blockHeader"].get_obj()["coinbase"].get_str());
+
+ if (o["blockHeader"].get_obj().count("stateRoot") > 0)
+ tmp.stateRoot = h256(o["blockHeader"].get_obj()["stateRoot"].get_str());
+
+ if (o["blockHeader"].get_obj().count("transactionsTrie") > 0)
+ tmp.transactionsRoot = h256(o["blockHeader"].get_obj()["transactionsTrie"].get_str());
+
+ if (o["blockHeader"].get_obj().count("receiptTrie") > 0)
+ tmp.receiptsRoot = h256(o["blockHeader"].get_obj()["receiptTrie"].get_str());
+
+ if (o["blockHeader"].get_obj().count("bloom") > 0)
+ tmp.logBloom = LogBloom(o["blockHeader"].get_obj()["bloom"].get_str());
+
+ if (o["blockHeader"].get_obj().count("difficulty") > 0)
+ tmp.difficulty = toInt(o["blockHeader"].get_obj()["difficulty"]);
+
+ if (o["blockHeader"].get_obj().count("number") > 0)
+ tmp.number = toInt(o["blockHeader"].get_obj()["number"]);
+
+ if (o["blockHeader"].get_obj().count("gasLimit") > 0)
+ tmp.gasLimit = toInt(o["blockHeader"].get_obj()["gasLimit"]);
+
+ if (o["blockHeader"].get_obj().count("gasUsed") > 0)
+ tmp.gasUsed = toInt(o["blockHeader"].get_obj()["gasUsed"]);
+
+ if (o["blockHeader"].get_obj().count("timestamp") > 0)
+ tmp.timestamp = toInt(o["blockHeader"].get_obj()["timestamp"]);
+
+ if (o["blockHeader"].get_obj().count("extraData") > 0)
+ tmp.extraData = importByteArray(o["blockHeader"].get_obj()["extraData"].get_str());
+
+ // find new valid nonce
+
+ if (tmp != current_BlockHeader)
+ {
+ current_BlockHeader = tmp;
+ cout << "new header!\n";
+ ProofOfWork pow;
+ MineInfo ret;
+ while (!ProofOfWork::verify(current_BlockHeader.headerHash(WithoutNonce), current_BlockHeader.nonce, current_BlockHeader.difficulty))
+ tie(ret, current_BlockHeader.nonce) = pow.mine(current_BlockHeader.headerHash(WithoutNonce), current_BlockHeader.difficulty, 10000, true, true);
+ oBlockHeader["nonce"] = toString(current_BlockHeader.nonce);
+ }
+ }
+ else
+ {
+ // take the blockheader as is
+ const bytes c_blockRLP = createBlockRLPFromFields(o["genesisBlockHeader"].get_obj());
+ const RLP c_bRLP(c_blockRLP);
+ current_BlockHeader.populateFromHeader(c_bRLP, false);
+ }
+ }
+
+ //txs:
+
+ RLPStream txStream;
+ txStream.appendList(txList.size());
+ for (unsigned i = 0; i < txList.size(); ++i)
+ {
+ RLPStream txrlp;
+ txList[i].streamRLP(txrlp);
+ txStream.appendRaw(txrlp.out());
+ }
+
+ cout << "create block:" << endl;
+
+ RLPStream rlpStream2;
+ current_BlockHeader.streamRLP(rlpStream2, WithNonce);
+
+ RLPStream block2(3);
+ block2.appendRaw(rlpStream2.out());
+ block2.appendRaw(txStream.out());
+ block2.appendRaw(RLPEmptyList);
+
+ if (sha3(RLP(state.blockData())[0].data()) != sha3(RLP(block2.out())[0].data()))
+ cout << "block 0 wrong" << endl;
+
+ if (sha3(RLP(state.blockData())[1].data()) != sha3(RLP(block2.out())[1].data()))
+ cout << "block 1 wrong" << endl;
+
+ if (sha3(RLP(state.blockData())[2].data()) != sha3(RLP(block2.out())[2].data()))
+ cout << "block 2 wrong" << endl;
+
+
+ if (sha3(state.blockData()) != sha3(block2.out()))
+ {
+ cout << "blocks do not match!" << endl;
+ o["rlp"] = "0x" + toHex(block2.out());
+ o.erase(o.find("blockHeader"));
+ o.erase(o.find("uncleHeaders"));
+ o.erase(o.find("transactions"));
+ }
+ else
+ {
+ o["blockHeader"] = oBlockHeader;
+
+ // write uncle list
+ mArray aUncleList; // as of now, our parent is always the genesis block, so we can not have uncles.
+ o["uncleHeaders"] = aUncleList;
+ }
}
else
@@ -254,13 +371,14 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
bc.import(blockRLP, state.db());
state.sync(bc);
}
- // if exception is thrown, RLP is invalid and no blockHeader, Transaction list, or Uncle list should be given
+ // if exception is thrown, RLP is invalid and no blockHeader, Transaction list, or Uncle list should be given
catch (Exception const& _e)
{
cnote << "state sync or block import did throw an exception: " << diagnostic_information(_e);
BOOST_CHECK(o.count("blockHeader") == 0);
BOOST_CHECK(o.count("transactions") == 0);
BOOST_CHECK(o.count("uncleHeaders") == 0);
+ return;
}
catch (std::exception const& _e)
{
@@ -268,6 +386,7 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
BOOST_CHECK(o.count("blockHeader") == 0);
BOOST_CHECK(o.count("transactions") == 0);
BOOST_CHECK(o.count("uncleHeaders") == 0);
+ return;
}
catch(...)
{
@@ -275,8 +394,10 @@ void doBlockTests(json_spirit::mValue& _v, bool _fillin)
BOOST_CHECK(o.count("blockHeader") == 0);
BOOST_CHECK(o.count("transactions") == 0);
BOOST_CHECK(o.count("uncleHeaders") == 0);
+ return;
}
-
+ cout << "valid block header\n";
+ //cout << "block number: " <<
BOOST_REQUIRE(o.count("blockHeader") > 0);
mObject tObj = o["blockHeader"].get_obj();
@@ -388,12 +509,12 @@ BOOST_AUTO_TEST_SUITE(BlockTests)
BOOST_AUTO_TEST_CASE(blValidBlockTest)
{
- dev::test::executeTests("blValidBlockTest", "/BlockTests", dev::test::doBlockTests);
+ dev::test::executeTests("blValidBlockTest", "/BlockTests", dev::test::doBlockTests);
}
BOOST_AUTO_TEST_CASE(userDefinedFileBl)
{
- dev::test::userDefinedTest("--bltest", dev::test::doBlockTests);
+ dev::test::userDefinedTest("--bltest", dev::test::doBlockTests);
}
BOOST_AUTO_TEST_SUITE_END()
diff --git a/stSystemOperationsTestFiller.json b/stSystemOperationsTestFiller.json
index eae39364..9f47b2fe 100644
--- a/stSystemOperationsTestFiller.json
+++ b/stSystemOperationsTestFiller.json
@@ -81,13 +81,13 @@
"pre" : {
"095e7baea6a6c7c4c2dfeb977efac326af552d87" : {
"balance" : "1000000000000000000",
- "nonce" : 0,
+ "nonce" : "0",
"code" : "0x444242424245434253f0",
"storage": {}
},
"a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
"balance" : "1000000000000000000",
- "nonce" : 0,
+ "nonce" : "0",
"code" : "",
"storage": {}
}