199451b44SJordan Rupprecht""" 299451b44SJordan RupprechtTest lldb breakpoint ids. 399451b44SJordan Rupprecht""" 499451b44SJordan Rupprecht 599451b44SJordan Rupprecht 699451b44SJordan Rupprecht 799451b44SJordan Rupprechtimport lldb 899451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import * 999451b44SJordan Rupprechtimport lldbsuite.test.lldbutil as lldbutil 1099451b44SJordan Rupprecht 1199451b44SJordan Rupprecht 1299451b44SJordan Rupprechtclass BreakpointIDTestCase(TestBase): 1399451b44SJordan Rupprecht 1499451b44SJordan Rupprecht def test(self): 1599451b44SJordan Rupprecht self.build() 1699451b44SJordan Rupprecht 1799451b44SJordan Rupprecht exe = self.getBuildArtifact("a.out") 1899451b44SJordan Rupprecht self.expect("file " + exe, 1999451b44SJordan Rupprecht patterns=["Current executable set to .*a.out"]) 2099451b44SJordan Rupprecht 2199451b44SJordan Rupprecht bpno = lldbutil.run_break_set_by_symbol( 2299451b44SJordan Rupprecht self, 'product', num_expected_locations=-1, sym_exact=False) 23*b3a0c4d7SRaphael Isemann self.assertEquals(bpno, 1, "First breakpoint number is 1.") 2499451b44SJordan Rupprecht 2599451b44SJordan Rupprecht bpno = lldbutil.run_break_set_by_symbol( 2699451b44SJordan Rupprecht self, 'sum', num_expected_locations=-1, sym_exact=False) 27*b3a0c4d7SRaphael Isemann self.assertEquals(bpno, 2, "Second breakpoint number is 2.") 2899451b44SJordan Rupprecht 2999451b44SJordan Rupprecht bpno = lldbutil.run_break_set_by_symbol( 3099451b44SJordan Rupprecht self, 'junk', num_expected_locations=0, sym_exact=False) 31*b3a0c4d7SRaphael Isemann self.assertEquals(bpno, 3, "Third breakpoint number is 3.") 3299451b44SJordan Rupprecht 3399451b44SJordan Rupprecht self.expect( 3499451b44SJordan Rupprecht "breakpoint disable 1.1 - 2.2 ", 3599451b44SJordan Rupprecht COMMAND_FAILED_AS_EXPECTED, 3699451b44SJordan Rupprecht error=True, 3799451b44SJordan Rupprecht startstr="error: Invalid range: Ranges that specify particular breakpoint locations must be within the same major breakpoint; you specified two different major breakpoints, 1 and 2.") 3899451b44SJordan Rupprecht 3999451b44SJordan Rupprecht self.expect( 4099451b44SJordan Rupprecht "breakpoint disable 2 - 2.2", 4199451b44SJordan Rupprecht COMMAND_FAILED_AS_EXPECTED, 4299451b44SJordan Rupprecht error=True, 4399451b44SJordan Rupprecht startstr="error: Invalid breakpoint id range: Either both ends of range must specify a breakpoint location, or neither can specify a breakpoint location.") 4499451b44SJordan Rupprecht 4599451b44SJordan Rupprecht self.expect( 4699451b44SJordan Rupprecht "breakpoint disable 2.1 - 2", 4799451b44SJordan Rupprecht COMMAND_FAILED_AS_EXPECTED, 4899451b44SJordan Rupprecht error=True, 4999451b44SJordan Rupprecht startstr="error: Invalid breakpoint id range: Either both ends of range must specify a breakpoint location, or neither can specify a breakpoint location.") 5099451b44SJordan Rupprecht 5199451b44SJordan Rupprecht self.expect("breakpoint disable 2.1 - 2.2", 5299451b44SJordan Rupprecht startstr="2 breakpoints disabled.") 5399451b44SJordan Rupprecht 5499451b44SJordan Rupprecht self.expect("breakpoint enable 2.*", 5599451b44SJordan Rupprecht patterns=[".* breakpoints enabled."]) 56