Browse Source

add EqualUncleInTwoDifferentBlocks test

Conflicts:
	test/libethereum/blockchain.cpp
cl-refactor
CJentzsch 10 years ago
parent
commit
fddc206d84
  1. 123
      test/libethereum/BlockTestsFiller/bcUncleTestFiller.json
  2. 67
      test/libethereum/blockchain.cpp

123
test/libethereum/BlockTestsFiller/bcUncleTestFiller.json

@ -151,6 +151,10 @@
] ]
}, },
{ {
"blockHeader" : {
"bruncle" : "1"
},
"transactions" : [ "transactions" : [
{ {
"data" : "", "data" : "",
@ -2562,5 +2566,124 @@
] ]
} }
] ]
},
"EqualUncleInTwoDifferentBlocks" : {
"genesisBlockHeader" : {
"bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"coinbase" : "0x8888f1f195afa192cfee860698584c030f4c9db1",
"difficulty" : "131072",
"extraData" : "0x42",
"gasLimit" : "3141592",
"gasUsed" : "0",
"number" : "0",
"parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
"receiptTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
"stateRoot" : "0xf99eb1626cfa6db435c0836235942d7ccaa935f1ae247d3f1c21e495685f903a",
"timestamp" : "0x54c98c81",
"mixHash" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
"nonce" : "0x0102030405060708",
"transactionsTrie" : "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
"uncleHash" : "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347"
},
"expect" : {
"095e7baea6a6c7c4c2dfeb977efac326af552d87" : {
"balance" : "20"
},
"a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
"nonce" : "2"
}
},
"pre" : {
"a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
"balance" : "10000000000000",
"nonce" : "0",
"code" : "",
"storage": {}
}
},
"blocks" : [
{
"transactions" : [
{
"data" : "",
"gasLimit" : "314159",
"gasPrice" : "1",
"nonce" : "0",
"secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
"to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
"value" : "10"
}
],
"uncleHeaders" : [
]
},
{
"transactions" : [
{
"data" : "",
"gasLimit" : "314159",
"gasPrice" : "1",
"nonce" : "1",
"secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
"to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
"value" : "10"
}
],
"uncleHeaders" : [
]
},
{
"transactions" : [
{
"data" : "",
"gasLimit" : "314159",
"gasPrice" : "1",
"nonce" : "2",
"secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
"to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
"value" : "10"
}
],
"uncleHeaders" : [
{
"bloom" : "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"coinbase" : "bcde5374fce5edbc8e2a8697c15331677e6ebf0b",
"difficulty" : "131072",
"extraData" : "0x",
"gasLimit" : "3141592",
"gasUsed" : "0",
"hash" : "9de9879b6a81d1b6c4993c63c90a3c9d1e775f14572694778e828bc64972ae04",
"mixHash" : "b557f905d29ed0fca99d65d0adcce698dee97cf72a13c7cd8d7a7826b8eee770",
"nonce" : "18a524c1790fa83b",
"number" : "2",
"parentHash" : "6134fc6b5d99ee03c4aab1592640f6f9dcbc850668d75d631aee34989b938fae",
"receiptTrie" : "56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
"stateRoot" : "ff640b30d613c35dad43e3693329e1b1ee6350f989cf46a288025a1cbfdab9cd",
"timestamp" : "0x54c98c82",
"transactionsTrie" : "56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
"uncleHash" : "1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347"
}
]
},
{
"transactions" : [
{
"data" : "",
"gasLimit" : "314159",
"gasPrice" : "1",
"nonce" : "2",
"secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
"to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
"value" : "10"
}
],
"uncleHeaders" : [
{
"sameAsPreviousBlockUncle" : "3"
}
]
}
]
} }
} }

67
test/libethereum/blockchain.cpp

@ -33,6 +33,9 @@ using namespace dev::eth;
namespace dev { namespace test { namespace dev { namespace test {
typedef std::vector<bytes> uncleList;
typedef std::pair<bytes, uncleList> blockSet;
BlockInfo constructBlock(mObject& _o); BlockInfo constructBlock(mObject& _o);
bytes createBlockRLPFromFields(mObject& _tObj); bytes createBlockRLPFromFields(mObject& _tObj);
RLPStream createFullBlockFromHeader(BlockInfo const& _bi, bytes const& _txs = RLPEmptyList, bytes const& _uncles = RLPEmptyList); RLPStream createFullBlockFromHeader(BlockInfo const& _bi, bytes const& _txs = RLPEmptyList, bytes const& _uncles = RLPEmptyList);
@ -42,7 +45,7 @@ mObject writeBlockHeaderToJson(mObject& _o, BlockInfo const& _bi);
void overwriteBlockHeader(BlockInfo& _current_BlockHeader, mObject& _blObj); void overwriteBlockHeader(BlockInfo& _current_BlockHeader, mObject& _blObj);
BlockInfo constructBlock(mObject& _o); BlockInfo constructBlock(mObject& _o);
void updatePoW(BlockInfo& _bi); void updatePoW(BlockInfo& _bi);
mArray importUncles(mObject const& blObj, vector<BlockInfo>& vBiUncles, vector<BlockInfo> const& vBiBlocks); mArray importUncles(mObject const& _blObj, vector<BlockInfo>& _vBiUncles, vector<BlockInfo> const& _vBiBlocks, std::vector<blockSet> _blockSet);
void doBlockchainTests(json_spirit::mValue& _v, bool _fillin) void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
{ {
@ -65,8 +68,6 @@ void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
State trueState(OverlayDB(State::openDB(td_stateDB_tmp.path())), BaseState::Empty, biGenesisBlock.coinbaseAddress); State trueState(OverlayDB(State::openDB(td_stateDB_tmp.path())), BaseState::Empty, biGenesisBlock.coinbaseAddress);
//Imported blocks from the start //Imported blocks from the start
typedef std::vector<bytes> uncleList;
typedef std::pair<bytes, uncleList> blockSet;
std::vector<blockSet> blockSets; std::vector<blockSet> blockSets;
importer.importState(o["pre"].get_obj(), trueState); importer.importState(o["pre"].get_obj(), trueState);
@ -138,7 +139,6 @@ void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
bc.sync(uncleQueue, state.db(), 4); bc.sync(uncleQueue, state.db(), 4);
bc.attemptImport(block, state.db()); bc.attemptImport(block, state.db());
vBiBlocks.push_back(BlockInfo(block)); vBiBlocks.push_back(BlockInfo(block));
state.sync(bc); state.sync(bc);
} }
@ -156,7 +156,7 @@ void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
//get uncles //get uncles
vector<BlockInfo> vBiUncles; vector<BlockInfo> vBiUncles;
blObj["uncleHeaders"] = importUncles(blObj, vBiUncles, vBiBlocks); blObj["uncleHeaders"] = importUncles(blObj, vBiUncles, vBiBlocks, blockSets);
BlockQueue uncleBlockQueue; BlockQueue uncleBlockQueue;
uncleList uncleBlockQueueList; uncleList uncleBlockQueueList;
@ -176,7 +176,6 @@ void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
cnote << "error in importing uncle! This produces an invalid block (May be by purpose for testing)."; cnote << "error in importing uncle! This produces an invalid block (May be by purpose for testing).";
} }
} }
bc.sync(uncleBlockQueue, state.db(), 4); bc.sync(uncleBlockQueue, state.db(), 4);
state.commitToMine(bc); state.commitToMine(bc);
@ -216,6 +215,12 @@ void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
uncleStream.appendRaw(uncleRlp.out()); uncleStream.appendRaw(uncleRlp.out());
} }
if (blObj.count("blockHeader"))
overwriteBlockHeader(current_BlockHeader, blObj);
if (blObj.count("blockHeader") && blObj["blockHeader"].get_obj().count("bruncle"))
current_BlockHeader.populateFromParent(vBiBlocks[vBiBlocks.size() -1]);
if (vBiUncles.size()) if (vBiUncles.size())
{ {
// update unclehash in case of invalid uncles // update unclehash in case of invalid uncles
@ -223,9 +228,6 @@ void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
updatePoW(current_BlockHeader); updatePoW(current_BlockHeader);
} }
if (blObj.count("blockHeader"))
overwriteBlockHeader(current_BlockHeader, blObj);
// write block header // write block header
mObject oBlockHeader; mObject oBlockHeader;
writeBlockHeaderToJson(oBlockHeader, current_BlockHeader); writeBlockHeaderToJson(oBlockHeader, current_BlockHeader);
@ -496,36 +498,48 @@ void doBlockchainTests(json_spirit::mValue& _v, bool _fillin)
// helping functions // helping functions
mArray importUncles(mObject const& blObj, vector<BlockInfo>& vBiUncles, vector<BlockInfo> const& vBiBlocks) mArray importUncles(mObject const& _blObj, vector<BlockInfo>& _vBiUncles, vector<BlockInfo> const& _vBiBlocks, std::vector<blockSet> _blockSet)
{ {
// write uncle list // write uncle list
mArray aUncleList; mArray aUncleList;
mObject uncleHeaderObj_pre; mObject uncleHeaderObj_pre;
for (auto const& uHObj: blObj.at("uncleHeaders").get_array()) for (auto const& uHObj: _blObj.at("uncleHeaders").get_array())
{ {
mObject uncleHeaderObj = uHObj.get_obj(); mObject uncleHeaderObj = uHObj.get_obj();
if (uncleHeaderObj.count("sameAsPreviousSibling")) if (uncleHeaderObj.count("sameAsPreviousSibling"))
{ {
writeBlockHeaderToJson(uncleHeaderObj_pre, vBiUncles[vBiUncles.size()-1]); writeBlockHeaderToJson(uncleHeaderObj_pre, _vBiUncles[_vBiUncles.size()-1]);
aUncleList.push_back(uncleHeaderObj_pre); aUncleList.push_back(uncleHeaderObj_pre);
vBiUncles.push_back(vBiUncles[vBiUncles.size()-1]); _vBiUncles.push_back(_vBiUncles[_vBiUncles.size()-1]);
uncleHeaderObj_pre = uncleHeaderObj; uncleHeaderObj_pre = uncleHeaderObj;
continue; continue;
} }
if (uncleHeaderObj.count("sameAsBlock")) if (uncleHeaderObj.count("sameAsBlock"))
{ {
size_t number = (size_t)toInt(uncleHeaderObj["sameAsBlock"]); size_t number = (size_t)toInt(uncleHeaderObj["sameAsBlock"]);
uncleHeaderObj.erase("sameAsBlock"); uncleHeaderObj.erase("sameAsBlock");
BlockInfo currentUncle = vBiBlocks[number]; BlockInfo currentUncle = _vBiBlocks[number];
writeBlockHeaderToJson(uncleHeaderObj, currentUncle); writeBlockHeaderToJson(uncleHeaderObj, currentUncle);
aUncleList.push_back(uncleHeaderObj); aUncleList.push_back(uncleHeaderObj);
vBiUncles.push_back(currentUncle); _vBiUncles.push_back(currentUncle);
uncleHeaderObj_pre = uncleHeaderObj; uncleHeaderObj_pre = uncleHeaderObj;
continue; continue;
} }
if (uncleHeaderObj.count("sameAsPreviousBlockUncle"))
{
bytes uncleRLP = _blockSet[(size_t)toInt(uncleHeaderObj["sameAsPreviousBlockUncle"])].second[0];
BlockInfo uncleHeader(uncleRLP);
writeBlockHeaderToJson(uncleHeaderObj, uncleHeader);
aUncleList.push_back(uncleHeaderObj);
_vBiUncles.push_back(uncleHeader);
uncleHeaderObj_pre = uncleHeaderObj;
continue;
}
string overwrite = "false"; string overwrite = "false";
if (uncleHeaderObj.count("overwriteAndRedoPoW")) if (uncleHeaderObj.count("overwriteAndRedoPoW"))
{ {
@ -538,12 +552,12 @@ mArray importUncles(mObject const& blObj, vector<BlockInfo>& vBiUncles, vector<B
// make uncle header valid // make uncle header valid
uncleBlockFromFields.timestamp = (u256)time(0); uncleBlockFromFields.timestamp = (u256)time(0);
cnote << "uncle block n = " << toString(uncleBlockFromFields.number); cnote << "uncle block n = " << toString(uncleBlockFromFields.number);
if (vBiBlocks.size() > 2) if (_vBiBlocks.size() > 2)
{ {
if (uncleBlockFromFields.number - 1 < vBiBlocks.size()) if (uncleBlockFromFields.number - 1 < _vBiBlocks.size())
uncleBlockFromFields.populateFromParent(vBiBlocks[(size_t)uncleBlockFromFields.number - 1]); uncleBlockFromFields.populateFromParent(_vBiBlocks[(size_t)uncleBlockFromFields.number - 1]);
else else
uncleBlockFromFields.populateFromParent(vBiBlocks[vBiBlocks.size() - 2]); uncleBlockFromFields.populateFromParent(_vBiBlocks[_vBiBlocks.size() - 2]);
} }
else else
continue; continue;
@ -557,12 +571,12 @@ mArray importUncles(mObject const& blObj, vector<BlockInfo>& vBiUncles, vector<B
uncleBlockFromFields.stateRoot = overwrite == "stateRoot" ? h256(uncleHeaderObj["stateRoot"].get_str()) : uncleBlockFromFields.stateRoot; uncleBlockFromFields.stateRoot = overwrite == "stateRoot" ? h256(uncleHeaderObj["stateRoot"].get_str()) : uncleBlockFromFields.stateRoot;
if (overwrite == "parentHashIsBlocksParent") if (overwrite == "parentHashIsBlocksParent")
uncleBlockFromFields.populateFromParent(vBiBlocks[vBiBlocks.size() - 1]); uncleBlockFromFields.populateFromParent(_vBiBlocks[_vBiBlocks.size() - 1]);
if (overwrite == "timestamp") if (overwrite == "timestamp")
{ {
uncleBlockFromFields.timestamp = toInt(uncleHeaderObj["timestamp"]); uncleBlockFromFields.timestamp = toInt(uncleHeaderObj["timestamp"]);
uncleBlockFromFields.difficulty = uncleBlockFromFields.calculateDifficulty(vBiBlocks[(size_t)uncleBlockFromFields.number - 1]); uncleBlockFromFields.difficulty = uncleBlockFromFields.calculateDifficulty(_vBiBlocks[(size_t)uncleBlockFromFields.number - 1]);
} }
} }
@ -570,10 +584,10 @@ mArray importUncles(mObject const& blObj, vector<BlockInfo>& vBiUncles, vector<B
writeBlockHeaderToJson(uncleHeaderObj, uncleBlockFromFields); writeBlockHeaderToJson(uncleHeaderObj, uncleBlockFromFields);
aUncleList.push_back(uncleHeaderObj); aUncleList.push_back(uncleHeaderObj);
vBiUncles.push_back(uncleBlockFromFields); _vBiUncles.push_back(uncleBlockFromFields);
uncleHeaderObj_pre = uncleHeaderObj; uncleHeaderObj_pre = uncleHeaderObj;
} //for blObj["uncleHeaders"].get_array() } //for _blObj["uncleHeaders"].get_array()
return aUncleList; return aUncleList;
} }
@ -808,6 +822,11 @@ BOOST_AUTO_TEST_CASE(bcGasPricerTest)
dev::test::executeTests("bcGasPricerTest", "/BlockTests",dev::test::getFolder(__FILE__) + "/BlockTestsFiller", dev::test::doBlockchainTests); dev::test::executeTests("bcGasPricerTest", "/BlockTests",dev::test::getFolder(__FILE__) + "/BlockTestsFiller", dev::test::doBlockchainTests);
} }
BOOST_AUTO_TEST_CASE(bcBruncleTest)
{
dev::test::executeTests("bcBruncleTest", "/BlockTests",dev::test::getFolder(__FILE__) + "/BlockTestsFiller", dev::test::doBlockchainTests);
}
BOOST_AUTO_TEST_CASE(bcWalletTest) BOOST_AUTO_TEST_CASE(bcWalletTest)
{ {
if (test::Options::get().wallet) if (test::Options::get().wallet)

Loading…
Cancel
Save