txdb: don't reset during in-memory cache resize

We can't support a reset of the dbwrapper object when in-memory configuration is used
because it results in the permanent loss of coins. This only affects unittest
configurations (since that's the only place we use in-memory CCoinsViewDB instances).
This commit is contained in:
James O'Beirne 2020-08-25 13:48:21 -04:00
parent f6e2da5fb7
commit ad949ba449
No known key found for this signature in database
GPG key ID: 7A935DADB2C44F05

View file

@ -47,11 +47,15 @@ CCoinsViewDB::CCoinsViewDB(fs::path ldb_path, size_t nCacheSize, bool fMemory, b
void CCoinsViewDB::ResizeCache(size_t new_cache_size) void CCoinsViewDB::ResizeCache(size_t new_cache_size)
{ {
// Have to do a reset first to get the original `m_db` state to release its // We can't do this operation with an in-memory DB since we'll lose all the coins upon
// filesystem lock. // reset.
m_db.reset(); if (!m_is_memory) {
m_db = MakeUnique<CDBWrapper>( // Have to do a reset first to get the original `m_db` state to release its
m_ldb_path, new_cache_size, m_is_memory, /*fWipe*/ false, /*obfuscate*/ true); // filesystem lock.
m_db.reset();
m_db = MakeUnique<CDBWrapper>(
m_ldb_path, new_cache_size, m_is_memory, /*fWipe*/ false, /*obfuscate*/ true);
}
} }
bool CCoinsViewDB::GetCoin(const COutPoint &outpoint, Coin &coin) const { bool CCoinsViewDB::GetCoin(const COutPoint &outpoint, Coin &coin) const {