aboutsummaryrefslogtreecommitdiff
path: root/src/processor/source_line_resolver_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/processor/source_line_resolver_unittest.cc')
-rw-r--r--src/processor/source_line_resolver_unittest.cc73
1 files changed, 43 insertions, 30 deletions
diff --git a/src/processor/source_line_resolver_unittest.cc b/src/processor/source_line_resolver_unittest.cc
index c47edce8..b5321085 100644
--- a/src/processor/source_line_resolver_unittest.cc
+++ b/src/processor/source_line_resolver_unittest.cc
@@ -15,9 +15,11 @@
#include <stdio.h>
#include <string>
#include "processor/source_line_resolver.h"
+#include "google/stack_frame.h"
using std::string;
using google_airbag::SourceLineResolver;
+using google_airbag::StackFrame;
#define ASSERT_TRUE(cond) \
if (!(cond)) { \
@@ -29,13 +31,19 @@ using google_airbag::SourceLineResolver;
#define ASSERT_EQ(e1, e2) ASSERT_TRUE((e1) == (e2))
-static bool VerifyEmpty(const SourceLineResolver::SourceLineInfo &info) {
- ASSERT_TRUE(info.function_name.empty());
- ASSERT_TRUE(info.source_file.empty());
- ASSERT_EQ(info.source_line, 0);
+static bool VerifyEmpty(const StackFrame &frame) {
+ ASSERT_TRUE(frame.function_name.empty());
+ ASSERT_TRUE(frame.source_file_name.empty());
+ ASSERT_EQ(frame.source_line, 0);
return true;
}
+static void ClearSourceLineInfo(StackFrame *frame) {
+ frame->function_name.clear();
+ frame->source_file_name.clear();
+ frame->source_line = 0;
+}
+
static bool RunTests() {
string testdata_dir = string(getenv("srcdir") ? getenv("srcdir") : ".") +
"/src/processor/testdata";
@@ -44,32 +52,37 @@ static bool RunTests() {
ASSERT_TRUE(resolver.LoadModule("module1", testdata_dir + "/module1.out"));
ASSERT_TRUE(resolver.LoadModule("module2", testdata_dir + "/module2.out"));
- SourceLineResolver::SourceLineInfo info;
- resolver.LookupAddress(0x1000, "module1", &info);
- ASSERT_EQ(info.function_name, "Function1_1");
- ASSERT_EQ(info.source_file, "file1_1.cc");
- ASSERT_EQ(info.source_line, 44);
-
- info.Reset();
- ASSERT_TRUE(VerifyEmpty(info));
-
- resolver.LookupAddress(0x800, "module1", &info);
- ASSERT_TRUE(VerifyEmpty(info));
-
- resolver.LookupAddress(0x1280, "module1", &info);
- ASSERT_EQ(info.function_name, "Function1_3");
- ASSERT_TRUE(info.source_file.empty());
- ASSERT_EQ(info.source_line, 0);
-
- resolver.LookupAddress(0x1380, "module1", &info);
- ASSERT_EQ(info.function_name, "Function1_4");
- ASSERT_TRUE(info.source_file.empty());
- ASSERT_EQ(info.source_line, 0);
-
- resolver.LookupAddress(0x2180, "module2", &info);
- ASSERT_EQ(info.function_name, "Function2_2");
- ASSERT_EQ(info.source_file, "file2_2.cc");
- ASSERT_EQ(info.source_line, 21);
+ StackFrame frame;
+ frame.instruction = 0x1000;
+ frame.module_name = "module1";
+ resolver.FillSourceLineInfo(&frame);
+ ASSERT_EQ(frame.function_name, "Function1_1");
+ ASSERT_EQ(frame.source_file_name, "file1_1.cc");
+ ASSERT_EQ(frame.source_line, 44);
+
+ ClearSourceLineInfo(&frame);
+ frame.instruction = 0x800;
+ resolver.FillSourceLineInfo(&frame);
+ ASSERT_TRUE(VerifyEmpty(frame));
+
+ frame.instruction = 0x1280;
+ resolver.FillSourceLineInfo(&frame);
+ ASSERT_EQ(frame.function_name, "Function1_3");
+ ASSERT_TRUE(frame.source_file_name.empty());
+ ASSERT_EQ(frame.source_line, 0);
+
+ frame.instruction = 0x1380;
+ resolver.FillSourceLineInfo(&frame);
+ ASSERT_EQ(frame.function_name, "Function1_4");
+ ASSERT_TRUE(frame.source_file_name.empty());
+ ASSERT_EQ(frame.source_line, 0);
+
+ frame.instruction = 0x2180;
+ frame.module_name = "module2";
+ resolver.FillSourceLineInfo(&frame);
+ ASSERT_EQ(frame.function_name, "Function2_2");
+ ASSERT_EQ(frame.source_file_name, "file2_2.cc");
+ ASSERT_EQ(frame.source_line, 21);
ASSERT_FALSE(resolver.LoadModule("module3",
testdata_dir + "/module3_bad.out"));