|
|
|
@ -8,7 +8,6 @@
@@ -8,7 +8,6 @@
|
|
|
|
|
|
|
|
|
|
#include <boost/test/unit_test.hpp> |
|
|
|
|
|
|
|
|
|
extern CWallet* pwalletMain; |
|
|
|
|
extern void SHA256Transform(void* pstate, void* pinput, const void* pinit); |
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_SUITE(miner_tests) |
|
|
|
@ -51,7 +50,7 @@ struct {
@@ -51,7 +50,7 @@ struct {
|
|
|
|
|
// NOTE: These tests rely on CreateNewBlock doing its own self-validation!
|
|
|
|
|
BOOST_AUTO_TEST_CASE(CreateNewBlock_validity) |
|
|
|
|
{ |
|
|
|
|
CReserveKey reservekey(pwalletMain); |
|
|
|
|
CScript scriptPubKey = CScript() << ParseHex("04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38c4f35504e51ec112de5c384df7ba0b8d578a4c702b6bf11d5f") << OP_CHECKSIG; |
|
|
|
|
CBlockTemplate *pblocktemplate; |
|
|
|
|
CTransaction tx; |
|
|
|
|
CScript script; |
|
|
|
@ -60,7 +59,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -60,7 +59,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
LOCK(cs_main); |
|
|
|
|
|
|
|
|
|
// Simple block creation, nothing special yet:
|
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
|
|
|
|
|
// We can't make transactions until we have inputs
|
|
|
|
|
// Therefore, load 100 blocks :)
|
|
|
|
@ -86,7 +85,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -86,7 +85,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
delete pblocktemplate; |
|
|
|
|
|
|
|
|
|
// Just to make sure we can still make simple blocks
|
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
|
|
|
|
|
// block sigops > limit: 1000 CHECKMULTISIG + 1
|
|
|
|
@ -104,7 +103,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -104,7 +103,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
mempool.addUnchecked(hash, CTxMemPoolEntry(tx, 11, GetTime(), 111.0, 11)); |
|
|
|
|
tx.vin[0].prevout.hash = hash; |
|
|
|
|
} |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
mempool.clear(); |
|
|
|
|
|
|
|
|
@ -124,14 +123,14 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -124,14 +123,14 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
mempool.addUnchecked(hash, CTxMemPoolEntry(tx, 11, GetTime(), 111.0, 11)); |
|
|
|
|
tx.vin[0].prevout.hash = hash; |
|
|
|
|
} |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
mempool.clear(); |
|
|
|
|
|
|
|
|
|
// orphan in mempool
|
|
|
|
|
hash = tx.GetHash(); |
|
|
|
|
mempool.addUnchecked(hash, CTxMemPoolEntry(tx, 11, GetTime(), 111.0, 11)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
mempool.clear(); |
|
|
|
|
|
|
|
|
@ -149,7 +148,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -149,7 +148,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
tx.vout[0].nValue = 5900000000LL; |
|
|
|
|
hash = tx.GetHash(); |
|
|
|
|
mempool.addUnchecked(hash, CTxMemPoolEntry(tx, 11, GetTime(), 111.0, 11)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
mempool.clear(); |
|
|
|
|
|
|
|
|
@ -160,7 +159,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -160,7 +159,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
tx.vout[0].nValue = 0; |
|
|
|
|
hash = tx.GetHash(); |
|
|
|
|
mempool.addUnchecked(hash, CTxMemPoolEntry(tx, 11, GetTime(), 111.0, 11)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
mempool.clear(); |
|
|
|
|
|
|
|
|
@ -178,7 +177,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -178,7 +177,7 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
tx.vout[0].nValue -= 1000000; |
|
|
|
|
hash = tx.GetHash(); |
|
|
|
|
mempool.addUnchecked(hash, CTxMemPoolEntry(tx, 11, GetTime(), 111.0, 11)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
mempool.clear(); |
|
|
|
|
|
|
|
|
@ -192,17 +191,17 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
@@ -192,17 +191,17 @@ BOOST_AUTO_TEST_CASE(CreateNewBlock_validity)
|
|
|
|
|
tx.vout[0].scriptPubKey = CScript() << OP_2; |
|
|
|
|
hash = tx.GetHash(); |
|
|
|
|
mempool.addUnchecked(hash, CTxMemPoolEntry(tx, 11, GetTime(), 111.0, 11)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
mempool.clear(); |
|
|
|
|
|
|
|
|
|
// subsidy changing
|
|
|
|
|
int nHeight = chainActive.Height(); |
|
|
|
|
chainActive.Tip()->nHeight = 209999; |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
chainActive.Tip()->nHeight = 210000; |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlockWithKey(reservekey)); |
|
|
|
|
BOOST_CHECK(pblocktemplate = CreateNewBlock(scriptPubKey)); |
|
|
|
|
delete pblocktemplate; |
|
|
|
|
chainActive.Tip()->nHeight = nHeight; |
|
|
|
|
|
|
|
|
|