199451b44SJordan Rupprecht"""Test that forward declarations don't cause bogus conflicts in namespaced types""" 299451b44SJordan Rupprecht 399451b44SJordan Rupprecht 499451b44SJordan Rupprecht 599451b44SJordan Rupprechtimport unittest2 699451b44SJordan Rupprechtimport lldb 799451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import * 899451b44SJordan Rupprechtfrom lldbsuite.test.decorators import * 999451b44SJordan Rupprechtimport lldbsuite.test.lldbutil as lldbutil 1099451b44SJordan Rupprecht 1199451b44SJordan Rupprecht 1299451b44SJordan Rupprechtclass NamespaceDefinitionsTestCase(TestBase): 1399451b44SJordan Rupprecht 14487ac0b3SRaphael Isemann # See also llvm.org/pr28948 1599451b44SJordan Rupprecht @expectedFailureAll( 16487ac0b3SRaphael Isemann bugnumber="llvm.org/pr50814", 17487ac0b3SRaphael Isemann compiler="gcc") 1899451b44SJordan Rupprecht @expectedFailureAll( 1999451b44SJordan Rupprecht bugnumber="llvm.org/pr28948", 2099451b44SJordan Rupprecht oslist=['linux'], compiler="gcc", archs=['arm','aarch64']) 2199451b44SJordan Rupprecht @expectedFailureAll(oslist=["windows"]) 2299451b44SJordan Rupprecht def test_expr(self): 2399451b44SJordan Rupprecht self.build() 2499451b44SJordan Rupprecht self.common_setup() 2599451b44SJordan Rupprecht 2699451b44SJordan Rupprecht self.expect( 2799451b44SJordan Rupprecht "expression -- Foo::MyClass()", 2899451b44SJordan Rupprecht VARIABLES_DISPLAYED_CORRECTLY, 2999451b44SJordan Rupprecht substrs=['thing = ']) 3099451b44SJordan Rupprecht 3199451b44SJordan Rupprecht def setUp(self): 3299451b44SJordan Rupprecht # Call super's setUp(). 3399451b44SJordan Rupprecht TestBase.setUp(self) 3499451b44SJordan Rupprecht # Find the line number to break inside main(). 3599451b44SJordan Rupprecht self.source = 'main.cpp' 3699451b44SJordan Rupprecht self.line = line_number(self.source, '// Set breakpoint here') 3799451b44SJordan Rupprecht self.shlib_names = ["a", "b"] 3899451b44SJordan Rupprecht 3999451b44SJordan Rupprecht def common_setup(self): 4099451b44SJordan Rupprecht # Run in synchronous mode 4199451b44SJordan Rupprecht self.dbg.SetAsync(False) 4299451b44SJordan Rupprecht 4399451b44SJordan Rupprecht # Create a target by the debugger. 4499451b44SJordan Rupprecht target = self.dbg.CreateTarget(self.getBuildArtifact("a.out")) 4599451b44SJordan Rupprecht self.assertTrue(target, VALID_TARGET) 4699451b44SJordan Rupprecht 4799451b44SJordan Rupprecht # Break inside the foo function which takes a bar_ptr argument. 4899451b44SJordan Rupprecht lldbutil.run_break_set_by_file_and_line( 4999451b44SJordan Rupprecht self, self.source, self.line, num_expected_locations=1, loc_exact=True) 5099451b44SJordan Rupprecht 5199451b44SJordan Rupprecht # Register our shared libraries for remote targets so they get 5299451b44SJordan Rupprecht # automatically uploaded 5399451b44SJordan Rupprecht environment = self.registerSharedLibrariesWithTarget( 5499451b44SJordan Rupprecht target, self.shlib_names) 5599451b44SJordan Rupprecht 5699451b44SJordan Rupprecht # Now launch the process, and do not stop at entry point. 5799451b44SJordan Rupprecht process = target.LaunchSimple( 5899451b44SJordan Rupprecht None, environment, self.get_process_working_directory()) 5999451b44SJordan Rupprecht self.assertTrue(process, PROCESS_IS_VALID) 6099451b44SJordan Rupprecht 6199451b44SJordan Rupprecht # The stop reason of the thread should be breakpoint. 6299451b44SJordan Rupprecht self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT, 6399451b44SJordan Rupprecht substrs=['stopped', 6499451b44SJordan Rupprecht 'stop reason = breakpoint']) 6599451b44SJordan Rupprecht 6699451b44SJordan Rupprecht # The breakpoint should have a hit count of 1. 67*9f0b5f9aSSYNOPSYS\georgiev lldbutil.check_breakpoint(self, bpno = 1, expected_hit_count = 1) 68