// Copyright (c) 2011-2013 The Bitcoin Core developers // Distributed under the MIT software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #define BOOST_TEST_MODULE Bitcoin Test Suite #include "test_bitcoin.h" #include "crypto/common.h" #include "key.h" #include "main.h" #include "random.h" #include "txdb.h" #include "txmempool.h" #include "ui_interface.h" #include "util.h" #ifdef ENABLE_WALLET #include "wallet/db.h" #include "wallet/wallet.h" #endif #include #include #include #include "librustzcash.h" CClientUIInterface uiInterface; // Declared but not defined in ui_interface.h CWallet* pwalletMain; ZCJoinSplit *pzcashParams; extern bool fPrintToConsole; extern void noui_connect(); JoinSplitTestingSetup::JoinSplitTestingSetup() { boost::filesystem::path pk_path = ZC_GetParamsDir() / "sprout-proving.key"; boost::filesystem::path vk_path = ZC_GetParamsDir() / "sprout-verifying.key"; pzcashParams = ZCJoinSplit::Prepared(vk_path.string(), pk_path.string()); boost::filesystem::path sapling_spend = ZC_GetParamsDir() / "sapling-spend-testnet.params"; boost::filesystem::path sapling_output = ZC_GetParamsDir() / "sapling-output-testnet.params"; boost::filesystem::path sprout_groth16 = ZC_GetParamsDir() / "sprout-groth16-testnet.params"; std::string sapling_spend_str = sapling_spend.string(); std::string sapling_output_str = sapling_output.string(); std::string sprout_groth16_str = sprout_groth16.string(); librustzcash_init_zksnark_params( sapling_spend_str.c_str(), sapling_output_str.c_str(), sprout_groth16_str.c_str() ); } JoinSplitTestingSetup::~JoinSplitTestingSetup() { delete pzcashParams; } BasicTestingSetup::BasicTestingSetup() { assert(init_and_check_sodium() != -1); ECC_Start(); SetupEnvironment(); fPrintToDebugLog = false; // don't want to write to debug.log file fCheckBlockIndex = true; SelectParams(CBaseChainParams::MAIN); } BasicTestingSetup::~BasicTestingSetup() { ECC_Stop(); } TestingSetup::TestingSetup() { #ifdef ENABLE_WALLET bitdb.MakeMock(); #endif ClearDatadirCache(); pathTemp = GetTempPath() / strprintf("test_bitcoin_%lu_%i", (unsigned long)GetTime(), (int)(GetRand(100000))); boost::filesystem::create_directories(pathTemp); mapArgs["-datadir"] = pathTemp.string(); pblocktree = new CBlockTreeDB(1 << 20, true); pcoinsdbview = new CCoinsViewDB(1 << 23, true); pcoinsTip = new CCoinsViewCache(pcoinsdbview); InitBlockIndex(); #ifdef ENABLE_WALLET bool fFirstRun; pwalletMain = new CWallet("wallet.dat"); pwalletMain->LoadWallet(fFirstRun); RegisterValidationInterface(pwalletMain); #endif nScriptCheckThreads = 3; for (int i=0; i < nScriptCheckThreads-1; i++) threadGroup.create_thread(&ThreadScriptCheck); RegisterNodeSignals(GetNodeSignals()); } TestingSetup::~TestingSetup() { UnregisterNodeSignals(GetNodeSignals()); threadGroup.interrupt_all(); threadGroup.join_all(); #ifdef ENABLE_WALLET UnregisterValidationInterface(pwalletMain); delete pwalletMain; pwalletMain = NULL; #endif UnloadBlockIndex(); delete pcoinsTip; delete pcoinsdbview; delete pblocktree; #ifdef ENABLE_WALLET bitdb.Flush(true); bitdb.Reset(); #endif boost::filesystem::remove_all(pathTemp); } CTxMemPoolEntry TestMemPoolEntryHelper::FromTx(CMutableTransaction &tx, CTxMemPool *pool) { return CTxMemPoolEntry(tx, nFee, nTime, dPriority, nHeight, pool ? pool->HasNoInputsOf(tx) : hadNoDependencies, spendsCoinbase, nBranchId); } void Shutdown(void* parg) { exit(0); } void StartShutdown() { exit(0); } bool ShutdownRequested() { return false; }