[Lldb-commits] [PATCH] D12888: Add first tests for mini-dump debugging.
Adrian McCarthy via lldb-commits
lldb-commits at lists.llvm.org
Wed Sep 16 11:02:47 PDT 2015
amccarth updated this revision to Diff 34906.
amccarth added a comment.
Addressed earlier comments and moved to functionalities\postmortem\minidump
http://reviews.llvm.org/D12888
Files:
test/functionalities/postmortem/minidump/TestMiniDump.py
test/functionalities/postmortem/minidump/fizzbuzz.cpp
test/functionalities/postmortem/minidump/fizzbuzz_no_heap.dmp
test/lldbtest.py
Index: test/lldbtest.py
===================================================================
--- test/lldbtest.py
+++ test/lldbtest.py
@@ -889,6 +889,10 @@
"""Decorate the item to skip tests that should be skipped on Windows."""
return skipIfHostPlatform(["windows"])(func)
+def skipUnlessWindows(func):
+ """Decorate the item to skip tests that should be skipped on any non-Windows platform."""
+ return skipUnlessPlatform(["windows"])(func)
+
def skipUnlessDarwin(func):
"""Decorate the item to skip tests that should be skipped on any non Darwin platform."""
return skipUnlessPlatform(getDarwinOSTriples())(func)
Index: test/functionalities/postmortem/minidump/fizzbuzz.cpp
===================================================================
--- /dev/null
+++ test/functionalities/postmortem/minidump/fizzbuzz.cpp
@@ -0,0 +1,31 @@
+// A sample program for getting minidumps on Windows.
+
+#include <iostream>
+
+bool
+fizz(int x)
+{
+ return x % 3 == 0;
+}
+
+bool
+buzz(int x)
+{
+ return x % 5 == 0;
+}
+
+int
+main()
+{
+ int *buggy = 0;
+
+ for (int i = 1; i <= 100; ++i)
+ {
+ if (fizz(i)) std::cout << "fizz";
+ if (buzz(i)) std::cout << "buzz";
+ if (!fizz(i) && !buzz(i)) std::cout << i;
+ std::cout << '\n';
+ }
+
+ return *buggy;
+}
Index: test/functionalities/postmortem/minidump/TestMiniDump.py
===================================================================
--- /dev/null
+++ test/functionalities/postmortem/minidump/TestMiniDump.py
@@ -0,0 +1,42 @@
+"""
+Test basics of mini dump debugging.
+"""
+
+import unittest2
+import lldb
+from lldbtest import *
+import lldbutil
+
+ at skipUnlessWindows # for now mini-dump debugging is limited to Windows hosts
+class MiniDumpTestCase(TestBase):
+
+ mydir = TestBase.compute_mydir(__file__)
+
+ def test_process_info_in_mini_dump(self):
+ """Test that lldb can read the process information from the minidump."""
+ self.assertTrue(self.process, PROCESS_IS_VALID)
+ self.assertEqual(self.process.GetNumThreads(), 1)
+ # TODO(amccarth): Check the process ID.
+
+ def test_thread_info_in_mini_dump(self):
+ """Test that lldb can read the thread information from the minidump."""
+ # This process crashed due to an access violation (0xc0000005) in its one and only thread.
+ self.assertEqual(self.process.GetNumThreads(), 1)
+ thread = self.process.GetThreadAtIndex(0)
+ self.assertEqual(thread.GetStopReason(), lldb.eStopReasonException)
+ stop_description = thread.GetStopDescription(256);
+ self.assertTrue("0xc0000005" in stop_description);
+
+ def setUp(self):
+ # Call super's setUp().
+ TestBase.setUp(self)
+ # target create -c fizzbuzz_no_heap.dmp
+ self.dbg.CreateTarget("")
+ self.target = self.dbg.GetSelectedTarget()
+ self.process = self.target.LoadCore("fizzbuzz_no_heap.dmp")
+
+if __name__ == '__main__':
+ import atexit
+ lldb.SBDebugger.Initialize()
+ atexit.register(lambda: lldb.SBDebugger.Terminate())
+ unittest2.main()
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D12888.34906.patch
Type: text/x-patch
Size: 3151 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20150916/518d2085/attachment-0001.bin>
More information about the lldb-commits
mailing list