Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3111)

Unified Diff: appengine/findit/crash/test/stacktrace_test.py

Issue 1980203002: [Findit] Filter inline function path frames (Closed) Base URL: https://chromium.googlesource.com/infra/infra.git@master
Patch Set: Rebase and fix nits. Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « appengine/findit/crash/test/fracas_parser_test.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: appengine/findit/crash/test/stacktrace_test.py
diff --git a/appengine/findit/crash/test/stacktrace_test.py b/appengine/findit/crash/test/stacktrace_test.py
index 5859a801f632dcc2887680980e065baffb7b8713..da9890f15f69536f01133077e4e6187055adf75a 100644
--- a/appengine/findit/crash/test/stacktrace_test.py
+++ b/appengine/findit/crash/test/stacktrace_test.py
@@ -3,20 +3,70 @@
# found in the LICENSE file.
from crash.callstack import CallStack
+from crash.callstack import StackFrame
from crash.stacktrace import Stacktrace
-from crash.test.crash_test_suite import CrashTestSuite
+from crash.test.stacktrace_test_suite import StacktraceTestSuite
-class StacktraceTest(CrashTestSuite):
+class StacktraceTest(StacktraceTestSuite):
+ def testCrashStackForStacktraceWithoutSignature(self):
+ frame_list1 = [
+ StackFrame(0, 'src/', '', 'func', 'file0.cc', [32])]
- def testGetCrashStack(self):
- stack_trace = Stacktrace()
- self.assertEqual(stack_trace.GetCrashStack(), None)
+ frame_list2 = [
+ StackFrame(0, 'src/', '', 'func2', 'file0.cc', [32])]
+
+ stacktrace = Stacktrace([CallStack(0, frame_list=frame_list1),
+ CallStack(1, frame_list=frame_list2)])
+ expected_crash_stack = CallStack(0, frame_list=frame_list1)
+
+ self._VerifyTwoCallStacksEqual(stacktrace.crash_stack, expected_crash_stack)
+
+ def testFilterFramesBeforeSignatureForCrashStack(self):
+ frame_list1 = [
+ StackFrame(0, 'src/', '', 'func', 'file0.cc', [32]),
+ ]
+ callstack1 = CallStack(0, frame_list=frame_list1)
+
+ frame_list2 = [
+ StackFrame(0, 'src/', '', 'func', 'file0.cc', [32]),
+ StackFrame(1, 'src/', '', 'signature_func', 'file1.cc', [53]),
+ StackFrame(2, 'src/', '', 'funcc', 'file2.cc', [3])
+ ]
+ callstack2 = CallStack(0, frame_list=frame_list2)
+
+ stacktrace = Stacktrace([callstack1, callstack2], 'signature')
+
+ expected_frame_list = [
+ StackFrame(1, 'src/', '', 'signature_func', 'file1.cc', [53]),
+ StackFrame(2, 'src/', '', 'funcc', 'file2.cc', [3])]
+ expected_crash_stack = CallStack(0, frame_list=expected_frame_list)
+
+ self._VerifyTwoCallStacksEqual(stacktrace.crash_stack,
+ expected_crash_stack)
+
+ def testNoSignatureMatchForCrashStack(self):
+ frame_list = [
+ StackFrame(0, 'src/', '', 'func', 'file0.cc', [32]),
+ ]
+ callstack = CallStack(0, frame_list=frame_list)
+
+ stacktrace = Stacktrace([callstack], 'signature')
+
+ expected_frame_list = frame_list
+ expected_crash_stack = CallStack(0, frame_list=expected_frame_list)
+
+ self._VerifyTwoCallStacksEqual(stacktrace.crash_stack,
+ expected_crash_stack)
+
+ def testCrashStackFallBackToFirstLeastPriorityCallStack(self):
+ stacktrace = Stacktrace()
+ self.assertEqual(stacktrace.crash_stack, None)
callstack_list = [CallStack(0), CallStack(1)]
- stack_trace.extend(callstack_list)
+ stacktrace.extend(callstack_list)
- self._VerifyTwoCallStacksEqual(stack_trace.GetCrashStack(),
+ self._VerifyTwoCallStacksEqual(stacktrace.crash_stack,
callstack_list[0])
def testInitStacktaceByCopyAnother(self):
« no previous file with comments | « appengine/findit/crash/test/fracas_parser_test.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698