[Lldb-commits] [PATCH] D12888: Add first tests for mini-dump debugging.

Zachary Turner via lldb-commits lldb-commits at lists.llvm.org
Wed Sep 16 11:06:33 PDT 2015


looks fine.

On Wed, Sep 16, 2015 at 11:02 AM Adrian McCarthy <amccarth at google.com>
wrote:

> 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 --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20150916/292880f0/attachment.html>


More information about the lldb-commits mailing list