mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-11 15:48:05 +00:00
Extend coins_tests
This commit is contained in:
parent
5083079688
commit
ce23efaa5c
@ -87,9 +87,12 @@ public:
|
|||||||
{
|
{
|
||||||
// Manually recompute the dynamic usage of the whole data, and compare it.
|
// Manually recompute the dynamic usage of the whole data, and compare it.
|
||||||
size_t ret = memusage::DynamicUsage(cacheCoins);
|
size_t ret = memusage::DynamicUsage(cacheCoins);
|
||||||
|
size_t count = 0;
|
||||||
for (CCoinsMap::iterator it = cacheCoins.begin(); it != cacheCoins.end(); it++) {
|
for (CCoinsMap::iterator it = cacheCoins.begin(); it != cacheCoins.end(); it++) {
|
||||||
ret += it->second.coins.DynamicMemoryUsage();
|
ret += it->second.coins.DynamicMemoryUsage();
|
||||||
|
++count;
|
||||||
}
|
}
|
||||||
|
BOOST_CHECK_EQUAL(GetCacheSize(), count);
|
||||||
BOOST_CHECK_EQUAL(DynamicMemoryUsage(), ret);
|
BOOST_CHECK_EQUAL(DynamicMemoryUsage(), ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -118,10 +121,12 @@ BOOST_AUTO_TEST_CASE(coins_cache_simulation_test)
|
|||||||
bool removed_all_caches = false;
|
bool removed_all_caches = false;
|
||||||
bool reached_4_caches = false;
|
bool reached_4_caches = false;
|
||||||
bool added_an_entry = false;
|
bool added_an_entry = false;
|
||||||
|
bool added_an_unspendable_entry = false;
|
||||||
bool removed_an_entry = false;
|
bool removed_an_entry = false;
|
||||||
bool updated_an_entry = false;
|
bool updated_an_entry = false;
|
||||||
bool found_an_entry = false;
|
bool found_an_entry = false;
|
||||||
bool missed_an_entry = false;
|
bool missed_an_entry = false;
|
||||||
|
bool uncached_an_entry = false;
|
||||||
|
|
||||||
// A simple map to track what we expect the cache stack to represent.
|
// A simple map to track what we expect the cache stack to represent.
|
||||||
std::map<COutPoint, Coin> result;
|
std::map<COutPoint, Coin> result;
|
||||||
@ -143,36 +148,49 @@ BOOST_AUTO_TEST_CASE(coins_cache_simulation_test)
|
|||||||
{
|
{
|
||||||
uint256 txid = txids[insecure_rand() % txids.size()]; // txid we're going to modify in this iteration.
|
uint256 txid = txids[insecure_rand() % txids.size()]; // txid we're going to modify in this iteration.
|
||||||
Coin& coin = result[COutPoint(txid, 0)];
|
Coin& coin = result[COutPoint(txid, 0)];
|
||||||
const Coin& entry = stack.back()->AccessCoin(COutPoint(txid, 0));
|
const Coin& entry = (insecure_rand() % 500 == 0) ? AccessByTxid(*stack.back(), txid) : stack.back()->AccessCoin(COutPoint(txid, 0));
|
||||||
BOOST_CHECK(coin == entry);
|
BOOST_CHECK(coin == entry);
|
||||||
|
|
||||||
if (insecure_rand() % 5 == 0 || coin.IsPruned()) {
|
if (insecure_rand() % 5 == 0 || coin.IsPruned()) {
|
||||||
if (coin.IsPruned()) {
|
Coin newcoin;
|
||||||
added_an_entry = true;
|
newcoin.out.nValue = insecure_rand();
|
||||||
|
newcoin.nHeight = 1;
|
||||||
|
if (insecure_rand() % 16 == 0 && coin.IsPruned()) {
|
||||||
|
newcoin.out.scriptPubKey.assign(1 + (insecure_rand() & 0x3F), OP_RETURN);
|
||||||
|
BOOST_CHECK(newcoin.out.scriptPubKey.IsUnspendable());
|
||||||
|
added_an_unspendable_entry = true;
|
||||||
} else {
|
} else {
|
||||||
updated_an_entry = true;
|
newcoin.out.scriptPubKey.assign(insecure_rand() & 0x3F, 0); // Random sizes so we can test memory usage accounting
|
||||||
|
(coin.IsPruned() ? added_an_entry : updated_an_entry) = true;
|
||||||
|
coin = newcoin;
|
||||||
}
|
}
|
||||||
coin.out.nValue = insecure_rand();
|
stack.back()->AddCoin(COutPoint(txid, 0), std::move(newcoin), !coin.IsPruned() || insecure_rand() & 1);
|
||||||
coin.nHeight = 1;
|
|
||||||
} else {
|
} else {
|
||||||
coin.Clear();
|
|
||||||
removed_an_entry = true;
|
removed_an_entry = true;
|
||||||
}
|
coin.Clear();
|
||||||
if (coin.IsPruned()) {
|
|
||||||
stack.back()->SpendCoin(COutPoint(txid, 0));
|
stack.back()->SpendCoin(COutPoint(txid, 0));
|
||||||
} else {
|
|
||||||
stack.back()->AddCoin(COutPoint(txid, 0), Coin(coin), true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// One every 10 iterations, remove a random entry from the cache
|
||||||
|
if (insecure_rand() % 10) {
|
||||||
|
COutPoint out(txids[insecure_rand() % txids.size()], 0);
|
||||||
|
int cacheid = insecure_rand() % stack.size();
|
||||||
|
stack[cacheid]->Uncache(out);
|
||||||
|
uncached_an_entry |= !stack[cacheid]->HaveCoinsInCache(out);
|
||||||
|
}
|
||||||
|
|
||||||
// Once every 1000 iterations and at the end, verify the full cache.
|
// Once every 1000 iterations and at the end, verify the full cache.
|
||||||
if (insecure_rand() % 1000 == 1 || i == NUM_SIMULATION_ITERATIONS - 1) {
|
if (insecure_rand() % 1000 == 1 || i == NUM_SIMULATION_ITERATIONS - 1) {
|
||||||
for (auto it = result.begin(); it != result.end(); it++) {
|
for (auto it = result.begin(); it != result.end(); it++) {
|
||||||
|
bool have = stack.back()->HaveCoins(it->first);
|
||||||
const Coin& coin = stack.back()->AccessCoin(it->first);
|
const Coin& coin = stack.back()->AccessCoin(it->first);
|
||||||
|
BOOST_CHECK(have == !coin.IsPruned());
|
||||||
BOOST_CHECK(coin == it->second);
|
BOOST_CHECK(coin == it->second);
|
||||||
if (coin.IsPruned()) {
|
if (coin.IsPruned()) {
|
||||||
missed_an_entry = true;
|
missed_an_entry = true;
|
||||||
} else {
|
} else {
|
||||||
|
BOOST_CHECK(stack.back()->HaveCoinsInCache(it->first));
|
||||||
found_an_entry = true;
|
found_an_entry = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -222,10 +240,12 @@ BOOST_AUTO_TEST_CASE(coins_cache_simulation_test)
|
|||||||
BOOST_CHECK(removed_all_caches);
|
BOOST_CHECK(removed_all_caches);
|
||||||
BOOST_CHECK(reached_4_caches);
|
BOOST_CHECK(reached_4_caches);
|
||||||
BOOST_CHECK(added_an_entry);
|
BOOST_CHECK(added_an_entry);
|
||||||
|
BOOST_CHECK(added_an_unspendable_entry);
|
||||||
BOOST_CHECK(removed_an_entry);
|
BOOST_CHECK(removed_an_entry);
|
||||||
BOOST_CHECK(updated_an_entry);
|
BOOST_CHECK(updated_an_entry);
|
||||||
BOOST_CHECK(found_an_entry);
|
BOOST_CHECK(found_an_entry);
|
||||||
BOOST_CHECK(missed_an_entry);
|
BOOST_CHECK(missed_an_entry);
|
||||||
|
BOOST_CHECK(uncached_an_entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Store of all necessary tx and undo data for next test
|
// Store of all necessary tx and undo data for next test
|
||||||
@ -275,6 +295,7 @@ BOOST_AUTO_TEST_CASE(updatecoins_simulation_test)
|
|||||||
tx.vin.resize(1);
|
tx.vin.resize(1);
|
||||||
tx.vout.resize(1);
|
tx.vout.resize(1);
|
||||||
tx.vout[0].nValue = i; //Keep txs unique unless intended to duplicate
|
tx.vout[0].nValue = i; //Keep txs unique unless intended to duplicate
|
||||||
|
tx.vout[0].scriptPubKey.assign(insecure_rand() & 0x3F, 0); // Random sizes so we can test memory usage accounting
|
||||||
unsigned int height = insecure_rand();
|
unsigned int height = insecure_rand();
|
||||||
Coin oldcoins;
|
Coin oldcoins;
|
||||||
|
|
||||||
@ -393,11 +414,24 @@ BOOST_AUTO_TEST_CASE(updatecoins_simulation_test)
|
|||||||
// Once every 1000 iterations and at the end, verify the full cache.
|
// Once every 1000 iterations and at the end, verify the full cache.
|
||||||
if (insecure_rand() % 1000 == 1 || i == NUM_SIMULATION_ITERATIONS - 1) {
|
if (insecure_rand() % 1000 == 1 || i == NUM_SIMULATION_ITERATIONS - 1) {
|
||||||
for (auto it = result.begin(); it != result.end(); it++) {
|
for (auto it = result.begin(); it != result.end(); it++) {
|
||||||
|
bool have = stack.back()->HaveCoins(it->first);
|
||||||
const Coin& coin = stack.back()->AccessCoin(it->first);
|
const Coin& coin = stack.back()->AccessCoin(it->first);
|
||||||
|
BOOST_CHECK(have == !coin.IsPruned());
|
||||||
BOOST_CHECK(coin == it->second);
|
BOOST_CHECK(coin == it->second);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// One every 10 iterations, remove a random entry from the cache
|
||||||
|
if (utxoset.size() > 1 && insecure_rand() % 30) {
|
||||||
|
stack[insecure_rand() % stack.size()]->Uncache(FindRandomFrom(utxoset)->first);
|
||||||
|
}
|
||||||
|
if (disconnectedids.size() > 1 && insecure_rand() % 30) {
|
||||||
|
stack[insecure_rand() % stack.size()]->Uncache(FindRandomFrom(disconnectedids)->first);
|
||||||
|
}
|
||||||
|
if (duplicateids.size() > 1 && insecure_rand() % 30) {
|
||||||
|
stack[insecure_rand() % stack.size()]->Uncache(FindRandomFrom(duplicateids)->first);
|
||||||
|
}
|
||||||
|
|
||||||
if (insecure_rand() % 100 == 0) {
|
if (insecure_rand() % 100 == 0) {
|
||||||
// Every 100 iterations, flush an intermediate cache
|
// Every 100 iterations, flush an intermediate cache
|
||||||
if (stack.size() > 1 && insecure_rand() % 2 == 0) {
|
if (stack.size() > 1 && insecure_rand() % 2 == 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user