From ed597441678604f6bf44513532ad282e4d5593be Mon Sep 17 00:00:00 2001 From: Egor Tensin Date: Mon, 14 Sep 2020 04:51:52 +0300 Subject: unit_tests: more call stack tests --- test/unit_tests/fixtures.hpp | 82 ++++++++++++++++++++++++++++++++++---------- 1 file changed, 63 insertions(+), 19 deletions(-) (limited to 'test/unit_tests/fixtures.hpp') diff --git a/test/unit_tests/fixtures.hpp b/test/unit_tests/fixtures.hpp index eb7dcc0..fadd393 100644 --- a/test/unit_tests/fixtures.hpp +++ b/test/unit_tests/fixtures.hpp @@ -3,6 +3,7 @@ #include "paths.hpp" #include +#include #include #include @@ -12,19 +13,6 @@ #include #include -class DbgHelp { -public: - DbgHelp() : dbghelp{pdb::DbgHelp::post_mortem()} { BOOST_TEST_MESSAGE("Initializing DbgHelp"); } - - ~DbgHelp() { BOOST_TEST_MESSAGE("Cleaning up DbgHelp"); } - - const pdb::DbgHelp dbghelp; - -private: - DbgHelp(const DbgHelp&) = delete; - DbgHelp& operator=(const DbgHelp&) = delete; -}; - template using Set = std::unordered_set; @@ -34,9 +22,18 @@ Set join(Set&& xs, Set&& ys) { return std::move(xs); } -class DbgHelpWithSymbols : public DbgHelp { +class DbgHelp { public: - DbgHelpWithSymbols() { load_test_lib_pdb(); } + DbgHelp(pdb::DbgHelp&& dbghelp) : dbghelp{std::move(dbghelp)} {} + + ~DbgHelp() { BOOST_TEST_MESSAGE("Cleaning up DbgHelp"); } + + const pdb::DbgHelp dbghelp; + + static const std::string& get_module_name() { + static const std::string name{"test_lib"}; + return name; + } static const std::string& get_namespace() { static const std::string name{"test_ns"}; @@ -44,16 +41,41 @@ public: } typedef Set SymbolList; + typedef Set AddressList; + + static AddressList expected_function_addresses() { + return cast({&test_ns::foo, &test_ns::bar, &test_ns::baz}); + } static SymbolList expected_functions() { return make_qualified({"foo", "bar", "baz"}); } + static SymbolList expected_functions_full() { return add_module(expected_functions()); } + static SymbolList expected_variables() { return make_qualified({"var"}); } static SymbolList expected_symbols() { return join(expected_functions(), expected_variables()); } +protected: + static pdb::DbgHelp init_dbghelp(bool current_process) { + BOOST_TEST_MESSAGE("Initializing DbgHelp"); + if (current_process) { + return pdb::DbgHelp::current_process(); + } else { + return pdb::DbgHelp::post_mortem(); + } + } + private: + static AddressList cast(Set&& fs) { + AddressList addresses; + for (auto&& f : fs) { + addresses.emplace(reinterpret_cast(f)); + } + return addresses; + } + static SymbolList make_qualified(SymbolList&& plain) { SymbolList qualified; for (auto&& name : plain) { @@ -62,13 +84,35 @@ private: return qualified; } - void load_test_lib_pdb() { - const auto pdb_path = get_test_lib_pdb_path().string(); + static SymbolList add_module(SymbolList&& plain) { + SymbolList full; + for (auto&& name : plain) { + full.emplace(get_module_name() + "!" + std::move(name)); + } + return full; + } + + DbgHelp(const DbgHelp&) = delete; + DbgHelp& operator=(const DbgHelp&) = delete; +}; + +class PostMortem : public DbgHelp { +public: + PostMortem() : DbgHelp{init_dbghelp(false)} { load_module_pdb(); } + +private: + void load_module_pdb() { + const auto pdb_path = get_module_pdb_path().string(); BOOST_TEST_MESSAGE("Loading PDB: " << pdb_path); dbghelp.load_pdb(pdb_path); } - static boost::filesystem::path get_test_lib_pdb_path() { - return Paths::get().exe_dir / "test_lib.pdb"; + static boost::filesystem::path get_module_pdb_path() { + return Paths::get().exe_dir / (get_module_name() + ".pdb"); } }; + +class CurrentProcess : public DbgHelp { +public: + CurrentProcess() : DbgHelp{init_dbghelp(true)} {} +}; -- cgit v1.2.3