diff options
Diffstat (limited to 'packages/Python/lldbsuite/test/tools/lldb-mi/TestMiGdbSetShow.py')
| -rw-r--r-- | packages/Python/lldbsuite/test/tools/lldb-mi/TestMiGdbSetShow.py | 110 | 
1 files changed, 64 insertions, 46 deletions
diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiGdbSetShow.py b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiGdbSetShow.py index 9898ad4398fb..5daf3fe0939c 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiGdbSetShow.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiGdbSetShow.py @@ -5,23 +5,25 @@ Test lldb-mi -gdb-set and -gdb-show commands.  from __future__ import print_function -  import unittest2  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_gdb_set_target_async_default(self):          """Test that 'lldb-mi --interpreter' switches to async mode by default.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Switch to sync mode          self.runCmd("-gdb-set target-async off") @@ -35,13 +37,15 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-show target-async")          self.expect("\^done,value=\"on\"") -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @expectedFlakeyLinux("llvm.org/pr26028") # Fails in ~1% of cases +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFlakeyLinux("llvm.org/pr26028")  # Fails in ~1% of cases      def test_lldbmi_gdb_set_target_async_on(self):          """Test that 'lldb-mi --interpreter' can execute commands in async mode.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Switch to sync mode          self.runCmd("-gdb-set target-async off") @@ -64,13 +68,17 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\*running")          self.expect("@\"argc=1") -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @expectedFailureAll(oslist=["linux"], bugnumber="Failing in ~11/600 dosep runs (build 3120-3122)") +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["linux"], +        bugnumber="Failing in ~11/600 dosep runs (build 3120-3122)")      def test_lldbmi_gdb_set_target_async_off(self):          """Test that 'lldb-mi --interpreter' can execute commands in sync mode.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -gdb-set can switch to sync mode          self.runCmd("-gdb-set target-async off") @@ -84,28 +92,32 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that program is executed in async mode          self.runCmd("-exec-run") -        unexpected = [ "\*running" ] # "\*running" is async notification -        it = self.expect(unexpected + [ "@\"argc=1\\\\r\\\\n" ]) +        unexpected = ["\*running"]  # "\*running" is async notification +        it = self.expect(unexpected + ["@\"argc=1\\\\r\\\\n"])          if it < len(unexpected):              self.fail("unexpected found: %s" % unexpected[it]) -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_gdb_show_target_async(self):          """Test that 'lldb-mi --interpreter' in async mode by default.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that default target-async value is "on"          self.runCmd("-gdb-show target-async")          self.expect("\^done,value=\"on\"") -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_gdb_show_language(self):          """Test that 'lldb-mi --interpreter' can get current language.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -122,36 +134,41 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-show language")          self.expect("\^done,value=\"c\+\+\"") -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows")      @unittest2.expectedFailure("-gdb-set ignores unknown properties")      def test_lldbmi_gdb_set_unknown(self):          """Test that 'lldb-mi --interpreter' fails when setting an unknown property.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -gdb-set fails if property is unknown          self.runCmd("-gdb-set unknown some_value")          self.expect("\^error") -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows")      @unittest2.expectedFailure("-gdb-show ignores unknown properties")      def test_lldbmi_gdb_show_unknown(self):          """Test that 'lldb-mi --interpreter' fails when showing an unknown property.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -gdb-show fails if property is unknown          self.runCmd("-gdb-show unknown")          self.expect("\^error") - -    @expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @expectedFailureAll( +        oslist=["windows"], +        bugnumber="llvm.org/pr22274: need a pexpect replacement for windows") +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfLinux  # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots      def test_lldbmi_gdb_set_ouptut_radix(self):          """Test that 'lldb-mi --interpreter' works for -gdb-set output-radix.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -162,31 +179,32 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-break-insert main.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"1\"")          self.runCmd("-exec-run") -        self.expect("\^running"); +        self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"")          # Setup variable -        self.runCmd("-var-create var_a * a"); -        self.expect("\^done,name=\"var_a\",numchild=\"0\",value=\"10\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.runCmd("-var-create var_a * a") +        self.expect( +            "\^done,name=\"var_a\",numchild=\"0\",value=\"10\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          # Test default output -        self.runCmd("-var-evaluate-expression var_a"); -        self.expect("\^done,value=\"10\""); +        self.runCmd("-var-evaluate-expression var_a") +        self.expect("\^done,value=\"10\"")          # Test hex output -        self.runCmd("-gdb-set output-radix 16"); -        self.expect("\^done"); -        self.runCmd("-var-evaluate-expression var_a"); -        self.expect("\^done,value=\"0xa\""); +        self.runCmd("-gdb-set output-radix 16") +        self.expect("\^done") +        self.runCmd("-var-evaluate-expression var_a") +        self.expect("\^done,value=\"0xa\"")          # Test octal output -        self.runCmd("-gdb-set output-radix 8"); -        self.expect("\^done"); -        self.runCmd("-var-evaluate-expression var_a"); -        self.expect("\^done,value=\"012\""); +        self.runCmd("-gdb-set output-radix 8") +        self.expect("\^done") +        self.runCmd("-var-evaluate-expression var_a") +        self.expect("\^done,value=\"012\"")          # Test decimal output -        self.runCmd("-gdb-set output-radix 10"); -        self.expect("\^done"); -        self.runCmd("-var-evaluate-expression var_a"); -        self.expect("\^done,value=\"10\""); +        self.runCmd("-gdb-set output-radix 10") +        self.expect("\^done") +        self.runCmd("-var-evaluate-expression var_a") +        self.expect("\^done,value=\"10\"")  | 
