tests: pass data dir as arg

This fixes test failure on builds that happen
to be built in 'build/' instead of 'build/release'.

Use boost filesystem path type.
This commit is contained in:
redfish 2017-09-25 02:46:14 +00:00
parent 1f9058187c
commit 540d6fa3d5
5 changed files with 33 additions and 10 deletions

View File

@ -30,6 +30,7 @@
# The docs say this only affects grouping in IDEs # The docs say this only affects grouping in IDEs
set(folder "tests") set(folder "tests")
set(TEST_DATA_DIR "${CMAKE_CURRENT_LIST_DIR}/data")
if (WIN32 AND STATIC) if (WIN32 AND STATIC)
add_definitions(-DSTATICLIB) add_definitions(-DSTATICLIB)

View File

@ -97,4 +97,4 @@ endif ()
add_test( add_test(
NAME unit_tests NAME unit_tests
COMMAND unit_tests) COMMAND unit_tests "${TEST_DATA_DIR}")

View File

@ -30,14 +30,32 @@
#include "gtest/gtest.h" #include "gtest/gtest.h"
#include <boost/filesystem.hpp>
#include "include_base_utils.h" #include "include_base_utils.h"
#include "unit_tests_utils.h"
boost::filesystem::path unit_test::data_dir;
int main(int argc, char** argv) int main(int argc, char** argv)
{ {
epee::string_tools::set_module_name_and_folder(argv[0]);
mlog_configure(mlog_get_default_log_path("unit_tests.log"), true); mlog_configure(mlog_get_default_log_path("unit_tests.log"), true);
epee::debug::get_set_enable_assert(true, false); epee::debug::get_set_enable_assert(true, false);
::testing::InitGoogleTest(&argc, argv); ::testing::InitGoogleTest(&argc, argv);
// Process remaining arguments
if (argc == 2 && argv[1] != NULL) { // one arg: path to dir with test data
unit_test::data_dir = argv[1];
} else if (argc == 1) { // legacy: assume test binaries in 'build/release'
epee::string_tools::set_module_name_and_folder(argv[0]);
unit_test::data_dir = boost::filesystem::path(epee::string_tools::get_current_module_folder())
.parent_path().parent_path().parent_path().parent_path()
.append("tests").append("data");
} else {
std::cerr << "Usage: " << argv[0] << " [<path-to-test-data-dir>]" << std::endl;
return 1;
}
return RUN_ALL_TESTS(); return RUN_ALL_TESTS();
} }

View File

@ -47,6 +47,7 @@
#include "serialization/binary_utils.h" #include "serialization/binary_utils.h"
#include "wallet/wallet2.h" #include "wallet/wallet2.h"
#include "gtest/gtest.h" #include "gtest/gtest.h"
#include "unit_tests_utils.h"
using namespace std; using namespace std;
struct Struct struct Struct
@ -671,12 +672,12 @@ TEST(Serialization, portability_wallet)
const bool testnet = true; const bool testnet = true;
const bool restricted = false; const bool restricted = false;
tools::wallet2 w(testnet, restricted); tools::wallet2 w(testnet, restricted);
string wallet_file = epee::string_tools::get_current_module_folder() + "/../../../../tests/data/wallet_9svHk1"; const boost::filesystem::path wallet_file = unit_test::data_dir / "wallet_9svHk1";
string password = "test"; string password = "test";
bool r = false; bool r = false;
try try
{ {
w.load(wallet_file, password); w.load(wallet_file.native(), password);
r = true; r = true;
} }
catch (const exception& e) catch (const exception& e)
@ -791,9 +792,9 @@ TEST(Serialization, portability_wallet)
TEST(Serialization, portability_outputs) TEST(Serialization, portability_outputs)
{ {
// read file // read file
const std::string filename = epee::string_tools::get_current_module_folder() + "/../../../../tests/data/outputs"; const boost::filesystem::path filename = unit_test::data_dir / "outputs";
std::string data; std::string data;
bool r = epee::file_io_utils::load_file_to_string(filename, data); bool r = epee::file_io_utils::load_file_to_string(filename.native(), data);
ASSERT_TRUE(r); ASSERT_TRUE(r);
const size_t magiclen = strlen(OUTPUT_EXPORT_FILE_MAGIC); const size_t magiclen = strlen(OUTPUT_EXPORT_FILE_MAGIC);
ASSERT_FALSE(data.size() < magiclen || memcmp(data.data(), OUTPUT_EXPORT_FILE_MAGIC, magiclen)); ASSERT_FALSE(data.size() < magiclen || memcmp(data.data(), OUTPUT_EXPORT_FILE_MAGIC, magiclen));
@ -906,10 +907,10 @@ TEST(Serialization, portability_outputs)
#define UNSIGNED_TX_PREFIX "Monero unsigned tx set\003" #define UNSIGNED_TX_PREFIX "Monero unsigned tx set\003"
TEST(Serialization, portability_unsigned_tx) TEST(Serialization, portability_unsigned_tx)
{ {
const string filename = epee::string_tools::get_current_module_folder() + "/../../../../tests/data/unsigned_monero_tx"; const boost::filesystem::path filename = unit_test::data_dir / "unsigned_monero_tx";
std::string s; std::string s;
const bool testnet = true; const bool testnet = true;
bool r = epee::file_io_utils::load_file_to_string(filename, s); bool r = epee::file_io_utils::load_file_to_string(filename.native(), s);
ASSERT_TRUE(r); ASSERT_TRUE(r);
const size_t magiclen = strlen(UNSIGNED_TX_PREFIX); const size_t magiclen = strlen(UNSIGNED_TX_PREFIX);
ASSERT_FALSE(strncmp(s.c_str(), UNSIGNED_TX_PREFIX, magiclen)); ASSERT_FALSE(strncmp(s.c_str(), UNSIGNED_TX_PREFIX, magiclen));
@ -1054,10 +1055,10 @@ TEST(Serialization, portability_unsigned_tx)
#define SIGNED_TX_PREFIX "Monero signed tx set\003" #define SIGNED_TX_PREFIX "Monero signed tx set\003"
TEST(Serialization, portability_signed_tx) TEST(Serialization, portability_signed_tx)
{ {
const string filename = epee::string_tools::get_current_module_folder() + "/../../../../tests/data/signed_monero_tx"; const boost::filesystem::path filename = unit_test::data_dir / "signed_monero_tx";
const bool testnet = true; const bool testnet = true;
std::string s; std::string s;
bool r = epee::file_io_utils::load_file_to_string(filename, s); bool r = epee::file_io_utils::load_file_to_string(filename.native(), s);
ASSERT_TRUE(r); ASSERT_TRUE(r);
const size_t magiclen = strlen(SIGNED_TX_PREFIX); const size_t magiclen = strlen(SIGNED_TX_PREFIX);
ASSERT_FALSE(strncmp(s.c_str(), SIGNED_TX_PREFIX, magiclen)); ASSERT_FALSE(strncmp(s.c_str(), SIGNED_TX_PREFIX, magiclen));

View File

@ -31,9 +31,12 @@
#pragma once #pragma once
#include <atomic> #include <atomic>
#include <boost/filesystem.hpp>
namespace unit_test namespace unit_test
{ {
extern boost::filesystem::path data_dir;
class call_counter class call_counter
{ {
public: public: