monero/tests/core_tests/ring_signature_1.h

66 lines
2.3 KiB
C
Raw Normal View History

2014-03-03 23:07:58 +01:00
// Copyright (c) 2012-2013 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 "chaingen.h"
/************************************************************************/
/* */
/************************************************************************/
class gen_ring_signature_1 : public test_chain_unit_base
{
public:
gen_ring_signature_1();
bool generate(std::vector<test_event_entry>& events) const;
bool check_balances_1(cryptonote::core& c, size_t ev_index, const std::vector<test_event_entry>& events);
bool check_balances_2(cryptonote::core& c, size_t ev_index, const std::vector<test_event_entry>& events);
private:
cryptonote::account_base m_bob_account;
cryptonote::account_base m_alice_account;
};
/************************************************************************/
/* */
/************************************************************************/
class gen_ring_signature_2 : public test_chain_unit_base
{
public:
gen_ring_signature_2();
bool generate(std::vector<test_event_entry>& events) const;
bool check_balances_1(cryptonote::core& c, size_t ev_index, const std::vector<test_event_entry>& events);
bool check_balances_2(cryptonote::core& c, size_t ev_index, const std::vector<test_event_entry>& events);
private:
cryptonote::account_base m_bob_account;
cryptonote::account_base m_alice_account;
};
/************************************************************************/
/* */
/************************************************************************/
class gen_ring_signature_big : public test_chain_unit_base
{
public:
gen_ring_signature_big();
bool generate(std::vector<test_event_entry>& events) const;
bool check_balances_1(cryptonote::core& c, size_t ev_index, const std::vector<test_event_entry>& events);
bool check_balances_2(cryptonote::core& c, size_t ev_index, const std::vector<test_event_entry>& events);
private:
size_t m_test_size;
uint64_t m_tx_amount;
cryptonote::account_base m_bob_account;
cryptonote::account_base m_alice_account;
};