aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/test/unit_tests/dbghelp.cpp
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2020-03-24 19:22:40 +0300
committerEgor Tensin <Egor.Tensin@gmail.com>2020-03-27 11:25:22 +0300
commit10b3c9e5a8ce46cfbc3c80042fcaf6079f6a8a34 (patch)
tree13cb9beac308afab5ec1188bb73f28beb64eafe2 /test/unit_tests/dbghelp.cpp
parentfix a bug where I failed to account for TCHARs, again (diff)
downloadwinapi-debug-10b3c9e5a8ce46cfbc3c80042fcaf6079f6a8a34.tar.gz
winapi-debug-10b3c9e5a8ce46cfbc3c80042fcaf6079f6a8a34.zip
add some unit tests
Diffstat (limited to '')
-rw-r--r--test/unit_tests/dbghelp.cpp95
1 files changed, 95 insertions, 0 deletions
diff --git a/test/unit_tests/dbghelp.cpp b/test/unit_tests/dbghelp.cpp
new file mode 100644
index 0000000..86cf1ff
--- /dev/null
+++ b/test/unit_tests/dbghelp.cpp
@@ -0,0 +1,95 @@
+#include "utils.hpp"
+
+#include <pdb/all.hpp>
+
+#include <boost/filesystem.hpp>
+#include <boost/test/unit_test.hpp>
+
+#include <iterator>
+#include <string>
+#include <unordered_set>
+#include <utility>
+
+namespace {
+
+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 <typename T>
+using Set = std::unordered_set<T>;
+
+template <typename T>
+Set<T> join(Set<T>&& xs, Set<T>&& ys) {
+ xs.insert(std::make_move_iterator(ys.begin()), std::make_move_iterator(ys.end()));
+ return std::move(xs);
+}
+
+class DbgHelpWithSymbols : public DbgHelp {
+public:
+ DbgHelpWithSymbols() { load_symbols_pdb(); }
+
+ static const std::string& get_namespace() {
+ static const std::string name{"foobar_ns"};
+ return name;
+ }
+
+ typedef std::unordered_set<std::string> SymbolList;
+
+ static SymbolList expected_functions() { return make_qualified({"foo", "bar", "baz"}); }
+
+ static SymbolList expected_variables() { return make_qualified({"exit_code"}); }
+
+ static SymbolList expected_symbols() {
+ return join(expected_functions(), expected_variables());
+ }
+
+private:
+ static SymbolList make_qualified(SymbolList&& plain) {
+ SymbolList qualified;
+ for (auto&& name : plain) {
+ qualified.emplace(get_namespace() + "::" + std::move(name));
+ }
+ return qualified;
+ }
+
+ void load_symbols_pdb() {
+ const auto pdb_path = get_symbols_pdb_path().string();
+ BOOST_TEST_MESSAGE("Loading PDB: " << pdb_path);
+ dbghelp.load_pdb(pdb_path);
+ }
+
+ static boost::filesystem::path get_symbols_pdb_path() {
+ return Paths::get().exe_dir / "symbols.pdb";
+ }
+};
+
+} // namespace
+
+BOOST_AUTO_TEST_SUITE(dbghelp_tests)
+BOOST_FIXTURE_TEST_SUITE(enum_symbols_tests, DbgHelpWithSymbols)
+
+BOOST_AUTO_TEST_CASE(basic) {
+ // Symbols can be enumerated, and all the expected symbols are there.
+ auto all_symbols = expected_symbols();
+ const auto callback = [&all_symbols](const pdb::SymbolInfo& symbol) {
+ const auto name = symbol.get_name();
+ all_symbols.erase(name);
+ };
+ dbghelp.enum_symbols(callback);
+ for (const auto& missing : all_symbols) {
+ BOOST_TEST(false, "Symbol wasn't enumerated: " << missing);
+ }
+}
+
+BOOST_AUTO_TEST_SUITE_END()
+BOOST_AUTO_TEST_SUITE_END()