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