199451b44SJordan Rupprecht"""
299451b44SJordan RupprechtTest lldb data formatter subsystem.
399451b44SJordan Rupprecht"""
499451b44SJordan Rupprecht
599451b44SJordan Rupprechtimport os
699451b44SJordan Rupprechtimport lldb
799451b44SJordan Rupprechtfrom lldbsuite.test.decorators import *
899451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import *
999451b44SJordan Rupprechtfrom lldbsuite.test import lldbutil
1099451b44SJordan Rupprecht
1199451b44SJordan Rupprecht
1299451b44SJordan Rupprechtclass SkipSummaryDataFormatterTestCase(TestBase):
1399451b44SJordan Rupprecht
1499451b44SJordan Rupprecht    @expectedFailureAll(
1599451b44SJordan Rupprecht        oslist=["windows"],
1699451b44SJordan Rupprecht        bugnumber="llvm.org/pr24462, Data formatters have problems on Windows")
1799451b44SJordan Rupprecht    def test_with_run_command(self):
1899451b44SJordan Rupprecht        """Test data formatter commands."""
1999451b44SJordan Rupprecht        self.build()
2099451b44SJordan Rupprecht        self.data_formatter_commands()
2199451b44SJordan Rupprecht
2299451b44SJordan Rupprecht    def setUp(self):
2399451b44SJordan Rupprecht        # Call super's setUp().
2499451b44SJordan Rupprecht        TestBase.setUp(self)
2599451b44SJordan Rupprecht        # Find the line number to break at.
2699451b44SJordan Rupprecht        self.line = line_number('main.cpp', '// Set break point at this line.')
2799451b44SJordan Rupprecht
2899451b44SJordan Rupprecht    def data_formatter_commands(self):
2999451b44SJordan Rupprecht        """Test that that file and class static variables display correctly."""
3099451b44SJordan Rupprecht        self.runCmd("file " + self.getBuildArtifact("a.out"), CURRENT_EXECUTABLE_SET)
3199451b44SJordan Rupprecht
3299451b44SJordan Rupprecht        #import lldbsuite.test.lldbutil as lldbutil
3399451b44SJordan Rupprecht        lldbutil.run_break_set_by_file_and_line(
3499451b44SJordan Rupprecht            self, "main.cpp", self.line, num_expected_locations=1, loc_exact=True)
3599451b44SJordan Rupprecht
3699451b44SJordan Rupprecht        self.runCmd("run", RUN_SUCCEEDED)
3799451b44SJordan Rupprecht
3899451b44SJordan Rupprecht        # The stop reason of the thread should be breakpoint.
3999451b44SJordan Rupprecht        self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
4099451b44SJordan Rupprecht                    substrs=['stopped',
4199451b44SJordan Rupprecht                             'stop reason = breakpoint'])
4299451b44SJordan Rupprecht
4399451b44SJordan Rupprecht        # This is the function to remove the custom formats in order to have a
4499451b44SJordan Rupprecht        # clean slate for the next test case.
4599451b44SJordan Rupprecht        def cleanup():
4699451b44SJordan Rupprecht            self.runCmd('type format clear', check=False)
4799451b44SJordan Rupprecht            self.runCmd('type summary clear', check=False)
4899451b44SJordan Rupprecht
4999451b44SJordan Rupprecht        # Execute the cleanup function during test case tear down.
5099451b44SJordan Rupprecht        self.addTearDownHook(cleanup)
5199451b44SJordan Rupprecht
5299451b44SJordan Rupprecht        # Setup the summaries for this scenario
5399451b44SJordan Rupprecht        #self.runCmd("type summary add --summary-string \"${var._M_dataplus._M_p}\" std::string")
5499451b44SJordan Rupprecht        self.runCmd(
5599451b44SJordan Rupprecht            "type summary add --summary-string \"Level 1\" \"DeepData_1\"")
5699451b44SJordan Rupprecht        self.runCmd(
5799451b44SJordan Rupprecht            "type summary add --summary-string \"Level 2\" \"DeepData_2\" -e")
5899451b44SJordan Rupprecht        self.runCmd(
5999451b44SJordan Rupprecht            "type summary add --summary-string \"Level 3\" \"DeepData_3\"")
6099451b44SJordan Rupprecht        self.runCmd(
6199451b44SJordan Rupprecht            "type summary add --summary-string \"Level 4\" \"DeepData_4\"")
6299451b44SJordan Rupprecht        self.runCmd(
6399451b44SJordan Rupprecht            "type summary add --summary-string \"Level 5\" \"DeepData_5\"")
6499451b44SJordan Rupprecht
6599451b44SJordan Rupprecht        # Default case, just print out summaries
6699451b44SJordan Rupprecht        self.expect('frame variable',
6799451b44SJordan Rupprecht                    substrs=['(DeepData_1) data1 = Level 1',
6899451b44SJordan Rupprecht                             '(DeepData_2) data2 = Level 2 {',
6999451b44SJordan Rupprecht                             'm_child1 = Level 3',
7099451b44SJordan Rupprecht                             'm_child2 = Level 3',
7199451b44SJordan Rupprecht                             'm_child3 = Level 3',
7299451b44SJordan Rupprecht                             'm_child4 = Level 3',
7399451b44SJordan Rupprecht                             '}'])
7499451b44SJordan Rupprecht
7599451b44SJordan Rupprecht        # Skip the default (should be 1) levels of summaries
7699451b44SJordan Rupprecht        self.expect('frame variable --no-summary-depth',
7799451b44SJordan Rupprecht                    substrs=['(DeepData_1) data1 = {',
7899451b44SJordan Rupprecht                             'm_child1 = 0x',
7999451b44SJordan Rupprecht                             '}',
8099451b44SJordan Rupprecht                             '(DeepData_2) data2 = {',
8199451b44SJordan Rupprecht                             'm_child1 = Level 3',
8299451b44SJordan Rupprecht                             'm_child2 = Level 3',
8399451b44SJordan Rupprecht                             'm_child3 = Level 3',
8499451b44SJordan Rupprecht                             'm_child4 = Level 3',
8599451b44SJordan Rupprecht                             '}'])
8699451b44SJordan Rupprecht
8799451b44SJordan Rupprecht        # Now skip 2 levels of summaries
8899451b44SJordan Rupprecht        self.expect('frame variable --no-summary-depth=2',
8999451b44SJordan Rupprecht                    substrs=['(DeepData_1) data1 = {',
9099451b44SJordan Rupprecht                             'm_child1 = 0x',
9199451b44SJordan Rupprecht                             '}',
9299451b44SJordan Rupprecht                             '(DeepData_2) data2 = {',
9399451b44SJordan Rupprecht                             'm_child1 = {',
9499451b44SJordan Rupprecht                             'm_child1 = 0x',
9599451b44SJordan Rupprecht                             'Level 4',
9699451b44SJordan Rupprecht                             'm_child2 = {',
9799451b44SJordan Rupprecht                             'm_child3 = {',
9899451b44SJordan Rupprecht                             '}'])
9999451b44SJordan Rupprecht
10099451b44SJordan Rupprecht        # Check that no "Level 3" comes out
10199451b44SJordan Rupprecht        self.expect(
10299451b44SJordan Rupprecht            'frame variable data1.m_child1 --no-summary-depth=2',
10399451b44SJordan Rupprecht            matching=False,
10499451b44SJordan Rupprecht            substrs=['Level 3'])
10599451b44SJordan Rupprecht
10699451b44SJordan Rupprecht        # Now expand a pointer with 2 level of skipped summaries
10799451b44SJordan Rupprecht        self.expect('frame variable data1.m_child1 --no-summary-depth=2',
10899451b44SJordan Rupprecht                    substrs=['(DeepData_2 *) data1.m_child1 = 0x'])
10999451b44SJordan Rupprecht
11099451b44SJordan Rupprecht        # Deref and expand said pointer
11199451b44SJordan Rupprecht        self.expect('frame variable *data1.m_child1 --no-summary-depth=2',
11299451b44SJordan Rupprecht                    substrs=['(DeepData_2) *data1.m_child1 = {',
11399451b44SJordan Rupprecht                             'm_child2 = {',
11499451b44SJordan Rupprecht                             'm_child1 = 0x',
11599451b44SJordan Rupprecht                             'Level 4',
11699451b44SJordan Rupprecht                             '}'])
11799451b44SJordan Rupprecht
11899451b44SJordan Rupprecht        # Expand an expression, skipping 2 layers of summaries
11999451b44SJordan Rupprecht        self.expect(
12099451b44SJordan Rupprecht            'frame variable data1.m_child1->m_child2 --no-summary-depth=2',
12199451b44SJordan Rupprecht            substrs=[
12299451b44SJordan Rupprecht                '(DeepData_3) data1.m_child1->m_child2 = {',
12399451b44SJordan Rupprecht                'm_child2 = {',
12499451b44SJordan Rupprecht                'm_child1 = Level 5',
12599451b44SJordan Rupprecht                'm_child2 = Level 5',
12699451b44SJordan Rupprecht                'm_child3 = Level 5',
12799451b44SJordan Rupprecht                '}'])
12899451b44SJordan Rupprecht
12999451b44SJordan Rupprecht        # Expand same expression, skipping only 1 layer of summaries
13099451b44SJordan Rupprecht        self.expect(
13199451b44SJordan Rupprecht            'frame variable data1.m_child1->m_child2 --no-summary-depth=1',
13299451b44SJordan Rupprecht            substrs=[
13399451b44SJordan Rupprecht                '(DeepData_3) data1.m_child1->m_child2 = {',
13499451b44SJordan Rupprecht                'm_child1 = 0x',
13599451b44SJordan Rupprecht                'Level 4',
13699451b44SJordan Rupprecht                'm_child2 = Level 4',
13799451b44SJordan Rupprecht                '}'])
13899451b44SJordan Rupprecht
13999451b44SJordan Rupprecht        # Bad debugging info on SnowLeopard gcc (Apple Inc. build 5666).
14099451b44SJordan Rupprecht        # Skip the following tests if the condition is met.
14199451b44SJordan Rupprecht        if self.getCompiler().endswith('gcc') and not self.getCompiler().endswith('llvm-gcc'):
14299451b44SJordan Rupprecht            import re
14399451b44SJordan Rupprecht            gcc_version_output = system(
144*c9d5a305SBenson Li                [[lldbutil.which(self.getCompiler()), "-v"]])
145b321b429SJonas Devlieghere            self.trace("my output:", gcc_version_output)
14699451b44SJordan Rupprecht            for line in gcc_version_output.split(os.linesep):
14799451b44SJordan Rupprecht                m = re.search('\(Apple Inc\. build ([0-9]+)\)', line)
148b321b429SJonas Devlieghere                self.trace("line:", line)
14999451b44SJordan Rupprecht                if m:
15099451b44SJordan Rupprecht                    gcc_build = int(m.group(1))
151b321b429SJonas Devlieghere                    self.trace("gcc build:", gcc_build)
15299451b44SJordan Rupprecht                    if gcc_build >= 5666:
15399451b44SJordan Rupprecht                        # rdar://problem/9804600"
15499451b44SJordan Rupprecht                        self.skipTest(
15599451b44SJordan Rupprecht                            "rdar://problem/9804600 wrong namespace for std::string in debug info")
15699451b44SJordan Rupprecht
15799451b44SJordan Rupprecht        # Expand same expression, skipping 3 layers of summaries
15899451b44SJordan Rupprecht        self.expect(
15999451b44SJordan Rupprecht            'frame variable data1.m_child1->m_child2 --show-types --no-summary-depth=3',
16099451b44SJordan Rupprecht            substrs=[
16199451b44SJordan Rupprecht                '(DeepData_3) data1.m_child1->m_child2 = {',
16299451b44SJordan Rupprecht                'm_some_text = "Just a test"',
16399451b44SJordan Rupprecht                'm_child2 = {',
16499451b44SJordan Rupprecht                'm_some_text = "Just a test"'])
16599451b44SJordan Rupprecht
16699451b44SJordan Rupprecht        # Change summary and expand, first without --no-summary-depth then with
16799451b44SJordan Rupprecht        # --no-summary-depth
16899451b44SJordan Rupprecht        self.runCmd(
16999451b44SJordan Rupprecht            "type summary add --summary-string \"${var.m_some_text}\" DeepData_5")
17099451b44SJordan Rupprecht
17199451b44SJordan Rupprecht        self.expect('fr var data2.m_child4.m_child2.m_child2', substrs=[
17299451b44SJordan Rupprecht                    '(DeepData_5) data2.m_child4.m_child2.m_child2 = "Just a test"'])
17399451b44SJordan Rupprecht
17499451b44SJordan Rupprecht        self.expect(
17599451b44SJordan Rupprecht            'fr var data2.m_child4.m_child2.m_child2 --no-summary-depth',
17699451b44SJordan Rupprecht            substrs=[
17799451b44SJordan Rupprecht                '(DeepData_5) data2.m_child4.m_child2.m_child2 = {',
17899451b44SJordan Rupprecht                'm_some_text = "Just a test"',
17999451b44SJordan Rupprecht                '}'])
180