199451b44SJordan Rupprecht"""
299451b44SJordan RupprechtTest that dynamic values update their child count correctly
399451b44SJordan Rupprecht"""
499451b44SJordan Rupprecht
599451b44SJordan Rupprecht
699451b44SJordan Rupprecht
799451b44SJordan Rupprechtimport lldb
899451b44SJordan Rupprechtfrom lldbsuite.test.decorators import *
999451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import *
1099451b44SJordan Rupprechtfrom lldbsuite.test import lldbutil
1199451b44SJordan Rupprecht
1299451b44SJordan Rupprecht
1399451b44SJordan Rupprechtclass DynamicValueChildCountTestCase(TestBase):
1499451b44SJordan Rupprecht
1599451b44SJordan Rupprecht    def setUp(self):
1699451b44SJordan Rupprecht        # Call super's setUp().
1799451b44SJordan Rupprecht        TestBase.setUp(self)
1899451b44SJordan Rupprecht
1999451b44SJordan Rupprecht        # Find the line number to break for main.c.
2099451b44SJordan Rupprecht
2199451b44SJordan Rupprecht        self.main_third_call_line = line_number(
2299451b44SJordan Rupprecht            'pass-to-base.cpp', '// Break here and check b has 0 children')
2399451b44SJordan Rupprecht        self.main_fourth_call_line = line_number(
2499451b44SJordan Rupprecht            'pass-to-base.cpp', '// Break here and check b still has 0 children')
2599451b44SJordan Rupprecht        self.main_fifth_call_line = line_number(
2699451b44SJordan Rupprecht            'pass-to-base.cpp', '// Break here and check b has one child now')
2799451b44SJordan Rupprecht        self.main_sixth_call_line = line_number(
2899451b44SJordan Rupprecht            'pass-to-base.cpp', '// Break here and check b has 0 children again')
2999451b44SJordan Rupprecht
3099451b44SJordan Rupprecht    @add_test_categories(['pyapi'])
3199451b44SJordan Rupprecht    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr24663")
3299451b44SJordan Rupprecht    def test_get_dynamic_vals(self):
3399451b44SJordan Rupprecht        """Test fetching C++ dynamic values from pointers & references."""
3499451b44SJordan Rupprecht        """Get argument vals for the call stack when stopped on a breakpoint."""
35d7dbe2c4SPavel Labath        self.build()
3699451b44SJordan Rupprecht        exe = self.getBuildArtifact("a.out")
3799451b44SJordan Rupprecht
3899451b44SJordan Rupprecht        # Create a target from the debugger.
3999451b44SJordan Rupprecht
4099451b44SJordan Rupprecht        target = self.dbg.CreateTarget(exe)
4199451b44SJordan Rupprecht        self.assertTrue(target, VALID_TARGET)
4299451b44SJordan Rupprecht
4399451b44SJordan Rupprecht        # Set up our breakpoints:
4499451b44SJordan Rupprecht
4599451b44SJordan Rupprecht        third_call_bpt = target.BreakpointCreateByLocation(
4699451b44SJordan Rupprecht            'pass-to-base.cpp', self.main_third_call_line)
4799451b44SJordan Rupprecht        self.assertTrue(third_call_bpt,
4899451b44SJordan Rupprecht                        VALID_BREAKPOINT)
4999451b44SJordan Rupprecht        fourth_call_bpt = target.BreakpointCreateByLocation(
5099451b44SJordan Rupprecht            'pass-to-base.cpp', self.main_fourth_call_line)
5199451b44SJordan Rupprecht        self.assertTrue(fourth_call_bpt,
5299451b44SJordan Rupprecht                        VALID_BREAKPOINT)
5399451b44SJordan Rupprecht        fifth_call_bpt = target.BreakpointCreateByLocation(
5499451b44SJordan Rupprecht            'pass-to-base.cpp', self.main_fifth_call_line)
5599451b44SJordan Rupprecht        self.assertTrue(fifth_call_bpt,
5699451b44SJordan Rupprecht                        VALID_BREAKPOINT)
5799451b44SJordan Rupprecht        sixth_call_bpt = target.BreakpointCreateByLocation(
5899451b44SJordan Rupprecht            'pass-to-base.cpp', self.main_sixth_call_line)
5999451b44SJordan Rupprecht        self.assertTrue(sixth_call_bpt,
6099451b44SJordan Rupprecht                        VALID_BREAKPOINT)
6199451b44SJordan Rupprecht
6299451b44SJordan Rupprecht        # Now launch the process, and do not stop at the entry point.
6399451b44SJordan Rupprecht        process = target.LaunchSimple(
6499451b44SJordan Rupprecht            None, None, self.get_process_working_directory())
6599451b44SJordan Rupprecht
66*ce825e46SJonas Devlieghere        self.assertState(process.GetState(), lldb.eStateStopped,
6799451b44SJordan Rupprecht                         PROCESS_STOPPED)
6899451b44SJordan Rupprecht
6999451b44SJordan Rupprecht        b = self.frame().FindVariable("b").GetDynamicValue(lldb.eDynamicCanRunTarget)
70b3a0c4d7SRaphael Isemann        self.assertEquals(b.GetNumChildren(), 0, "b has 0 children")
7199451b44SJordan Rupprecht        self.runCmd("continue")
72b3a0c4d7SRaphael Isemann        self.assertEquals(b.GetNumChildren(), 0, "b still has 0 children")
7399451b44SJordan Rupprecht        self.runCmd("continue")
74b3a0c4d7SRaphael Isemann        self.assertNotEqual(b.GetNumChildren(), 0, "b now has 1 child")
7599451b44SJordan Rupprecht        self.runCmd("continue")
760ed758b2SDave Lee        self.assertEqual(
770ed758b2SDave Lee            b.GetNumChildren(), 0,
7899451b44SJordan Rupprecht            "b didn't go back to 0 children")
79