16 #include "test/test_raven.h" 21 #include <boost/test/unit_test.hpp> 38 #define RANDOM_REPEATS 5 40 std::vector<std::unique_ptr<CWalletTx>>
wtxn;
46 static const CWallet testWallet;
47 static std::vector<COutput> vCoins;
49 static void add_coin(
const CAmount &nValue,
int nAge = 6 * 24,
bool fIsFromMe =
false,
int nInput = 0)
51 static int nextLockTime = 0;
54 tx.
vout.resize(nInput + 1);
55 tx.
vout[nInput].nValue = nValue;
62 std::unique_ptr<CWalletTx> wtx(
new CWalletTx(&testWallet, MakeTransactionRef(std::move(tx))));
65 wtx->fDebitCached =
true;
66 wtx->nDebitCached = 1;
68 COutput output(wtx.get(), nInput, nAge,
true ,
true ,
true );
69 vCoins.push_back(output);
70 wtxn.emplace_back(std::move(wtx));
73 static void empty_wallet(
void)
81 std::pair<CoinSet::iterator, CoinSet::iterator> ret = mismatch(a.begin(), a.end(), b.begin());
82 return ret.first == a.end() && ret.second == b.end();
87 BOOST_TEST_MESSAGE(
"Running Coin Selection Test");
89 CoinSet setCoinsRet, setCoinsRet2;
102 add_coin(1 * CENT, 4);
121 add_coin(10 * CENT, 3,
true);
210 add_coin(MIN_CHANGE * 1 / 10);
211 add_coin(MIN_CHANGE * 2 / 10);
212 add_coin(MIN_CHANGE * 3 / 10);
213 add_coin(MIN_CHANGE * 4 / 10);
214 add_coin(MIN_CHANGE * 5 / 10);
222 add_coin(1111 * MIN_CHANGE);
229 add_coin(MIN_CHANGE * 6 / 10);
230 add_coin(MIN_CHANGE * 7 / 10);
239 for (
int j = 0; j < 20; j++)
240 add_coin(50000 * COIN);
251 add_coin(MIN_CHANGE * 5 / 10);
252 add_coin(MIN_CHANGE * 6 / 10);
253 add_coin(MIN_CHANGE * 7 / 10);
254 add_coin(1111 * MIN_CHANGE);
261 add_coin(MIN_CHANGE * 4 / 10);
262 add_coin(MIN_CHANGE * 6 / 10);
263 add_coin(MIN_CHANGE * 8 / 10);
264 add_coin(1111 * MIN_CHANGE);
271 add_coin(MIN_CHANGE * 5 / 100);
272 add_coin(MIN_CHANGE * 1);
273 add_coin(MIN_CHANGE * 100);
286 for (
CAmount amt = 1500; amt < COIN; amt *= 10)
290 for (uint16_t j = 0; j < 676; j++)
293 if (amt - 2000 < MIN_CHANGE)
296 uint16_t returnSize = std::ceil((2000.0 + MIN_CHANGE) / amt);
297 CAmount returnValue = amt * returnSize;
311 for (
int i2 = 0; i2 < 100; i2++)
318 BOOST_CHECK(!equal_sets(setCoinsRet, setCoinsRet2));
327 if (equal_sets(setCoinsRet, setCoinsRet2))
330 BOOST_CHECK_NE(fails, RANDOM_REPEATS);
348 if (equal_sets(setCoinsRet, setCoinsRet2))
351 BOOST_CHECK_NE(fails, RANDOM_REPEATS);
359 BOOST_TEST_MESSAGE(
"Running ApproximateBestSubset Test");
369 for (
int i = 0; i < 1000; i++)
370 add_coin(1000 * COIN);
380 static void AddKey(
CWallet &wallet,
const CKey &key)
389 BOOST_TEST_MESSAGE(
"Running Rescan Test");
404 AddKey(wallet, coinbaseKey);
417 AddKey(wallet, coinbaseKey);
433 key.
pushKV(
"timestamp", 0);
450 strprintf(
"[{\"success\":false,\"error\":{\"code\":-1,\"message\":\"Rescan failed for key with creation " 451 "timestamp %d. There was an error reading a block from time %d, which is after or within %d " 452 "seconds of key creation, and could contain transactions pertaining to the key. As a result, " 453 "transactions and coins using this key may not appear in the wallet. This error could be caused " 454 "by pruning or data corruption (see ravend log for details) and could be dealt with by " 455 "downloading and rescanning the relevant blocks (see -reindex and -rescan " 456 "options).\"}},{\"success\":true}]",
469 BOOST_TEST_MESSAGE(
"Running ImportWallet Rescan Test");
477 coinbaseTxns.emplace_back(*CreateAndProcessBlock({},
GetScriptForRawPubKey(coinbaseKey.GetPubKey())).vtx[0]);
478 coinbaseTxns.emplace_back(*CreateAndProcessBlock({},
GetScriptForRawPubKey(coinbaseKey.GetPubKey())).vtx[0]);
482 const int64_t KEY_TIME = BLOCK_TIME + TIMESTAMP_WINDOW;
484 coinbaseTxns.emplace_back(*CreateAndProcessBlock({},
GetScriptForRawPubKey(coinbaseKey.GetPubKey())).vtx[0]);
490 wallet.
mapKeyMetadata[coinbaseKey.GetPubKey().GetID()].nCreateTime = KEY_TIME;
491 wallet.
AddKeyPubKey(coinbaseKey, coinbaseKey.GetPubKey());
513 for (
size_t i = 0; i < coinbaseTxns.size(); ++i)
515 bool found = wallet.
GetWalletTx(coinbaseTxns[i].GetHash());
516 bool expected = i >= 100;
533 BOOST_TEST_MESSAGE(
"Running Coin Mark Dirty Immature Credit Test");
536 CWalletTx wtx(&wallet, MakeTransactionRef(coinbaseTxns.back()));
548 wallet.
AddKeyPubKey(coinbaseKey, coinbaseKey.GetPubKey());
552 static int64_t AddTx(
CWallet &wallet, uint32_t lockTime, int64_t mockTime, int64_t blockTime)
561 assert(inserted.second);
562 const uint256 &hash = inserted.first->first;
563 block = inserted.first->second;
564 block->
nTime = blockTime;
568 CWalletTx wtx(&wallet, MakeTransactionRef(tx));
581 BOOST_TEST_MESSAGE(
"Running ComputeTimeSmart Test");
611 BOOST_TEST_MESSAGE(
"Running LoadReceiveRequests Test");
614 pwalletMain->
AddDestData(dest,
"misc",
"val_misc");
634 AddKey(*wallet, coinbaseKey);
668 BOOST_TEST_MESSAGE(
"Running ListCoins Test");
672 std::string coinbaseAddress = coinbaseKey.GetPubKey().GetID().ToString();
679 BOOST_CHECK_EQUAL(boost::get<CKeyID>(list.begin()->first).ToString(), coinbaseAddress);
692 BOOST_CHECK_EQUAL(boost::get<CKeyID>(list.begin()->first).ToString(), coinbaseAddress);
693 auto output = list.begin()->second[0].ToString();
698 std::vector<COutput> available;
701 for (
const auto &group : list)
703 for (
const auto &coin : group.second)
715 BOOST_CHECK_EQUAL(boost::get<CKeyID>(list.begin()->first).ToString(), coinbaseAddress);
CDiskBlockPos GetBlockPos() const
void SetMerkleBranch(const CBlockIndex *pIndex, int posInBlock)
boost::variant< CNoDestination, CKeyID, CScriptID > CTxDestination
A txout script template with a specific destination.
const CWalletTx * GetWalletTx(const uint256 &hash) const
CAmount GetImmatureBalance() const
bool SelectCoinsMinConf(const CAmount &nTargetValue, int nConfMine, int nConfTheirs, uint64_t nMaxAncestors, std::vector< COutput > vCoins, std::set< CInputCoin > &setCoinsRet, CAmount &nValueRet) const
Shuffle and select coins until nTargetValue is reached while avoiding small change; This method is st...
CAmount GetAvailableBalance(const CCoinControl *coinControl=nullptr) const
std::vector< std::string > GetDestValues(const std::string &prefix) const
Get all destination values matching a prefix.
CCriticalSection cs_wallet
const uint256 & GetHash() const
CPubKey GetPubKey() const
Compute the public key from a private key.
BOOST_AUTO_TEST_CASE(coin_selection_test)
bool AddKeyPubKey(const CKey &key, const CPubKey &pubkey) override
Adds a key to the store, and saves it to disk.
void SetMockTime(int64_t nMockTimeIn)
CCriticalSection cs_main
Global state.
std::string HexStr(const T itbegin, const T itend, bool fSpaces=false)
CScript GetScriptForRawPubKey(const CPubKey &pubKey)
Generate a P2PK script for the given pubkey.
std::string write(unsigned int prettyIndent=0, unsigned int indentLevel=0) const
void Flush(bool fShutdown)
CBlockIndex * ScanForWalletTransactions(CBlockIndex *pindexStart, CBlockIndex *pindexStop, bool fUpdate=false)
Scan the block chain (starting in pindexStart) for transactions from or to us.
std::vector< CWalletRef > vpwallets
CBlockIndex * Genesis() const
Returns the index entry for the genesis block of this chain, or nullptr if none.
void MarkDirty()
make sure balances are recalculated
std::map< CTxDestination, CKeyMetadata > mapKeyMetadata
CAmount GetImmatureCredit(bool fUseCache=true) const
#define L(x0, x1, x2, x3, x4, x5, x6, x7)
CWalletTx & AddTx(CRecipient recipient)
int64_t CAmount
Amount in corbies (Can be negative)
uint256 GetBlockHash() const
bool CreateTransaction(const std::vector< CRecipient > &vecSend, CWalletTx &wtxNew, CReserveKey &reservekey, CAmount &nFeeRet, int &nChangePosInOut, std::string &strFailReason, const CCoinControl &coin_control, bool sign=true)
An instance of this class represents one database.
bool push_back(const UniValue &val)
void PruneOneBlockFile(const int fileNumber)
Mark one block file as pruned.
DBErrors LoadWallet(bool &fFirstRunRet)
std::unique_ptr< CWallet > wallet
void AvailableCoins(std::vector< COutput > &vCoins, bool fOnlySafe=true, const CCoinControl *coinControl=nullptr, const CAmount &nMinimumAmount=1, const CAmount &nMaximumAmount=MAX_MONEY, const CAmount &nMinimumSumAmount=MAX_MONEY, const uint64_t &nMaximumCount=0, const int &nMinDepth=0, const int &nMaxDepth=9999999) const
populate vCoins with vector of available COutputs.
void MakeNewKey(bool fCompressed)
Generate a new private key using a cryptographic PRNG.
int64_t GetBlockTimeMax() const
void UnlinkPrunedFiles(const std::set< int > &setFilesToPrune)
Actually unlink the specified files.
bool pushKV(const std::string &key, const UniValue &val)
CChain chainActive
The currently-connected chain of blocks (protected by cs_main).
An outpoint - a combination of a transaction hash and an index n into its vout.
CBlockFileInfo * GetBlockFileInfo(size_t n)
Get block file info entry for one block file.
BOOST_FIXTURE_TEST_CASE(rescan_test, TestChain100Setup)
std::vector< CTxOut > vout
void LockCoin(const COutPoint &output)
bool AddToWallet(const CWalletTx &wtxIn, bool fFlushOnClose=true)
A transaction with a bunch of additional info that only the owner cares about.
UniValue importmulti(const JSONRPCRequest &request)
UniValue dumpwallet(const JSONRPCRequest &request)
std::map< CTxDestination, std::vector< COutput > > ListCoins() const
Return list of available coins and locked coins grouped by non-change output address.
#define BOOST_FIXTURE_TEST_SUITE(a, b)
A key allocated from the key pool.
Testing setup and teardown for wallet.
#define BOOST_CHECK_EQUAL(v1, v2)
The block chain is a tree shaped structure starting with the genesis block at the root...
A reference to a CKey: the Hash160 of its serialized public key.
CBlockIndex * Tip() const
Returns the index entry for the tip of this chain, or nullptr if none.
#define BOOST_AUTO_TEST_SUITE_END()
A CWallet is an extension of a keystore, which also maintains a set of transactions and balances...
bool error(const char *fmt, const Args &... args)
std::map< uint256, CWalletTx > mapWallet
A mutable version of CTransaction.
std::set< CInputCoin > CoinSet
An encapsulated private key.
bool AddDestData(const CTxDestination &dest, const std::string &key, const std::string &value)
Adds a destination data tuple to the store, and saves it to disk.
UniValue importwallet(const JSONRPCRequest &request)
#define BOOST_CHECK(expr)
std::vector< std::unique_ptr< CWalletTx > > wtxn
bool CommitTransaction(CWalletTx &wtxNew, CReserveKey &reservekey, CConnman *connman, CValidationState &state)
RVN END.
const uint256 * phashBlock
pointer to the hash of the block, if any. Memory is owned by this CBlockIndex