diff options
author | Antonio Juarez <antonio.maria.juarez@live.com> | 2014-03-03 22:07:58 +0000 |
---|---|---|
committer | Antonio Juarez <antonio.maria.juarez@live.com> | 2014-03-03 22:07:58 +0000 |
commit | 296ae46ed8f8f6e5f986f978febad302e3df231a (patch) | |
tree | 1629164454a239308f33c9e12afb22e7f3cd8eeb /tests/daemon_tests | |
parent | changed name (diff) | |
download | monero-296ae46ed8f8f6e5f986f978febad302e3df231a.tar.xz |
moved all stuff to github
Diffstat (limited to '')
-rw-r--r-- | tests/daemon_tests/CMakeLists.txt | 5 | ||||
-rw-r--r-- | tests/daemon_tests/transfers.cpp | 77 |
2 files changed, 82 insertions, 0 deletions
diff --git a/tests/daemon_tests/CMakeLists.txt b/tests/daemon_tests/CMakeLists.txt new file mode 100644 index 000000000..68ca3a87e --- /dev/null +++ b/tests/daemon_tests/CMakeLists.txt @@ -0,0 +1,5 @@ +add_executable(transfers transfers.cpp) +target_link_libraries(transfers useragent rpc cryptonote_core crypto common epee gtest_main ${Boost_LIBRARIES}) + +file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/test_transfers) +add_custom_target(test_transfers COMMAND transfers WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/test_transfers) diff --git a/tests/daemon_tests/transfers.cpp b/tests/daemon_tests/transfers.cpp new file mode 100644 index 000000000..23b8b8335 --- /dev/null +++ b/tests/daemon_tests/transfers.cpp @@ -0,0 +1,77 @@ +// 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. + +#include "gtest/gtest.h" +#include <sstream> +#include "wallet/wallet.h" +#include "rpc/core_rpc_server.h" +#include "cryptonote_core/account.h" +#include "net/http_client_abstract_invoke.h" +using namespace std; +using namespace epee::misc_utils; +using namespace cryptonote; + +string daemon_address = "http://localhost:23400"; + +#define ACCS 5 + +TEST(Transfers, Transfers) +{ + log_space::get_set_log_detalisation_level(true, LOG_LEVEL_3); + log_space::log_singletone::add_logger(LOGGER_CONSOLE, NULL, NULL); + + cout << "TESTING: transfers" << endl; + + net_utils::http::http_simple_client http_client; + wallet miner, accs[100], receiver; + miner.generate(); + ASSERT_TRUE(miner.init()); + ASSERT_TRUE(miner.store("miner.b2wallet")); + cout << "miner: " << miner.get_account().get_public_address_str() << endl; + + for (int i = 0; i < ACCS; i++) { + ostringstream s; + s << "acc" << setw(2) << setfill('0') << i << ".b2wallet"; + accs[i].generate(); + assert(accs[i].init()); + assert(accs[i].store(s.str())); + } + receiver.generate(); + assert(receiver.init()); + receiver.store("receiver.b2wallet"); + + { + COMMAND_RPC_START_MINE::request req; + req.miner_address = miner.get_account().get_public_address_str(); + req.threads_count = 1; + COMMAND_RPC_START_MINE::response res; + bool r = net_utils::http::invoke_http_json_remote_command(daemon_address + "/start_mine", req, res, http_client); + ASSERT_TRUE(r); + } + + string s; + //getline(cin, s); + sleep_no_w(1000); + ASSERT_TRUE(miner.refresh()); + cout << "miner balance: " << miner.balance() << endl; + + vector<pair<account_public_address, uint64_t>> d_accs; + for (int i = 0; i < ACCS; i++) + d_accs.push_back(make_pair(accs[i].get_account().get_keys().m_account_address, 1)); + ASSERT_TRUE(miner.transfer(d_accs)); + + //getline(cin, s); + sleep_no_w(1000); + for (int i = 0; i < ACCS; i++) { + ASSERT_TRUE(accs[i].refresh()); + ASSERT_TRUE(accs[i].transfer(receiver.get_account().get_keys().m_account_address, 1)); + } + + //getline(cin, s); + cout << "wait for block" << endl; + sleep_no_w(10000); + receiver.refresh(); + ASSERT_TRUE(receiver.balance() == ACCS); + cout << "OK" << endl; +} |