1
0
Fork 0
forked from lthn/blockchain
blockchain/tests/performance_tests/main.cpp

141 lines
5 KiB
C++
Raw Permalink Normal View History

2018-12-27 18:50:45 +03: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.
#include "performance_tests.h"
#include "performance_utils.h"
#include <mutex>
// tests
#include "construct_tx.h"
#include "check_ring_signature.h"
#include "derive_public_key.h"
#include "derive_secret_key.h"
#include "generate_key_derivation.h"
#include "generate_key_image.h"
#include "generate_key_image_helper.h"
#include "is_out_to_acc.h"
#include "core_market_performance_test.h"
#include "serialization_performance_test.h"
#include "chacha_stream_performance_test.h"
2019-01-08 18:51:57 +03:00
#include "keccak_test.h"
#include "blake2_test.h"
#include "print_struct_to_json.h"
#include "free_space_check.h"
#include "htlc_hash_tests.h"
#include "threads_pool_tests.h"
#include "wallet/plain_wallet_api.h"
#include "wallet/view_iface.h"
void test_plain_wallet()
{
std::string res = plain_wallet::init("195.201.107.230", "33336", "E:\\tmp\\", 0);
uint64_t instance_id = 0;
res = plain_wallet::open("test.zan", "111");
while(true)
{
epee::misc_utils::sleep_no_w(2000);
res = plain_wallet::sync_call("get_wallet_status", instance_id, "");
view::wallet_sync_status_info wsi = AUTO_VAL_INIT(wsi);
epee::serialization::load_t_from_json(wsi, res);
if (wsi.wallet_state == 2)
break;
}
std::string invoke_body = "{\"method\":\"get_recent_txs_and_info\",\"params\":{\"offset\":0,\"count\":30,\"update_provision_info\":true}}";
res = plain_wallet::sync_call("invoke", instance_id, invoke_body);
LOG_PRINT_L0(res);
}
2018-12-27 18:50:45 +03:00
int main(int argc, char** argv)
{
epee::string_tools::set_module_name_and_folder(argv[0]);
epee::log_space::get_set_log_detalisation_level(true, LOG_LEVEL_2);
epee::log_space::log_singletone::add_logger(LOGGER_CONSOLE, NULL, NULL, LOG_LEVEL_2);
epee::log_space::log_singletone::add_logger(LOGGER_FILE,
epee::log_space::log_singletone::get_default_log_file().c_str(),
epee::log_space::log_singletone::get_default_log_folder().c_str());
2018-12-27 18:50:45 +03:00
test_plain_wallet();
//parse_weird_tx();
//thread_pool_tests();
// std::string buf1 = tools::get_varint_data<uint64_t>(CURRENCY_PUBLIC_ADDRESS_BASE58_PREFIX);
// std::string buf2 = tools::get_varint_data<uint64_t>(CURRENCY_PUBLIC_INTEG_ADDRESS_BASE58_PREFIX);
// std::string buf3 = tools::get_varint_data<uint64_t>(CURRENCY_PUBLIC_INTEG_ADDRESS_V2_BASE58_PREFIX);
// std::string buf4 = tools::get_varint_data<uint64_t>(CURRENCY_PUBLIC_AUDITABLE_ADDRESS_BASE58_PREFIX);
// std::string buf5 = tools::get_varint_data<uint64_t>(CURRENCY_PUBLIC_AUDITABLE_INTEG_ADDRESS_BASE58_PREFIX);
//
// std::cout << "Buf1: " << epee::string_tools::buff_to_hex_nodelimer(buf1) << ENDL;
// std::cout << "Buf2: " << epee::string_tools::buff_to_hex_nodelimer(buf2) << ENDL;
// std::cout << "Buf3: " << epee::string_tools::buff_to_hex_nodelimer(buf3) << ENDL;
// std::cout << "Buf4: " << epee::string_tools::buff_to_hex_nodelimer(buf4) << ENDL;
// std::cout << "Buf5: " << epee::string_tools::buff_to_hex_nodelimer(buf5) << ENDL;
//
//
//do_htlc_hash_tests();
2019-01-08 18:51:57 +03:00
//run_serialization_performance_test();
2018-12-27 18:50:45 +03:00
//return 1;
//run_core_market_performance_tests(100000);
//set_process_affinity(1);
//set_thread_high_priority();
2018-12-27 18:50:45 +03:00
//do_chacha_stream_performance_test();
//test_blake2();
//free_space_check();
//print_struct_to_json();
//performance_timer timer;
//timer.start();
2018-12-27 18:50:45 +03:00
2019-02-23 23:50:17 +01:00
//generate_scratchpad();
//generate_light_scratchpad();
2019-02-20 20:02:43 +01:00
//measure_keccak_over_scratchpad();
2019-03-25 01:30:20 +01:00
//test_scratchpad_against_light_scratchpad();
2018-12-27 18:50:45 +03:00
/*
TEST_PERFORMANCE2(test_construct_tx, 1, 1);
TEST_PERFORMANCE2(test_construct_tx, 1, 2);
TEST_PERFORMANCE2(test_construct_tx, 1, 10);
TEST_PERFORMANCE2(test_construct_tx, 1, 100);
TEST_PERFORMANCE2(test_construct_tx, 1, 1000);
TEST_PERFORMANCE2(test_construct_tx, 2, 1);
TEST_PERFORMANCE2(test_construct_tx, 2, 2);
TEST_PERFORMANCE2(test_construct_tx, 2, 10);
TEST_PERFORMANCE2(test_construct_tx, 2, 100);
TEST_PERFORMANCE2(test_construct_tx, 10, 1);
TEST_PERFORMANCE2(test_construct_tx, 10, 2);
TEST_PERFORMANCE2(test_construct_tx, 10, 10);
TEST_PERFORMANCE2(test_construct_tx, 10, 100);
TEST_PERFORMANCE2(test_construct_tx, 100, 1);
TEST_PERFORMANCE2(test_construct_tx, 100, 2);
TEST_PERFORMANCE2(test_construct_tx, 100, 10);
TEST_PERFORMANCE2(test_construct_tx, 100, 100);
TEST_PERFORMANCE1(test_check_ring_signature, 1);
TEST_PERFORMANCE1(test_check_ring_signature, 2);
TEST_PERFORMANCE1(test_check_ring_signature, 10);
TEST_PERFORMANCE1(test_check_ring_signature, 100);
*/
2019-01-08 18:51:57 +03:00
//TEST_PERFORMANCE0(test_is_out_to_acc);
2018-12-27 18:50:45 +03:00
//TEST_PERFORMANCE0(test_generate_key_image_helper);
//TEST_PERFORMANCE0(test_generate_key_derivation);
2018-12-27 18:50:45 +03:00
//TEST_PERFORMANCE0(test_generate_key_image);
2019-01-08 18:51:57 +03:00
//TEST_PERFORMANCE0(test_derive_public_key);
2018-12-27 18:50:45 +03:00
//TEST_PERFORMANCE0(test_derive_secret_key);
//std::cout << "Tests finished. Elapsed time: " << timer.elapsed_ms() / 1000 << " sec" << std::endl;
2018-12-27 18:50:45 +03:00
return 0;
}