diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2018-07-28 11:09:23 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2018-07-28 11:09:23 +0000 | 
| commit | f73363f1dd94996356cefbf24388f561891acf0b (patch) | |
| tree | e3c31248bdb36eaec5fd833490d4278162dba2a0 /packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename | |
| parent | 160ee69dd7ae18978f4068116777639ea98dc951 (diff) | |
Notes
Diffstat (limited to 'packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename')
3 files changed, 103 insertions, 0 deletions
| diff --git a/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/Makefile b/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/Makefile new file mode 100644 index 000000000000..314f1cb2f077 --- /dev/null +++ b/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/Makefile @@ -0,0 +1,5 @@ +LEVEL = ../../../make + +CXX_SOURCES := main.cpp + +include $(LEVEL)/Makefile.rules diff --git a/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/TestDynamicValueSameBase.py b/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/TestDynamicValueSameBase.py new file mode 100644 index 000000000000..358b3b2d93ae --- /dev/null +++ b/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/TestDynamicValueSameBase.py @@ -0,0 +1,66 @@ +""" +Make sure if we have two classes with the same base name the +dynamic value calculator doesn't confuse them +""" + +from __future__ import print_function + + +import os +import time +import re +import lldb +import lldbsuite.test.lldbutil as lldbutil +from lldbsuite.test.lldbtest import * + + +class DynamicValueSameBaseTestCase(TestBase): + +    mydir = TestBase.compute_mydir(__file__) + +    # If your test case doesn't stress debug info, the  +    # set this to true.  That way it won't be run once for +    # each debug info format. +    NO_DEBUG_INFO_TESTCASE = True + +    def test_same_basename_this(self): +        """Test that the we use the full name to resolve dynamic types.""" +        self.build() +        self.main_source_file = lldb.SBFileSpec("main.cpp") +        self.sample_test() + +    def setUp(self): +        # Call super's setUp(). +        TestBase.setUp(self) + +    def sample_test(self): +        (target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(self, +                                   "Break here to get started", self.main_source_file)  + +        # Set breakpoints in the two class methods and run to them: +        namesp_bkpt = target.BreakpointCreateBySourceRegex("namesp function did something.", self.main_source_file) +        self.assertEqual(namesp_bkpt.GetNumLocations(), 1, "Namespace breakpoint invalid") + +        virtual_bkpt = target.BreakpointCreateBySourceRegex("Virtual function did something.", self.main_source_file) +        self.assertEqual(virtual_bkpt.GetNumLocations(), 1, "Virtual breakpoint invalid") + +        threads = lldbutil.continue_to_breakpoint(process, namesp_bkpt) +        self.assertEqual(len(threads), 1, "Didn't stop at namespace breakpoint") + +        frame = threads[0].frame[0] +        namesp_this = frame.FindVariable("this", lldb.eDynamicCanRunTarget) +        # Clang specifies the type of this as "T *", gcc as "T * const". This +        # erases the difference. +        namesp_type = namesp_this.GetType().GetUnqualifiedType() +        self.assertEqual(namesp_type.GetName(), "namesp::Virtual *", "Didn't get the right dynamic type") + +        threads = lldbutil.continue_to_breakpoint(process, virtual_bkpt) +        self.assertEqual(len(threads), 1, "Didn't stop at virtual breakpoint") + +        frame = threads[0].frame[0] +        virtual_this = frame.FindVariable("this", lldb.eDynamicCanRunTarget) +        virtual_type = virtual_this.GetType().GetUnqualifiedType() +        self.assertEqual(virtual_type.GetName(), "Virtual *", "Didn't get the right dynamic type") + +         + diff --git a/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/main.cpp b/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/main.cpp new file mode 100644 index 000000000000..38e46c03f41e --- /dev/null +++ b/packages/Python/lldbsuite/test/lang/cpp/dynamic-value-same-basename/main.cpp @@ -0,0 +1,32 @@ +#include <stdio.h> + +namespace namesp +{ +  class Virtual { +  public: +    virtual void doSomething() { +      printf ("namesp function did something.\n"); +    } +  };  +} + +class Virtual { +  public: +  virtual void doSomething() { +    printf("Virtual function did something.\n"); +  } +}; + +int +main() +{ +  namesp::Virtual my_outer; +  Virtual my_virtual; + +  // Break here to get started +  my_outer.doSomething(); +  my_virtual.doSomething(); + +  return 0; +} +     | 
