diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-01-02 19:26:05 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-01-02 19:26:05 +0000 | 
| commit | 14f1b3e8826ce43b978db93a62d1166055db5394 (patch) | |
| tree | 0a00ad8d3498783fe0193f3b656bca17c4c8697d /packages/Python/lldbsuite/test/lang/cpp/diamond/TestDiamond.py | |
| parent | 4ee8c119c71a06dcad1e0fecc8c675e480e59337 (diff) | |
Notes
Diffstat (limited to 'packages/Python/lldbsuite/test/lang/cpp/diamond/TestDiamond.py')
| -rw-r--r-- | packages/Python/lldbsuite/test/lang/cpp/diamond/TestDiamond.py | 31 | 
1 files changed, 20 insertions, 11 deletions
| diff --git a/packages/Python/lldbsuite/test/lang/cpp/diamond/TestDiamond.py b/packages/Python/lldbsuite/test/lang/cpp/diamond/TestDiamond.py index d525e12b31ee..c6f9d85cd2c8 100644 --- a/packages/Python/lldbsuite/test/lang/cpp/diamond/TestDiamond.py +++ b/packages/Python/lldbsuite/test/lang/cpp/diamond/TestDiamond.py @@ -5,22 +5,25 @@ import lldb  from lldbsuite.test.lldbtest import *  import lldbsuite.test.lldbutil as lldbutil +  class CPPTestDiamondInheritance(TestBase): -     +      mydir = TestBase.compute_mydir(__file__) -     +      def test_with_run_command(self):          """Test that virtual base classes work in when SBValue objects are used to explore the variable value"""          self.build()          exe = os.path.join(os.getcwd(), "a.out") -         +          target = self.dbg.CreateTarget(exe)          self.assertTrue(target, VALID_TARGET)          self.set_breakpoint(line_number('main.cpp', '// breakpoint 1'))          self.set_breakpoint(line_number('main.cpp', '// breakpoint 2')) -        process = target.LaunchSimple (None, None, self.get_process_working_directory()) +        process = target.LaunchSimple( +            None, None, self.get_process_working_directory())          self.assertTrue(process, PROCESS_IS_VALID) -        thread = lldbutil.get_stopped_thread(process, lldb.eStopReasonBreakpoint) +        thread = lldbutil.get_stopped_thread( +            process, lldb.eStopReasonBreakpoint)          self.assertIsNotNone(thread)          frame = thread.GetFrameAtIndex(0)          j1 = frame.FindVariable("j1") @@ -30,13 +33,19 @@ class CPPTestDiamondInheritance(TestBase):          j1_Derived2_VBase = j1_Derived2.GetChildAtIndex(0)          j1_Derived1_VBase_m_value = j1_Derived1_VBase.GetChildAtIndex(0)          j1_Derived2_VBase_m_value = j1_Derived2_VBase.GetChildAtIndex(0) -        self.assertTrue(j1_Derived1_VBase.GetLoadAddress() == j1_Derived2_VBase.GetLoadAddress(), "ensure virtual base class is the same between Derived1 and Derived2") -        self.assertTrue(j1_Derived1_VBase_m_value.GetValueAsUnsigned(1) == j1_Derived2_VBase_m_value.GetValueAsUnsigned(2), "ensure m_value in VBase is the same") -        self.assertTrue(frame.FindVariable("d").GetChildAtIndex(0).GetChildAtIndex(0).GetValueAsUnsigned(0) == 12345, "ensure Derived2 from j1 is correct"); +        self.assertTrue( +            j1_Derived1_VBase.GetLoadAddress() == j1_Derived2_VBase.GetLoadAddress(), +            "ensure virtual base class is the same between Derived1 and Derived2") +        self.assertTrue(j1_Derived1_VBase_m_value.GetValueAsUnsigned( +            1) == j1_Derived2_VBase_m_value.GetValueAsUnsigned(2), "ensure m_value in VBase is the same") +        self.assertTrue(frame.FindVariable("d").GetChildAtIndex(0).GetChildAtIndex( +            0).GetValueAsUnsigned(0) == 12345, "ensure Derived2 from j1 is correct")          thread.StepOver() -        self.assertTrue(frame.FindVariable("d").GetChildAtIndex(0).GetChildAtIndex(0).GetValueAsUnsigned(0) == 12346, "ensure Derived2 from j2 is correct"); -     +        self.assertTrue(frame.FindVariable("d").GetChildAtIndex(0).GetChildAtIndex( +            0).GetValueAsUnsigned(0) == 12346, "ensure Derived2 from j2 is correct") +      def set_breakpoint(self, line):          # Some compilers (for example GCC 4.4.7 and 4.6.1) emit multiple locations for the statement with the ternary          # operator in the test program, while others emit only 1. -        lldbutil.run_break_set_by_file_and_line (self, "main.cpp", line, num_expected_locations=-1, loc_exact=False) +        lldbutil.run_break_set_by_file_and_line( +            self, "main.cpp", line, num_expected_locations=-1, loc_exact=False) | 
