Skip to content
This repository has been archived by the owner on Oct 28, 2021. It is now read-only.

Retesteth support #5909

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion libethcore/BlockHeader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -116,8 +116,10 @@ h256 BlockHeader::hash(IncludeSeal _i) const

void BlockHeader::streamRLPFields(RLPStream& _s) const
{
bigint nnn = m_number; // Fix rlp stream issue with uint65_t
Copy link
Member

@gumb0 gumb0 Jun 22, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it supposed to fix the case when block number doesn't in 64 bit?
But it doesn't fix it, because m_number is still uint64_t

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also there are some proposals to require the limit for block nuumber and timestamp, so I'm not sure it makes sense to change it now.
https://eips.ethereum.org/EIPS/eip-1985

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It fixes the test. Because RLPStream << was working incorrectly with u64int_t

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What do you mean exactly? Maybe we should fix operator<< for uint64_t or something

(Some tests currently fail anyway)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes. I had blockchain/invalidblocks/bcInvalidHeader/timestamp4 test failing without this change. I assume the issue is in << operation

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I can't find this test, what are header values there?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

sorry I was out of laptop.
it is this test:
BlockchainTests/InvalidBlocks/bcUncleHeaderValidity/incorrectUncleTimestamp4

I set timestamp of the uncleheader to 500000000000 + previous block (~1000)
and the value I get rlp::85746a528800. but testeth gives me RLP encode of this argument rlp::846a528800
unless I explicitly say that it is a bigint in that function. the fix is dirty because I just try to make the tests pass

bigint ttt = m_timestamp; // Fix rlp stream issue with uint65_t
_s << m_parentHash << m_sha3Uncles << m_author << m_stateRoot << m_transactionsRoot << m_receiptsRoot << m_logBloom
<< m_difficulty << m_number << m_gasLimit << m_gasUsed << m_timestamp << m_extraData;
<< m_difficulty << nnn << m_gasLimit << m_gasUsed << ttt << m_extraData;
}

void BlockHeader::streamRLP(RLPStream& _s, IncludeSeal _i) const
Expand Down
2 changes: 1 addition & 1 deletion libethereum/ClientTest.h
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ class ClientTest: public Client
void onBadBlock(Exception& _ex);
void addNestedBadBlockException(bytes const& _blockBytes, Exception& io_ex);

unsigned const m_singleBlockMaxMiningTimeInSeconds = 60;
unsigned const m_singleBlockMaxMiningTimeInSeconds = 3600;
boost::exception_ptr m_lastImportError;
bytes m_lastBadBlock;
Mutex m_badBlockMutex;
Expand Down
6 changes: 3 additions & 3 deletions libweb3jsonrpc/JsonHelper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ Json::Value toJson(dev::eth::BlockHeader const& _bi, SealEngineFace* _sealer)
res["number"] = toJS(_bi.number());
res["gasUsed"] = toJS(_bi.gasUsed());
res["gasLimit"] = toJS(_bi.gasLimit());
res["extraData"] = toJS(_bi.extraData());
res["extraData"] = _bi.extraData().empty() ? "0x" : toJS(_bi.extraData());
res["logsBloom"] = toJS(_bi.logBloom());
res["timestamp"] = toJS(_bi.timestamp());
// TODO: remove once JSONRPC spec is updated to use "author" over "miner".
Expand Down Expand Up @@ -113,8 +113,8 @@ Json::Value toJson(dev::eth::Transaction const& _t, std::pair<h256, unsigned> _l
res["transactionIndex"] = toJS(_location.second);
res["blockNumber"] = toJS(_blockNumber);
res["v"] = toJS(_t.rawV());
res["r"] = toJS(_t.signature().r);
res["s"] = toJS(_t.signature().s);
res["r"] = toJS(dev::u256(_t.signature().r));
res["s"] = toJS(dev::u256(_t.signature().s));
}
return res;
}
Expand Down
2 changes: 1 addition & 1 deletion test/jsontests
Submodule jsontests updated 19329 files
11 changes: 6 additions & 5 deletions test/tools/jsontests/BlockChainTests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,10 @@ json_spirit::mValue doBCTest(
"\"network\" field is not found. filename: " + TestOutputHelper::get().testFile().string() +
" testname: " + TestOutputHelper::get().testName()
);
dev::test::TestBlockChain::s_sealEngineNetwork = stringToNetId(inputTest.at("network").get_str());
string const c_network = inputTest.at("network").get_str();
if (test::isAfterSupportNetwork(c_network))
continue;
dev::test::TestBlockChain::s_sealEngineNetwork = stringToNetId(c_network);
if (Options::get().verbosity > 1)
std::cout << "Running " << TestOutputHelper::get().testName() << std::endl;
testBCTest(inputTest);
Expand Down Expand Up @@ -539,8 +542,7 @@ void testBCTest(json_spirit::mObject const& _o)
BOOST_REQUIRE_MESSAGE(blObj.count("blockHeader"),
"blockHeader field is not found. "
"filename: " + TestOutputHelper::get().testFile().string() +
" testname: " + TestOutputHelper::get().testName()
);
" testname: " + TestOutputHelper::get().testName());

//Check Provided Header against block in RLP
TestBlock blockFromFields(blObj["blockHeader"].get_obj());
Expand All @@ -549,8 +551,7 @@ void testBCTest(json_spirit::mObject const& _o)
BOOST_REQUIRE_MESSAGE(blObj.count("transactions"),
"transactions field is not found. "
"filename: " + TestOutputHelper::get().testFile().string() +
" testname: " + TestOutputHelper::get().testName()
);
" testname: " + TestOutputHelper::get().testName());
for (auto const& txObj: blObj["transactions"].get_array())
{
TestTransaction transaction(txObj.get_obj());
Expand Down
1 change: 0 additions & 1 deletion test/tools/jsontests/LegacyTests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,6 @@ BOOST_AUTO_TEST_CASE(stBadOpcode) {}

// New Tests
BOOST_AUTO_TEST_CASE(stArgsZeroOneBalance) {}
BOOST_AUTO_TEST_CASE(stEWASMTests) {}
BOOST_AUTO_TEST_CASE(stTimeConsuming) {}
BOOST_AUTO_TEST_SUITE_END() // GeneralStateTests Constantinople Legacy

Expand Down
8 changes: 6 additions & 2 deletions test/tools/jsontests/StateTests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,12 @@ json_spirit::mValue StateTestSuite::doTests(json_spirit::mValue const& _input, b
BOOST_REQUIRE_MESSAGE(exp.type() == obj_type, " post field should contain an array of objects for each network.");
if (!Options::get().singleTestNet.empty() && i->first != Options::get().singleTestNet)
continue;
if (importer.checkGeneralTestSection(exp.get_obj(), wrongTransactionsIndexes, i->first))
if (test::isAfterSupportNetwork(i->first))
{
foundResults = true;
continue;
}
if (importer.checkGeneralTestSection(exp.get_obj(), wrongTransactionsIndexes, i->first))
foundResults = true;
}
}
Expand Down Expand Up @@ -189,7 +194,6 @@ BOOST_AUTO_TEST_CASE(stBadOpcode){}

//New Tests
BOOST_AUTO_TEST_CASE(stArgsZeroOneBalance){}
BOOST_AUTO_TEST_CASE(stEWASMTests){}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does that mean we can't use testeth anymore with https://github.com/ewasm/hera ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

you can use your fork sure.
The issue is that new forks will not be supported in testeth.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What fork do you mean?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I mean if you have stEWASMTests somewhere and use testeth to run it.

BOOST_AUTO_TEST_CASE(stTimeConsuming) {}
BOOST_AUTO_TEST_CASE(stChainId) {}
BOOST_AUTO_TEST_CASE(stSLoadTest) {}
Expand Down
2 changes: 1 addition & 1 deletion test/tools/libtesteth/ImportTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -741,7 +741,7 @@ void ImportTest::checkAllowedNetwork(string const& _network)
// Can't use boost at this point
std::cerr << TestOutputHelper::get().testName() + " Specified Network not found: "
<< _network << "\n";
exit(1);
//exit(1);
}
}

Expand Down
13 changes: 12 additions & 1 deletion test/tools/libtesteth/TestHelper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,9 @@ eth::Network stringToNetId(string const& _netname)
if (netIdToString(net) == _netname)
return net;

BOOST_ERROR(TestOutputHelper::get().testName() + " network not found: " + _netname);
string const message = TestOutputHelper::get().testName() + " network not found: " + _netname;
std::cerr << message << " using Frontier instead or skipping" << std::endl;
//BOOST_ERROR(message);
return eth::Network::FrontierTest;
}

Expand Down Expand Up @@ -218,6 +220,15 @@ set<string> translateNetworks(set<string> const& _networks)
return out;
}

bool isAfterSupportNetwork(std::string const& net)
{
static vector<string> c_unsupportedNets = { "Berlin" };
for (auto const& n : c_unsupportedNets)
if (n == net)
return true;
return false;
}

string exportLog(eth::LogEntries const& _logs)
{
RLPStream s;
Expand Down
1 change: 1 addition & 0 deletions test/tools/libtesteth/TestHelper.h
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ class ZeroGasPricer: public eth::GasPricer
};

// helping functions
bool isAfterSupportNetwork(std::string const&);
std::string prepareVersionString();
std::string prepareLLLCVersionString();
std::vector<boost::filesystem::path> getFiles(boost::filesystem::path const& _dirPath, std::set<std::string> _extentionMask, std::string const& _particularFile = {});
Expand Down