aboutsummaryrefslogtreecommitdiffstats
path: root/createRandomTest.cpp
diff options
context:
space:
mode:
authorCJentzsch <jentzsch.software@gmail.com>2015-01-12 19:46:40 +0800
committerCJentzsch <jentzsch.software@gmail.com>2015-01-12 19:46:40 +0800
commitd4f1ab9145132d98e8ebe09e8a067f1f7f013574 (patch)
treef4560b63939a81ce214c3e20a9fa58f6eb9f3acd /createRandomTest.cpp
parentc8b33fb7099716fa3a93df4ae86c746d04eb2533 (diff)
downloaddexon-solidity-d4f1ab9145132d98e8ebe09e8a067f1f7f013574.tar
dexon-solidity-d4f1ab9145132d98e8ebe09e8a067f1f7f013574.tar.gz
dexon-solidity-d4f1ab9145132d98e8ebe09e8a067f1f7f013574.tar.bz2
dexon-solidity-d4f1ab9145132d98e8ebe09e8a067f1f7f013574.tar.lz
dexon-solidity-d4f1ab9145132d98e8ebe09e8a067f1f7f013574.tar.xz
dexon-solidity-d4f1ab9145132d98e8ebe09e8a067f1f7f013574.tar.zst
dexon-solidity-d4f1ab9145132d98e8ebe09e8a067f1f7f013574.zip
start with block info opcodes
Diffstat (limited to 'createRandomTest.cpp')
-rw-r--r--createRandomTest.cpp22
1 files changed, 15 insertions, 7 deletions
diff --git a/createRandomTest.cpp b/createRandomTest.cpp
index 1af12f64..40ed1aa9 100644
--- a/createRandomTest.cpp
+++ b/createRandomTest.cpp
@@ -54,18 +54,26 @@ int main(int argc, char *argv[])
gen.seed(static_cast<unsigned int>(timeSinceEpoch));
boost::random::uniform_int_distribution<> lengthOfCodeDist(2, 16);
boost::random::uniform_int_distribution<> opcodeDist(0, 255);
+ boost::random::uniform_int_distribution<> BlockInfoOpcodeDist(0x41, 0x45);
boost::random::variate_generator<boost::mt19937&,
boost::random::uniform_int_distribution<> > randGen(gen, opcodeDist);
+ boost::random::variate_generator<boost::mt19937&,
+ boost::random::uniform_int_distribution<> > randGenBlockInfoOpcode(gen, BlockInfoOpcodeDist);
int lengthOfCode = lengthOfCodeDist(gen);
string randomCode;
for (int i = 0; i < lengthOfCode; ++i)
{
- uint8_t opcode = randGen();
+ if (i < 8 && (randGen() < 192))
+ {
+ randomCode += toHex(toCompactBigEndian((uint8_t)randGenBlockInfoOpcode()));
+ continue;
+ }
- // disregard all invalid commands, except of one (0x10)
- if (dev::eth::isValidInstruction(dev::eth::Instruction(opcode)) || opcode == 0x10)
+ uint8_t opcode = randGen();
+ // disregard all invalid commands, except of one (0x0c)
+ if (dev::eth::isValidInstruction(dev::eth::Instruction(opcode)) || opcode == 0x0a)
randomCode += toHex(toCompactBigEndian(opcode));
else
i--;
@@ -77,9 +85,9 @@ int main(int argc, char *argv[])
\"env\" : {\n\
\"previousHash\" : \"5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6\",\n\
\"currentNumber\" : \"0\",\n\
- \"currentGasLimit\" : \"1000000\",\n\
- \"currentDifficulty\" : \"256\",\n\
- \"currentTimestamp\" : 1,\n\
+ \"currentGasLimit\" : \"115792089237316195423570985008687907853269984665640564039457584007913129639935\",\n\
+ \"currentDifficulty\" : \"1\",\n\
+ \"currentTimestamp\" : 2,\n\
\"currentCoinbase\" : \"2adc25665018aa1fe0e6bc666dac8fc2697ff9ba\"\n\
},\n\
\"pre\" : {\n\
@@ -106,7 +114,7 @@ int main(int argc, char *argv[])
read_string(s, v);
// insert new random code
- v.get_obj().find("randomVMtest")->second.get_obj().find("pre")->second.get_obj().begin()->second.get_obj()["code"] = "0x" + randomCode;
+ v.get_obj().find("randomVMtest")->second.get_obj().find("pre")->second.get_obj().begin()->second.get_obj()["code"] = "0x" + randomCode + "55";
// execute code in vm
doMyTests(v);