aboutsummaryrefslogtreecommitdiff
path: root/tests/daemon_tests
diff options
context:
space:
mode:
authorAntonio Juarez <antonio.maria.juarez@live.com>2014-03-03 22:07:58 +0000
committerAntonio Juarez <antonio.maria.juarez@live.com>2014-03-03 22:07:58 +0000
commit296ae46ed8f8f6e5f986f978febad302e3df231a (patch)
tree1629164454a239308f33c9e12afb22e7f3cd8eeb /tests/daemon_tests
parentchanged name (diff)
downloadmonero-296ae46ed8f8f6e5f986f978febad302e3df231a.tar.xz
moved all stuff to github
Diffstat (limited to 'tests/daemon_tests')
-rw-r--r--tests/daemon_tests/CMakeLists.txt5
-rw-r--r--tests/daemon_tests/transfers.cpp77
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;
+}