// Copyright (c) 2011-2015 The Cryptonote developers // Distributed under the MIT/X11 software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #pragma once #include #include #include #include #include "crypto/hash.h" #include "cryptonote_core/cryptonote_basic.h" #include "cryptonote_core/cryptonote_basic_impl.h" #include "cryptonote_core/cryptonote_format_utils.h" #include "cryptonote_core/Currency.h" #include "cryptonote_core/difficulty.h" class test_generator { public: struct BlockInfo { BlockInfo() : prevId() , alreadyGeneratedCoins(0) , blockSize(0) { } BlockInfo(crypto::hash aPrevId, uint64_t anAlreadyGeneratedCoins, size_t aBlockSize) : prevId(aPrevId) , alreadyGeneratedCoins(anAlreadyGeneratedCoins) , blockSize(aBlockSize) { } crypto::hash prevId; uint64_t alreadyGeneratedCoins; size_t blockSize; }; enum BlockFields { bf_none = 0, bf_major_ver = 1 << 0, bf_minor_ver = 1 << 1, bf_timestamp = 1 << 2, bf_prev_id = 1 << 3, bf_miner_tx = 1 << 4, bf_tx_hashes = 1 << 5, bf_diffic = 1 << 6 }; test_generator(const cryptonote::Currency& currency, uint8_t majorVersion = cryptonote::BLOCK_MAJOR_VERSION_1, uint8_t minorVersion = cryptonote::BLOCK_MINOR_VERSION_0) : m_currency(currency), defaultMajorVersion(majorVersion), defaultMinorVersion(minorVersion) { } uint8_t defaultMajorVersion; uint8_t defaultMinorVersion; const cryptonote::Currency& currency() const { return m_currency; } void getBlockchain(std::vector& blockchain, const crypto::hash& head, size_t n) const; void getLastNBlockSizes(std::vector& blockSizes, const crypto::hash& head, size_t n) const; uint64_t getAlreadyGeneratedCoins(const crypto::hash& blockId) const; uint64_t getAlreadyGeneratedCoins(const cryptonote::Block& blk) const; void addBlock(const cryptonote::Block& blk, size_t tsxSize, uint64_t fee, std::vector& blockSizes, uint64_t alreadyGeneratedCoins); bool constructBlock(cryptonote::Block& blk, uint64_t height, const crypto::hash& prevId, const cryptonote::account_base& minerAcc, uint64_t timestamp, uint64_t alreadyGeneratedCoins, std::vector& blockSizes, const std::list& txList); bool constructBlock(cryptonote::Block& blk, const cryptonote::account_base& minerAcc, uint64_t timestamp); bool constructBlock(cryptonote::Block& blk, const cryptonote::Block& blkPrev, const cryptonote::account_base& minerAcc, const std::list& txList = std::list()); bool constructBlockManually(cryptonote::Block& blk, const cryptonote::Block& prevBlock, const cryptonote::account_base& minerAcc, int actualParams = bf_none, uint8_t majorVer = 0, uint8_t minorVer = 0, uint64_t timestamp = 0, const crypto::hash& prevId = crypto::hash(), const cryptonote::difficulty_type& diffic = 1, const cryptonote::Transaction& minerTx = cryptonote::Transaction(), const std::vector& txHashes = std::vector(), size_t txsSizes = 0, uint64_t fee = 0); bool constructBlockManuallyTx(cryptonote::Block& blk, const cryptonote::Block& prevBlock, const cryptonote::account_base& minerAcc, const std::vector& txHashes, size_t txsSize); bool constructMaxSizeBlock(cryptonote::Block& blk, const cryptonote::Block& blkPrev, const cryptonote::account_base& minerAccount, size_t medianBlockCount = 0, const std::list& txList = std::list()); private: const cryptonote::Currency& m_currency; std::unordered_map m_blocksInfo; }; inline cryptonote::difficulty_type getTestDifficulty() { return 1; } void fillNonce(cryptonote::Block& blk, const cryptonote::difficulty_type& diffic); bool constructMinerTxManually(const cryptonote::Currency& currency, size_t height, uint64_t alreadyGeneratedCoins, const cryptonote::AccountPublicAddress& minerAddress, cryptonote::Transaction& tx, uint64_t fee, cryptonote::KeyPair* pTxKey = 0); bool constructMinerTxBySize(const cryptonote::Currency& currency, cryptonote::Transaction& minerTx, uint64_t height, uint64_t alreadyGeneratedCoins, const cryptonote::AccountPublicAddress& minerAddress, std::vector& blockSizes, size_t targetTxSize, size_t targetBlockSize, uint64_t fee = 0);