""" Test more expression command sequences with objective-c. """ import lldb from lldbsuite.test.decorators import * from lldbsuite.test.lldbtest import * from lldbsuite.test import lldbutil class FoundationTestCaseNSError(TestBase): @expectedFailureAll(archs=["i[3-6]86"], bugnumber="") def test_runtime_types(self): """Test commands that require runtime types""" self.build() self.target, process, thread, bkpt = lldbutil.run_to_source_breakpoint( self, "// Break here for NSString tests", lldb.SBFileSpec("main.m", False) ) # Test_NSString: self.runCmd("thread backtrace") self.expect("expression [str length]", patterns=[r"\(NSUInteger\) \$.* ="]) self.expect("expression str.length") self.expect('expression str = [NSString stringWithCString: "new"]') self.expect( 'po [NSError errorWithDomain:@"Hello" code:35 userInfo:@{@"NSDescription" : @"be completed."}]', substrs=["Error Domain=Hello", "Code=35", "be completed."], ) self.runCmd("process continue") @expectedFailureAll(archs=["i[3-6]86"], bugnumber="") def test_NSError_p(self): """Test that p of the result of an unknown method does require a cast.""" self.build() self.target, process, thread, bkpt = lldbutil.run_to_source_breakpoint( self, "// Set break point at this line", lldb.SBFileSpec("main.m", False) ) self.expect( "expression [NSError thisMethodIsntImplemented:0]", error=True, patterns=[ "no known method", "cast the message send to the method's return type", ], ) self.runCmd("process continue") @skipIfOutOfTreeDebugserver def test_runtime_types_efficient_memreads(self): # Test that we use an efficient reading of memory when reading # Objective-C method descriptions. logfile = os.path.join(self.getBuildDir(), "log.txt") self.runCmd(f"log enable -f {logfile} gdb-remote packets process") self.addTearDownHook(lambda: self.runCmd("log disable gdb-remote packets")) self.build() self.target, process, thread, bkpt = lldbutil.run_to_source_breakpoint( self, "// Break here for NSString tests", lldb.SBFileSpec("main.m", False) ) self.runCmd(f"proc plugin packet send StartTesting", check=False) self.expect('expression str = [NSString stringWithCString: "new"]') self.runCmd(f"proc plugin packet send EndTesting", check=False) self.assertTrue(os.path.exists(logfile)) log_text = open(logfile).read() log_text = log_text.split("StartTesting", 1)[-1].split("EndTesting", 1)[0] # This test is only checking that the packet it used at all (and that # no errors are produced). It doesn't check that the packet is being # used to solve a problem in an optimal way. self.assertIn("MultiMemRead:", log_text) self.assertNotIn("MultiMemRead error", log_text)