diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-01-02 19:26:05 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-01-02 19:26:05 +0000 | 
| commit | 14f1b3e8826ce43b978db93a62d1166055db5394 (patch) | |
| tree | 0a00ad8d3498783fe0193f3b656bca17c4c8697d /packages/Python/lldbsuite/test/tools/lldb-mi | |
| parent | 4ee8c119c71a06dcad1e0fecc8c675e480e59337 (diff) | |
Notes
Diffstat (limited to 'packages/Python/lldbsuite/test/tools/lldb-mi')
20 files changed, 1353 insertions, 797 deletions
| diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiExit.py b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiExit.py index 6f814c13ec83..0cc50370b164 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiExit.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiExit.py @@ -9,16 +9,19 @@ from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiExitTestCase(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_exit(self):          """Test that '-gdb-exit' terminates local debug session and exits.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -37,12 +40,14 @@ class MiExitTestCase(lldbmi_testcase.MiTestCaseBase):          import pexpect          self.expect(pexpect.EOF) -    @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_quit(self):          """Test that 'quit' exits immediately.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -60,12 +65,14 @@ class MiExitTestCase(lldbmi_testcase.MiTestCaseBase):          import pexpect          self.expect(pexpect.EOF) -    @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_q(self):          """Test that 'q' exits immediately.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiFile.py b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiFile.py index 99a06f2711fa..7a99ecf7d1e5 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiFile.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiFile.py @@ -5,22 +5,22 @@ Test lldb-mi -file-xxx commands.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiFileTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_file_exec_and_symbols_file(self):          """Test that 'lldb-mi --interpreter' works for -file-exec-and-symbols exe.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -file-exec-and-symbols works for filename          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -31,12 +31,12 @@ class MiFileTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_file_exec_and_symbols_absolute_path(self):          """Test that 'lldb-mi --interpreter' works for -file-exec-and-symbols fullpath/exe.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -file-exec-and-symbols works for absolute path          import os @@ -49,12 +49,12 @@ class MiFileTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_file_exec_and_symbols_relative_path(self):          """Test that 'lldb-mi --interpreter' works for -file-exec-and-symbols relpath/exe.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -file-exec-and-symbols works for relative path          path = "./%s" % self.myexe @@ -66,12 +66,12 @@ class MiFileTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_file_exec_and_symbols_unknown_path(self):          """Test that 'lldb-mi --interpreter' works for -file-exec-and-symbols badpath/exe.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -file-exec-and-symbols fails on unknown path          path = "unknown_dir/%s" % self.myexe 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\"") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiLibraryLoaded.py b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiLibraryLoaded.py index 8e1d72aa19c6..68d670c9cd1e 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiLibraryLoaded.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiLibraryLoaded.py @@ -5,22 +5,22 @@ Test lldb-mi =library-loaded notifications.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiLibraryLoadedTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_library_loaded(self):          """Test that 'lldb-mi --interpreter' shows the =library-loaded notifications.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -29,7 +29,30 @@ class MiLibraryLoadedTestCase(lldbmi_testcase.MiTestCaseBase):          # Test =library-loaded          import os          path = os.path.join(os.getcwd(), self.myexe) -        symbols_path = os.path.join(path + ".dSYM", "Contents", "Resources", "DWARF", self.myexe) -        def add_slashes(x): return x.replace("\\", "\\\\").replace("\"", "\\\"").replace("\'", "\\\'").replace("\0", "\\\0") -        self.expect([ "=library-loaded,id=\"%s\",target-name=\"%s\",host-name=\"%s\",symbols-loaded=\"1\",symbols-path=\"%s\",loaded_addr=\"-\",size=\"[0-9]+\"" % (add_slashes(path), add_slashes(path), add_slashes(path), add_slashes(symbols_path)), -                      "=library-loaded,id=\"%s\",target-name=\"%s\",host-name=\"%s\",symbols-loaded=\"0\",loaded_addr=\"-\",size=\"[0-9]+\"" % (add_slashes(path), add_slashes(path), add_slashes(path)) ]) +        symbols_path = os.path.join( +            path + ".dSYM", +            "Contents", +            "Resources", +            "DWARF", +            self.myexe) + +        def add_slashes(x): return x.replace( +            "\\", +            "\\\\").replace( +            "\"", +            "\\\"").replace( +            "\'", +            "\\\'").replace( +                "\0", +            "\\\0") +        self.expect( +            [ +                "=library-loaded,id=\"%s\",target-name=\"%s\",host-name=\"%s\",symbols-loaded=\"1\",symbols-path=\"%s\",loaded_addr=\"-\",size=\"[0-9]+\"" % +                (add_slashes(path), +                 add_slashes(path), +                 add_slashes(path), +                 add_slashes(symbols_path)), +                "=library-loaded,id=\"%s\",target-name=\"%s\",host-name=\"%s\",symbols-loaded=\"0\",loaded_addr=\"-\",size=\"[0-9]+\"" % +                (add_slashes(path), +                 add_slashes(path), +                 add_slashes(path))]) diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiPrompt.py b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiPrompt.py index 50e108e9fa20..b853673211bb 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiPrompt.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/TestMiPrompt.py @@ -5,52 +5,53 @@ Test that the lldb-mi driver prints prompt properly.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiPromptTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_prompt(self):          """Test that 'lldb-mi --interpreter' echos '(gdb)' after commands and events.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that lldb-mi is ready after unknown command          self.runCmd("-unknown-command") -        self.expect("\^error,msg=\"Driver\. Received command '-unknown-command'\. It was not handled\. Command 'unknown-command' not in Command Factory\"") -        self.expect(self.child_prompt, exactly = True) +        self.expect( +            "\^error,msg=\"Driver\. Received command '-unknown-command'\. It was not handled\. Command 'unknown-command' not in Command Factory\"") +        self.expect(self.child_prompt, exactly=True)          # Test that lldb-mi is ready after -file-exec-and-symbols          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done") -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Test that lldb-mi is ready after -break-insert          self.runCmd("-break-insert -f main")          self.expect("\^done,bkpt={number=\"1\"") -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Test that lldb-mi is ready after -exec-run          self.runCmd("-exec-run")          self.expect("\*running") -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Test that lldb-mi is ready after BP hit          self.expect("\*stopped,reason=\"breakpoint-hit\"") -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Test that lldb-mi is ready after -exec-continue          self.runCmd("-exec-continue")          self.expect("\^running") -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Test that lldb-mi is ready after program exited          self.expect("\*stopped,reason=\"exited-normally\"") -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True) diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/breakpoint/TestMiBreak.py b/packages/Python/lldbsuite/test/tools/lldb-mi/breakpoint/TestMiBreak.py index c4a801c991a4..38c6b1f0b179 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/breakpoint/TestMiBreak.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/breakpoint/TestMiBreak.py @@ -11,68 +11,79 @@ from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiBreakTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      @expectedFlakeyLinux("llvm.org/pr24717")      def test_lldbmi_break_insert_function_pending(self):          """Test that 'lldb-mi --interpreter' works for pending function breakpoints.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          self.runCmd("-break-insert -f printf") -        #FIXME function name is unknown on Darwin, fullname should be ??, line is -1 -        #self.expect("\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"printf\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") -        self.expect("\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"\?\?\",file=\"\?\?\",fullname=\"\?\?/\?\?\",line=\"0\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") -        #FIXME function name is unknown on Darwin, fullname should be ??, line -1 -        #self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"printf\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") -        self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"\?\?\",file=\"\?\?\",fullname=\"\?\?/\?\?\",line=\"0\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") +        # FIXME function name is unknown on Darwin, fullname should be ??, line is -1 +        # self.expect("\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"printf\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") +        self.expect( +            "\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"\?\?\",file=\"\?\?\",fullname=\"\?\?/\?\?\",line=\"0\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") +        # FIXME function name is unknown on Darwin, fullname should be ??, line -1 +        # self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"printf\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"0xffffffffffffffff\",func=\"\?\?\",file=\"\?\?\",fullname=\"\?\?/\?\?\",line=\"0\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}")          self.runCmd("-exec-run")          self.expect("\^running") -        self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",pending=\[\"printf\"\],times=\"0\",original-location=\"printf\"}")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_break_insert_function(self):          """Test that 'lldb-mi --interpreter' works for function breakpoints.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          self.runCmd("-break-insert -f main") -        self.expect("\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",pending=\[\"main\"\],times=\"0\",original-location=\"main\"}") -        self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",pending=\[\"main\"\],times=\"0\",original-location=\"main\"}") +        self.expect( +            "\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",pending=\[\"main\"\],times=\"0\",original-location=\"main\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",pending=\[\"main\"\],times=\"0\",original-location=\"main\"}")          self.runCmd("-exec-run")          self.expect("\^running") -        self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",pending=\[\"main\"\],times=\"0\",original-location=\"main\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",pending=\[\"main\"\],times=\"0\",original-location=\"main\"}")          self.expect("\*stopped,reason=\"breakpoint-hit\"")          # Test that -break-insert can set non-pending BP          self.runCmd("-break-insert printf") -        #FIXME function name is unknown on Darwin -        #self.expect("\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"printf\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") -        self.expect("\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") -        #FIXME function name is unknown on Darwin -        #self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"printf\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") -        self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}")          # FIXME function name is unknown on Darwin -        #self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"printf\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") -        self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") +        # self.expect("\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"printf\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") +        self.expect( +            "\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") +        # FIXME function name is unknown on Darwin +        # self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"printf\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") +        # FIXME function name is unknown on Darwin +        # self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"printf\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\",times=\"0\",original-location=\"printf\"}")          # Test that -break-insert fails if non-pending BP can't be resolved          self.runCmd("-break-insert unknown_func") -        self.expect("\^error,msg=\"Command 'break-insert'. Breakpoint location 'unknown_func' not found\"") +        self.expect( +            "\^error,msg=\"Command 'break-insert'. Breakpoint location 'unknown_func' not found\"")          # Test that non-pending BP was set correctly          self.runCmd("-exec-continue") @@ -84,28 +95,28 @@ class MiBreakTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^done,bkpt={number=\"4\"")          self.runCmd("-break-insert main.cpp:ns::foo1")          self.expect("\^done,bkpt={number=\"5\"") -        #FIXME: quotes on filenames aren't handled correctly in lldb-mi. +        # FIXME: quotes on filenames aren't handled correctly in lldb-mi.          #self.runCmd("-break-insert \"main.cpp\":main") -        #self.expect("\^done,bkpt={number=\"6\"") +        # self.expect("\^done,bkpt={number=\"6\"")          # We should hit BP #5 on 'main.cpp:ns::foo1'          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\".*bkptno=\"5\"") -        #FIXME: this test is disabled due to lldb bug llvm.org/pr24271. +        # FIXME: this test is disabled due to lldb bug llvm.org/pr24271.          # Test that we can set a BP using the global namespace token          #self.runCmd("-break-insert ::main") -        #self.expect("\^done,bkpt={number=\"7\"") +        # self.expect("\^done,bkpt={number=\"7\"")          #self.runCmd("-break-insert main.cpp:::main") -        #self.expect("\^done,bkpt={number=\"8\"") +        # self.expect("\^done,bkpt={number=\"8\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_break_insert_file_line_pending(self):          """Test that 'lldb-mi --interpreter' works for pending file:line breakpoints.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done") @@ -114,19 +125,27 @@ class MiBreakTestCase(lldbmi_testcase.MiTestCaseBase):          # pending BP          line = line_number('main.cpp', '// BP_return')          self.runCmd("-break-insert -f main.cpp:%d" % line) -        self.expect("\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",pending=\[\"main.cpp:%d\"\],times=\"0\",original-location=\"main.cpp:%d\"}" % (line, line, line)) -        self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",pending=\[\"main.cpp:%d\"\],times=\"0\",original-location=\"main.cpp:%d\"}" % (line, line, line)) +        self.expect( +            "\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",pending=\[\"main.cpp:%d\"\],times=\"0\",original-location=\"main.cpp:%d\"}" % +            (line, +             line, +             line)) +        self.expect( +            "=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",pending=\[\"main.cpp:%d\"\],times=\"0\",original-location=\"main.cpp:%d\"}" % +            (line, +             line, +             line))          self.runCmd("-exec-run")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_break_insert_file_line(self):          """Test that 'lldb-mi --interpreter' works for file:line breakpoints.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done") @@ -141,25 +160,29 @@ class MiBreakTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -break-insert can set non-pending BP          line = line_number('main.cpp', '// BP_return')          self.runCmd("-break-insert main.cpp:%d" % line) -        self.expect("\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",times=\"0\",original-location=\"main.cpp:%d\"}" % (line, line)) -        self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",times=\"0\",original-location=\"main.cpp:%d\"}" % (line, line)) +        self.expect( +            "\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",times=\"0\",original-location=\"main.cpp:%d\"}" % +            (line, line)) +        self.expect( +            "=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"%d\",times=\"0\",original-location=\"main.cpp:%d\"}" % +            (line, line))          # Test that -break-insert fails if non-pending BP can't be resolved          self.runCmd("-break-insert unknown_file:1") -        self.expect("\^error,msg=\"Command 'break-insert'. Breakpoint location 'unknown_file:1' not found\"") +        self.expect( +            "\^error,msg=\"Command 'break-insert'. Breakpoint location 'unknown_file:1' not found\"")          # Test that non-pending BP was set correctly          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @unittest2.expectedFailure("-break-insert doesn't work for absolute path") +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_break_insert_file_line_absolute_path(self):          """Test that 'lldb-mi --interpreter' works for file:line breakpoints.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done") @@ -181,19 +204,21 @@ class MiBreakTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_break_insert_settings(self):          """Test that 'lldb-mi --interpreter' can set breakpoints accoridng to global options.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done") -        # Set target.move-to-nearest-code=off and try to set BP #1 that shouldn't be hit -        self.runCmd("-interpreter-exec console \"settings set target.move-to-nearest-code off\"") +        # Set target.move-to-nearest-code=off and try to set BP #1 that +        # shouldn't be hit +        self.runCmd( +            "-interpreter-exec console \"settings set target.move-to-nearest-code off\"")          self.expect("\^done")          line = line_number('main.cpp', '// BP_before_main')          self.runCmd("-break-insert -f main.cpp:%d" % line) @@ -202,17 +227,23 @@ class MiBreakTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that non-pending BP will not be set on non-existing line if target.move-to-nearest-code=off          # Note: this increases the BP number by 1 even though BP #2 is invalid.          self.runCmd("-break-insert main.cpp:%d" % line) -        self.expect("\^error,msg=\"Command 'break-insert'. Breakpoint location 'main.cpp:%d' not found\"" % line) - -        # Set target.move-to-nearest-code=on and target.skip-prologue=on and set BP #3 -        self.runCmd("-interpreter-exec console \"settings set target.move-to-nearest-code on\"") -        self.runCmd("-interpreter-exec console \"settings set target.skip-prologue on\"") +        self.expect( +            "\^error,msg=\"Command 'break-insert'. Breakpoint location 'main.cpp:%d' not found\"" % +            line) + +        # Set target.move-to-nearest-code=on and target.skip-prologue=on and +        # set BP #3 +        self.runCmd( +            "-interpreter-exec console \"settings set target.move-to-nearest-code on\"") +        self.runCmd( +            "-interpreter-exec console \"settings set target.skip-prologue on\"")          self.expect("\^done")          self.runCmd("-break-insert main.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"3\"")          # Set target.skip-prologue=off and set BP #4 -        self.runCmd("-interpreter-exec console \"settings set target.skip-prologue off\"") +        self.runCmd( +            "-interpreter-exec console \"settings set target.skip-prologue off\"")          self.expect("\^done")          self.runCmd("-break-insert main.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"4\"") @@ -220,74 +251,92 @@ class MiBreakTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that BP #4 is located before BP #3          self.runCmd("-exec-run")          self.expect("\^running") -        self.expect("\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"4\"") +        self.expect( +            "\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"4\"")          # Test that BP #3 is hit          self.runCmd("-exec-continue")          self.expect("\^running") -        self.expect("\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"3\"") +        self.expect( +            "\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"3\"") -        # Test that the target.language=pascal setting works and that BP #5 is NOT set -        self.runCmd("-interpreter-exec console \"settings set target.language c\"") +        # Test that the target.language=pascal setting works and that BP #5 is +        # NOT set +        self.runCmd( +            "-interpreter-exec console \"settings set target.language c\"")          self.expect("\^done")          self.runCmd("-break-insert ns.foo1")          self.expect("\^error")          # Test that the target.language=c++ setting works and that BP #6 is hit -        self.runCmd("-interpreter-exec console \"settings set target.language c++\"") +        self.runCmd( +            "-interpreter-exec console \"settings set target.language c++\"")          self.expect("\^done")          self.runCmd("-break-insert ns::foo1")          self.expect("\^done,bkpt={number=\"6\"")          self.runCmd("-exec-continue")          self.expect("\^running") -        self.expect("\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"6\"") +        self.expect( +            "\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"6\"")          # Test that BP #1 and #2 weren't set by running to program exit          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_break_enable_disable(self):          """Test that 'lldb-mi --interpreter' works for enabling / disabling breakpoints.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          self.runCmd("-break-insert main") -        self.expect("\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\"") -        self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"main\"}") +        self.expect( +            "\^done,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\"") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"main\"}")          self.runCmd("-exec-run")          self.expect("\^running") -        self.expect("=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"main\"}") -        self.expect("\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"1\"") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"1\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"main\"}") +        self.expect( +            "\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"1\"")          self.runCmd("-break-insert ns::foo1") -        self.expect("\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo1\(\)\"") -        self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo1\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo1\"}") +        self.expect( +            "\^done,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo1\(\)\"") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo1\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo1\"}")          self.runCmd("-break-insert ns::foo2") -        self.expect("\^done,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\"") -        self.expect("=breakpoint-modified,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo2\"}") +        self.expect( +            "\^done,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\"") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo2\"}")          # disable the 2nd breakpoint          self.runCmd("-break-disable 2")          self.expect("\^done") -        self.expect("=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"n\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo1\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo1\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"2\",type=\"breakpoint\",disp=\"keep\",enabled=\"n\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo1\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo1\"}")          # disable the 3rd breakpoint and re-enable          self.runCmd("-break-disable 3")          self.expect("\^done") -        self.expect("=breakpoint-modified,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"n\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo2\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"n\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo2\"}")          self.runCmd("-break-enable 3")          self.expect("\^done") -        self.expect("=breakpoint-modified,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo2\"}") +        self.expect( +            "=breakpoint-modified,bkpt={number=\"3\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"(?!0xffffffffffffffff)0x[0-9a-f]+\",func=\"ns::foo2\(\)\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\",times=\"0\",original-location=\"ns::foo2\"}")          self.runCmd("-exec-continue")          self.expect("\^running") -        self.expect("\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"3\"") +        self.expect( +            "\*stopped,reason=\"breakpoint-hit\",disp=\"del\",bkptno=\"3\"") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/control/TestMiExec.py b/packages/Python/lldbsuite/test/tools/lldb-mi/control/TestMiExec.py index a62b9a25400c..354f955b7478 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/control/TestMiExec.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/control/TestMiExec.py @@ -5,23 +5,25 @@ Test lldb-mi -exec-xxx commands.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @expectedFailureAll(oslist=["linux"], bugnumber="llvm.org/pr25000: lldb-mi does not receive broadcasted notification from Core/Process about process stopped") +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["linux"], +        bugnumber="llvm.org/pr25000: lldb-mi does not receive broadcasted notification from Core/Process about process stopped")      def test_lldbmi_exec_run(self):          """Test that 'lldb-mi --interpreter' can stop at entry.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -30,20 +32,22 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that program is stopped at entry          self.runCmd("-exec-run --start")          self.expect("\^running") -        self.expect("\*stopped,reason=\"signal-received\",signal-name=\"SIGSTOP\",signal-meaning=\"Stop\",.*?thread-id=\"1\",stopped-threads=\"all\"") +        self.expect( +            "\*stopped,reason=\"signal-received\",signal-name=\"SIGSTOP\",signal-meaning=\"Stop\",.*?thread-id=\"1\",stopped-threads=\"all\"")          # Test that lldb-mi is ready to execute next commands -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_abort(self):          """Test that 'lldb-mi --interpreter' works for -exec-abort.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -exec-abort fails on invalid process          self.runCmd("-exec-abort") -        self.expect("\^error,msg=\"Command 'exec-abort'\. Invalid process during debug session\"") +        self.expect( +            "\^error,msg=\"Command 'exec-abort'\. Invalid process during debug session\"")          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -83,19 +87,20 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^done")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_arguments_set(self):          """Test that 'lldb-mi --interpreter' can pass args using -exec-arguments.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          # Set arguments -        self.runCmd("-exec-arguments --arg1 \"2nd arg\" third_arg fourth=\"4th arg\"") +        self.runCmd( +            "-exec-arguments --arg1 \"2nd arg\" third_arg fourth=\"4th arg\"")          self.expect("\^done")          # Run to main @@ -109,7 +114,7 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-data-evaluate-expression argc")          self.expect("\^done,value=\"5\"")          #self.runCmd("-data-evaluate-expression argv[1]") -        #self.expect("\^done,value=\"--arg1\"") +        # self.expect("\^done,value=\"--arg1\"")          self.runCmd("-interpreter-exec command \"print argv[1]\"")          self.expect("\"--arg1\"")          #self.runCmd("-data-evaluate-expression argv[2]") @@ -117,7 +122,7 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-interpreter-exec command \"print argv[2]\"")          self.expect("\"2nd arg\"")          #self.runCmd("-data-evaluate-expression argv[3]") -        #self.expect("\^done,value=\"third_arg\"") +        # self.expect("\^done,value=\"third_arg\"")          self.runCmd("-interpreter-exec command \"print argv[3]\"")          self.expect("\"third_arg\"")          #self.runCmd("-data-evaluate-expression argv[4]") @@ -125,12 +130,12 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-interpreter-exec command \"print argv[4]\"")          self.expect("\"fourth=\\\\\\\"4th arg\\\\\\\"\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_arguments_reset(self):          """Test that 'lldb-mi --interpreter' can reset previously set args using -exec-arguments.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -153,12 +158,12 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-data-evaluate-expression argc")          self.expect("\^done,value=\"1\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_next(self):          """Test that 'lldb-mi --interpreter' works for stepping.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -176,22 +181,26 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -exec-next          self.runCmd("-exec-next --thread 1 --frame 0")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"29\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"29\"")          # Test that --thread is optional          self.runCmd("-exec-next --frame 0")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"30\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"30\"")          # Test that --frame is optional          self.runCmd("-exec-next --thread 1")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"31\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"31\"")          # Test that both --thread and --frame are optional          self.runCmd("-exec-next")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"32\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"32\"")          # Test that an invalid --thread is handled          self.runCmd("-exec-next --thread 0") @@ -204,13 +213,12 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-next --frame 10")          #self.expect("\^error: Frame index 10 is out of range") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @expectedFailureAll(archs=["i[3-6]86"], bugnumber="xfail to get buildbot green, failing config: i386 binary running on ubuntu 14.04 x86_64") +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_next_instruction(self):          """Test that 'lldb-mi --interpreter' works for instruction stepping.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -229,25 +237,29 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -exec-next-instruction          self.runCmd("-exec-next-instruction --thread 1 --frame 0")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"28\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"28\"")          # Test that --thread is optional          self.runCmd("-exec-next-instruction --frame 0")          self.expect("\^running")          # Depending on compiler, it can stop at different line -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"(28|29)\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"(28|29)\"")          # Test that --frame is optional          self.runCmd("-exec-next-instruction --thread 1")          self.expect("\^running")          # Depending on compiler, it can stop at different line -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"(29|30)\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"(28|29|30)\"")          # Test that both --thread and --frame are optional          self.runCmd("-exec-next-instruction")          self.expect("\^running")          # Depending on compiler, it can stop at different line -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"(29|30|31)\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"(29|30|31)\"")          # Test that an invalid --thread is handled          self.runCmd("-exec-next-instruction --thread 0") @@ -260,12 +272,12 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-next-instruction --frame 10")          #self.expect("\^error: Frame index 10 is out of range") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_step(self):          """Test that 'lldb-mi --interpreter' works for stepping into.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -283,39 +295,45 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -exec-step steps into (or not) printf depending on debug info          # Note that message is different in Darwin and Linux:          # Darwin: "*stopped,reason=\"end-stepping-range\",frame={addr=\"0x[0-9a-f]+\",func=\"main\",args=[{name=\"argc\",value=\"1\"},{name=\"argv\",value="0x[0-9a-f]+\"}],file=\"main.cpp\",fullname=\".+main.cpp\",line=\"\d\"},thread-id=\"1\",stopped-threads=\"all\" -        # Linux:  "*stopped,reason=\"end-stepping-range\",frame={addr="0x[0-9a-f]+\",func=\"__printf\",args=[{name=\"format\",value=\"0x[0-9a-f]+\"}],file=\"printf.c\",fullname=\".+printf.c\",line="\d+"},thread-id=\"1\",stopped-threads=\"all\" +        # Linux: +        # "*stopped,reason=\"end-stepping-range\",frame={addr="0x[0-9a-f]+\",func=\"__printf\",args=[{name=\"format\",value=\"0x[0-9a-f]+\"}],file=\"printf.c\",fullname=\".+printf.c\",line="\d+"},thread-id=\"1\",stopped-threads=\"all\"          self.runCmd("-exec-step --thread 1 --frame 0")          self.expect("\^running") -        it = self.expect([ "\*stopped,reason=\"end-stepping-range\".+?func=\"main\"", -                           "\*stopped,reason=\"end-stepping-range\".+?func=\"(?!main).+?\"" ]) +        it = self.expect(["\*stopped,reason=\"end-stepping-range\".+?func=\"main\"", +                          "\*stopped,reason=\"end-stepping-range\".+?func=\"(?!main).+?\""])          # Exit from printf if needed          if it == 1:              self.runCmd("-exec-finish")              self.expect("\^running") -            self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"main\"") +            self.expect( +                "\*stopped,reason=\"end-stepping-range\".+?func=\"main\"")          # Test that -exec-step steps into g_MyFunction and back out          # (and that --thread is optional)          self.runCmd("-exec-step --frame 0")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"")          # Use -exec-finish here to make sure that control reaches the caller.          # -exec-step can keep us in the g_MyFunction for gcc          self.runCmd("-exec-finish --frame 0")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"30\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"30\"")          # Test that -exec-step steps into s_MyFunction          # (and that --frame is optional)          self.runCmd("-exec-step --thread 1")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\".*?s_MyFunction.*?\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?func=\".*?s_MyFunction.*?\"")          # Test that -exec-step steps into g_MyFunction from inside          # s_MyFunction (and that both --thread and --frame are optional)          self.runCmd("-exec-step")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"")          # Test that an invalid --thread is handled          self.runCmd("-exec-step --thread 0") @@ -328,12 +346,12 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-step --frame 10")          #self.expect("\^error: Frame index 10 is out of range") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_step_instruction(self):          """Test that 'lldb-mi --interpreter' works for instruction stepping into.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -352,7 +370,8 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -exec-next steps over printf          self.runCmd("-exec-next --thread 1 --frame 0")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"29\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?main\.cpp\",line=\"29\"")          # Test that -exec-step-instruction steps over non branching          # instruction @@ -364,19 +383,22 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          # instruction (and that --thread is optional)          self.runCmd("-exec-step-instruction --frame 0")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"")          # Test that -exec-step-instruction steps over non branching          # (and that --frame is optional)          self.runCmd("-exec-step-instruction --thread 1")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"")          # Test that -exec-step-instruction steps into g_MyFunction          # (and that both --thread and --frame are optional)          self.runCmd("-exec-step-instruction")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?func=\"g_MyFunction.*?\"")          # Test that an invalid --thread is handled          self.runCmd("-exec-step-instruction --thread 0") @@ -389,12 +411,12 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-step-instruction --frame 10")          #self.expect("\^error: Frame index 10 is out of range") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_exec_finish(self):          """Test that 'lldb-mi --interpreter' works for -exec-finish.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -429,7 +451,8 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          # s_MyFunction (and that --frame is optional)          self.runCmd("-exec-finish --thread 1")          self.expect("\^running") -        self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\".*?s_MyFunction.*?\"") +        self.expect( +            "\*stopped,reason=\"end-stepping-range\".+?func=\".*?s_MyFunction.*?\"")          # Test that -exec-finish returns from s_MyFunction          # (and that both --thread and --frame are optional) @@ -455,7 +478,7 @@ class MiExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -        ## Test that -exec-finish returns from printf +        # Test that -exec-finish returns from printf          self.runCmd("-exec-finish --thread 1 --frame 0")          self.expect("\^running")          self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"main\"") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/data/TestMiData.py b/packages/Python/lldbsuite/test/tools/lldb-mi/data/TestMiData.py index a19387627c49..7281ae305dbe 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/data/TestMiData.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/data/TestMiData.py @@ -5,23 +5,23 @@ Test lldb-mi -data-xxx 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 MiDataTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_data_disassemble(self):          """Test that 'lldb-mi --interpreter' works for -data-disassemble.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -36,16 +36,23 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Get an address for disassembling: use main          self.runCmd("-data-evaluate-expression main") -        self.expect("\^done,value=\"0x[0-9a-f]+ \(a.out`main at main.cpp:[0-9]+\)\"") +        self.expect( +            "\^done,value=\"0x[0-9a-f]+ \(a.out`main at main.cpp:[0-9]+\)\"")          addr = int(self.child.after.split("\"")[1].split(" ")[0], 16)          # Test -data-disassemble: try to disassemble some address -        self.runCmd("-data-disassemble -s %#x -e %#x -- 0" % (addr, addr + 0x10)) -        self.expect("\^done,asm_insns=\[{address=\"0x0*%x\",func-name=\"main\",offset=\"0\",size=\"[1-9]+\",inst=\".+?\"}," % addr) -         +        self.runCmd( +            "-data-disassemble -s %#x -e %#x -- 0" % +            (addr, addr + 0x10)) +        self.expect( +            "\^done,asm_insns=\[{address=\"0x0*%x\",func-name=\"main\",offset=\"0\",size=\"[1-9]+\",inst=\".+?\"}," % +            addr) +          # Test -data-disassemble without "--"          self.runCmd("-data-disassemble -s %#x -e %#x 0" % (addr, addr + 0x10)) -        self.expect("\^done,asm_insns=\[{address=\"0x0*%x\",func-name=\"main\",offset=\"0\",size=\"[1-9]+\",inst=\".+?\"}," % addr) +        self.expect( +            "\^done,asm_insns=\[{address=\"0x0*%x\",func-name=\"main\",offset=\"0\",size=\"[1-9]+\",inst=\".+?\"}," % +            addr)          # Run to hello_world          self.runCmd("-break-insert -f hello_world") @@ -56,27 +63,31 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Get an address for disassembling: use hello_world          self.runCmd("-data-evaluate-expression hello_world") -        self.expect("\^done,value=\"0x[0-9a-f]+ \(a.out`hello_world\(\) at main.cpp:[0-9]+\)\"") +        self.expect( +            "\^done,value=\"0x[0-9a-f]+ \(a.out`hello_world\(\) at main.cpp:[0-9]+\)\"")          addr = int(self.child.after.split("\"")[1].split(" ")[0], 16)          # Test -data-disassemble: try to disassemble some address -        self.runCmd("-data-disassemble -s %#x -e %#x -- 0" % (addr, addr + 0x10)) +        self.runCmd( +            "-data-disassemble -s %#x -e %#x -- 0" % +            (addr, addr + 0x10))          # This matches a line similar to:          # Darwin: {address="0x0000000100000f18",func-name="hello_world()",offset="8",size="7",inst="leaq 0x65(%rip), %rdi; \"Hello, World!\\n\""},          # Linux:  {address="0x0000000000400642",func-name="hello_world()",offset="18",size="5",inst="callq 0x4004d0; symbol stub for: printf"}          # To match the escaped characters in the ouptut, we must use four backslashes per matches backslash          # See https://docs.python.org/2/howto/regex.html#the-backslash-plague -        self.expect([ "{address=\"0x[0-9a-f]+\",func-name=\"hello_world\(\)\",offset=\"[0-9]+\",size=\"[0-9]+\",inst=\".+?; \\\\\"Hello, World!\\\\\\\\n\\\\\"\"}", -                      "{address=\"0x[0-9a-f]+\",func-name=\"hello_world\(\)\",offset=\"[0-9]+\",size=\"[0-9]+\",inst=\".+?; symbol stub for: printf\"}" ]) +        self.expect(["{address=\"0x[0-9a-f]+\",func-name=\"hello_world\(\)\",offset=\"[0-9]+\",size=\"[0-9]+\",inst=\".+?; \\\\\"Hello, World!\\\\\\\\n\\\\\"\"}", +                     "{address=\"0x[0-9a-f]+\",func-name=\"hello_world\(\)\",offset=\"[0-9]+\",size=\"[0-9]+\",inst=\".+?; symbol stub for: printf\"}"]) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @unittest2.skip("-data-evaluate-expression doesn't work on globals") #FIXME: the global case worked before refactoring +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    # FIXME: the global case worked before refactoring +    @unittest2.skip("-data-evaluate-expression doesn't work on globals")      def test_lldbmi_data_read_memory_bytes_global(self):          """Test that -data-read-memory-bytes can access global buffers.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -97,7 +108,9 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -data-read-memory-bytes works for char[] type (global)          self.runCmd("-data-read-memory-bytes %#x %d" % (addr, size)) -        self.expect("\^done,memory=\[{begin=\"0x0*%x\",offset=\"0x0+\",end=\"0x0*%x\",contents=\"1112131400\"}\]" % (addr, addr + size)) +        self.expect( +            "\^done,memory=\[{begin=\"0x0*%x\",offset=\"0x0+\",end=\"0x0*%x\",contents=\"1112131400\"}\]" % +            (addr, addr + size))          # Get address of static char[]          self.runCmd("-data-evaluate-expression &s_CharArray") @@ -107,14 +120,16 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -data-read-memory-bytes works for static char[] type          self.runCmd("-data-read-memory-bytes %#x %d" % (addr, size)) -        self.expect("\^done,memory=\[{begin=\"0x0*%x\",offset=\"0x0+\",end=\"0x0*%x\",contents=\"1112131400\"}\]" % (addr, addr + size)) +        self.expect( +            "\^done,memory=\[{begin=\"0x0*%x\",offset=\"0x0+\",end=\"0x0*%x\",contents=\"1112131400\"}\]" % +            (addr, addr + size)) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_data_read_memory_bytes_local(self):          """Test that -data-read-memory-bytes can access local buffers.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd('-file-exec-and-symbols %s' % self.myexe) @@ -136,44 +151,65 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that an unquoted hex literal address works          self.runCmd('-data-read-memory-bytes %#x %d' % (addr, size)) -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % +            (addr, addr + size))          # Test that a double-quoted hex literal address works          self.runCmd('-data-read-memory-bytes "%#x" %d' % (addr, size)) -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % +            (addr, addr + size))          # Test that unquoted expressions work          self.runCmd('-data-read-memory-bytes &array %d' % size) -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % +            (addr, addr + size)) -        # This doesn't work, and perhaps that makes sense, but it does work on GDB +        # This doesn't work, and perhaps that makes sense, but it does work on +        # GDB          self.runCmd('-data-read-memory-bytes array 4')          self.expect(r'\^error')          #self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size))          self.runCmd('-data-read-memory-bytes &array[2] 2') -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="0304"\}\]' % (addr + 2, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="0304"\}\]' % +            (addr + 2, addr + size))          self.runCmd('-data-read-memory-bytes first_element_ptr %d' % size) -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % +            (addr, addr + size))          # Test that double-quoted expressions work          self.runCmd('-data-read-memory-bytes "&array" %d' % size) -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % +            (addr, addr + size))          self.runCmd('-data-read-memory-bytes "&array[0] + 1" 3') -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="020304"\}\]' % (addr + 1, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="020304"\}\]' % +            (addr + 1, addr + size))          self.runCmd('-data-read-memory-bytes "first_element_ptr + 1" 3') -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="020304"\}\]' % (addr + 1, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="020304"\}\]' % +            (addr + 1, addr + size))          # Test the -o (offset) option          self.runCmd('-data-read-memory-bytes -o 1 &array 3') -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="020304"\}\]' % (addr + 1, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="020304"\}\]' % +            (addr + 1, addr + size))          # Test the --thread option          self.runCmd('-data-read-memory-bytes --thread 1 &array 4') -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % +            (addr, addr + size))          # Test the --thread option with an invalid value          self.runCmd('-data-read-memory-bytes --thread 999 &array 4') @@ -181,22 +217,29 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Test the --frame option (current frame)          self.runCmd('-data-read-memory-bytes --frame 0 &array 4') -        self.expect(r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % (addr, addr + size)) +        self.expect( +            r'\^done,memory=\[\{begin="0x0*%x",offset="0x0+",end="0x0*%x",contents="01020304"\}\]' % +            (addr, addr + size))          # Test the --frame option (outer frame)          self.runCmd('-data-read-memory-bytes --frame 1 &array 4') -        self.expect(r'\^done,memory=\[\{begin="0x[0-9a-f]+",offset="0x0+",end="0x[0-9a-f]+",contents="05060708"\}\]') +        self.expect( +            r'\^done,memory=\[\{begin="0x[0-9a-f]+",offset="0x0+",end="0x[0-9a-f]+",contents="05060708"\}\]')          # Test the --frame option with an invalid value          self.runCmd('-data-read-memory-bytes --frame 999 &array 4')          self.expect(r'\^error')          # Test all the options at once -        self.runCmd('-data-read-memory-bytes --thread 1 --frame 1 -o 2 &array 2') -        self.expect(r'\^done,memory=\[\{begin="0x[0-9a-f]+",offset="0x0+",end="0x[0-9a-f]+",contents="0708"\}\]') - -        # Test that an expression that references undeclared variables doesn't work -        self.runCmd('-data-read-memory-bytes "&undeclared_array1 + undeclared_array2[1]" 2') +        self.runCmd( +            '-data-read-memory-bytes --thread 1 --frame 1 -o 2 &array 2') +        self.expect( +            r'\^done,memory=\[\{begin="0x[0-9a-f]+",offset="0x0+",end="0x[0-9a-f]+",contents="0708"\}\]') + +        # Test that an expression that references undeclared variables doesn't +        # work +        self.runCmd( +            '-data-read-memory-bytes "&undeclared_array1 + undeclared_array2[1]" 2')          self.expect(r'\^error')          # Test that the address argument is required @@ -207,23 +250,25 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd('-data-read-memory-bytes &array')          self.expect(r'\^error') -        # Test that the address and count arguments are required when other options are present +        # Test that the address and count arguments are required when other +        # options are present          self.runCmd('-data-read-memory-bytes --thread 1')          self.expect(r'\^error')          self.runCmd('-data-read-memory-bytes --thread 1 --frame 0')          self.expect(r'\^error') -        # Test that the count argument is required when other options are present +        # Test that the count argument is required when other options are +        # present          self.runCmd('-data-read-memory-bytes --thread 1 &array')          self.expect(r'\^error') -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_data_list_register_names(self):          """Test that 'lldb-mi --interpreter' works for -data-list-register-names.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -244,12 +289,12 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-data-list-register-names 0")          self.expect("\^done,register-names=\[\".+?\"\]") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_data_list_register_values(self):          """Test that 'lldb-mi --interpreter' works for -data-list-register-values.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -264,18 +309,20 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -data-list-register-values: try to get all registers          self.runCmd("-data-list-register-values x") -        self.expect("\^done,register-values=\[{number=\"0\",value=\"0x[0-9a-f]+\"") +        self.expect( +            "\^done,register-values=\[{number=\"0\",value=\"0x[0-9a-f]+\"")          # Test -data-list-register-values: try to get specified registers          self.runCmd("-data-list-register-values x 0") -        self.expect("\^done,register-values=\[{number=\"0\",value=\"0x[0-9a-f]+\"}\]") +        self.expect( +            "\^done,register-values=\[{number=\"0\",value=\"0x[0-9a-f]+\"}\]") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_data_info_line(self):          """Test that 'lldb-mi --interpreter' works for -data-info-line.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -290,38 +337,46 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          # Get the address of main and its line          self.runCmd("-data-evaluate-expression main") -        self.expect("\^done,value=\"0x[0-9a-f]+ \(a.out`main at main.cpp:[0-9]+\)\"") +        self.expect( +            "\^done,value=\"0x[0-9a-f]+ \(a.out`main at main.cpp:[0-9]+\)\"")          addr = int(self.child.after.split("\"")[1].split(" ")[0], 16)          line = line_number('main.cpp', '// FUNC_main')          # Test that -data-info-line works for address          self.runCmd("-data-info-line *%#x" % addr) -        self.expect("\^done,start=\"0x0*%x\",end=\"0x[0-9a-f]+\",file=\".+?main.cpp\",line=\"%d\"" % (addr, line)) +        self.expect( +            "\^done,start=\"0x0*%x\",end=\"0x[0-9a-f]+\",file=\".+?main.cpp\",line=\"%d\"" % +            (addr, line))          # Test that -data-info-line works for file:line          self.runCmd("-data-info-line main.cpp:%d" % line) -        self.expect("\^done,start=\"0x0*%x\",end=\"0x[0-9a-f]+\",file=\".+?main.cpp\",line=\"%d\"" % (addr, line)) +        self.expect( +            "\^done,start=\"0x0*%x\",end=\"0x[0-9a-f]+\",file=\".+?main.cpp\",line=\"%d\"" % +            (addr, line))          # Test that -data-info-line fails when invalid address is specified          self.runCmd("-data-info-line *0x0") -        self.expect("\^error,msg=\"Command 'data-info-line'\. Error: The LineEntry is absent or has an unknown format\.\"") +        self.expect( +            "\^error,msg=\"Command 'data-info-line'\. Error: The LineEntry is absent or has an unknown format\.\"")          # Test that -data-info-line fails when file is unknown          self.runCmd("-data-info-line unknown_file:1") -        self.expect("\^error,msg=\"Command 'data-info-line'\. Error: The LineEntry is absent or has an unknown format\.\"") +        self.expect( +            "\^error,msg=\"Command 'data-info-line'\. Error: The LineEntry is absent or has an unknown format\.\"")          # Test that -data-info-line fails when line has invalid format          self.runCmd("-data-info-line main.cpp:bad_line") -        self.expect("\^error,msg=\"error: invalid line number string 'bad_line'") +        self.expect( +            "\^error,msg=\"error: invalid line number string 'bad_line'")          self.runCmd("-data-info-line main.cpp:0")          self.expect("\^error,msg=\"error: zero is an invalid line number") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_data_evaluate_expression(self):          """Test that 'lldb-mi --interpreter' works for -data-evaluate-expression.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -334,6 +389,7 @@ class MiDataTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -        # Check 2d array  +        # Check 2d array          self.runCmd("-data-evaluate-expression array2d") -        self.expect("\^done,value=\"\{\[0\] = \{\[0\] = 1, \[1\] = 2, \[2\] = 3\}, \[1\] = \{\[0\] = 4, \[1\] = 5, \[2\] = 6\}\}\"") +        self.expect( +            "\^done,value=\"\{\[0\] = \{\[0\] = 1, \[1\] = 2, \[2\] = 3\}, \[1\] = \{\[0\] = 4, \[1\] = 5, \[2\] = 6\}\}\"") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiCliSupport.py b/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiCliSupport.py index d80bc7f94a65..24b3881c1be1 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiCliSupport.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiCliSupport.py @@ -5,22 +5,22 @@ Test lldb-mi can interpret CLI commands directly.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_target_create(self):          """Test that 'lldb-mi --interpreter' can create target by 'target create' command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that "target create" loads executable          self.runCmd("target create \"%s\"" % self.myexe) @@ -33,13 +33,13 @@ class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_breakpoint_set(self):          """Test that 'lldb-mi --interpreter' can set breakpoint by 'breakpoint set' command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -56,17 +56,18 @@ class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("=breakpoint-modified,bkpt={number=\"1\"")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_settings_set_target_run_args_before(self):          """Test that 'lldb-mi --interpreter' can set target arguments by 'setting set target.run-args' command before than target was created.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that "settings set target.run-args" passes arguments to executable -        #FIXME: --arg1 causes an error -        self.runCmd("setting set target.run-args arg1 \"2nd arg\" third_arg fourth=\"4th arg\"") +        # FIXME: --arg1 causes an error +        self.runCmd( +            "setting set target.run-args arg1 \"2nd arg\" third_arg fourth=\"4th arg\"")          self.expect("\^done")          # Load executable @@ -80,21 +81,22 @@ class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that arguments were passed properly          self.expect("@\"argc=5\\\\r\\\\n\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_settings_set_target_run_args_after(self):          """Test that 'lldb-mi --interpreter' can set target arguments by 'setting set target.run-args' command after than target was created.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          # Test that "settings set target.run-args" passes arguments to executable -        #FIXME: --arg1 causes an error -        self.runCmd("setting set target.run-args arg1 \"2nd arg\" third_arg fourth=\"4th arg\"") +        # FIXME: --arg1 causes an error +        self.runCmd( +            "setting set target.run-args arg1 \"2nd arg\" third_arg fourth=\"4th arg\"")          self.expect("\^done")          # Run @@ -104,13 +106,13 @@ class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that arguments were passed properly          self.expect("@\"argc=5\\\\r\\\\n\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_process_launch(self):          """Test that 'lldb-mi --interpreter' can launch process by "process launch" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -127,13 +129,13 @@ class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that breakpoint hit          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_thread_step_in(self):          """Test that 'lldb-mi --interpreter' can step in by "thread step-in" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -149,21 +151,23 @@ class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that "thread step-in" steps into (or not) printf depending on debug info          # Note that message is different in Darwin and Linux:          # Darwin: "*stopped,reason=\"end-stepping-range\",frame={addr=\"0x[0-9a-f]+\",func=\"main\",args=[{name=\"argc\",value=\"1\"},{name=\"argv\",value="0x[0-9a-f]+\"}],file=\"main.cpp\",fullname=\".+main.cpp\",line=\"\d\"},thread-id=\"1\",stopped-threads=\"all\" -        # Linux:  "*stopped,reason=\"end-stepping-range\",frame={addr="0x[0-9a-f]+\",func=\"__printf\",args=[{name=\"format\",value=\"0x[0-9a-f]+\"}],file=\"printf.c\",fullname=\".+printf.c\",line="\d+"},thread-id=\"1\",stopped-threads=\"all\" +        # Linux: +        # "*stopped,reason=\"end-stepping-range\",frame={addr="0x[0-9a-f]+\",func=\"__printf\",args=[{name=\"format\",value=\"0x[0-9a-f]+\"}],file=\"printf.c\",fullname=\".+printf.c\",line="\d+"},thread-id=\"1\",stopped-threads=\"all\"          self.runCmd("thread step-in")          self.expect("\^done") -        it = self.expect([ "@\"argc=1\\\\r\\\\n\"", -                           "\*stopped,reason=\"end-stepping-range\".+?func=\"(?!main).+?\"" ]) +        it = self.expect(["@\"argc=1\\\\r\\\\n\"", +                          "\*stopped,reason=\"end-stepping-range\".+?func=\"(?!main).+?\""])          if it == 0: -            self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"main\"") +            self.expect( +                "\*stopped,reason=\"end-stepping-range\".+?func=\"main\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_thread_step_over(self):          """Test that 'lldb-mi --interpreter' can step over by "thread step-over" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -182,13 +186,13 @@ class MiCliSupportTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("@\"argc=1\\\\r\\\\n\"")          self.expect("\*stopped,reason=\"end-stepping-range\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_thread_continue(self):          """Test that 'lldb-mi --interpreter' can continue execution by "thread continue" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiInterpreterExec.py b/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiInterpreterExec.py index 2bcaaad38f45..23da825d591b 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiInterpreterExec.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/interpreter/TestMiInterpreterExec.py @@ -5,25 +5,27 @@ Test lldb-mi -interpreter-exec command.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_target_create(self):          """Test that 'lldb-mi --interpreter' can create target by 'target create' command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that "target create" loads executable -        self.runCmd("-interpreter-exec console \"target create \\\"%s\\\"\"" % self.myexe) +        self.runCmd( +            "-interpreter-exec console \"target create \\\"%s\\\"\"" % +            self.myexe)          self.expect("\^done")          # Test that executable was loaded properly @@ -33,12 +35,12 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_breakpoint_set(self):          """Test that 'lldb-mi --interpreter' can set breakpoint by 'breakpoint set' command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -55,17 +57,18 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("=breakpoint-modified,bkpt={number=\"1\"")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      @expectedFlakeyLinux(bugnumber="llvm.org/pr25470")      def test_lldbmi_settings_set_target_run_args_before(self):          """Test that 'lldb-mi --interpreter' can set target arguments by 'setting set target.run-args' command before than target was created.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that "settings set target.run-args" passes arguments to executable -        #FIXME: --arg1 causes an error -        self.runCmd("-interpreter-exec console \"setting set target.run-args arg1 \\\"2nd arg\\\" third_arg fourth=\\\"4th arg\\\"\"") +        # FIXME: --arg1 causes an error +        self.runCmd( +            "-interpreter-exec console \"setting set target.run-args arg1 \\\"2nd arg\\\" third_arg fourth=\\\"4th arg\\\"\"")          self.expect("\^done")          # Load executable @@ -87,21 +90,24 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that program exited normally          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @expectedFailureAll(oslist=["linux"], bugnumber="Failing in ~9/600 dosep runs (build 3120-3122)") +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["linux"], +        bugnumber="Failing in ~9/600 dosep runs (build 3120-3122)")      def test_lldbmi_settings_set_target_run_args_after(self):          """Test that 'lldb-mi --interpreter' can set target arguments by 'setting set target.run-args' command after than target was created.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          # Test that "settings set target.run-args" passes arguments to executable -        #FIXME: --arg1 causes an error -        self.runCmd("-interpreter-exec console \"setting set target.run-args arg1 \\\"2nd arg\\\" third_arg fourth=\\\"4th arg\\\"\"") +        # FIXME: --arg1 causes an error +        self.runCmd( +            "-interpreter-exec console \"setting set target.run-args arg1 \\\"2nd arg\\\" third_arg fourth=\\\"4th arg\\\"\"")          self.expect("\^done")          # Run to BP_printf @@ -109,7 +115,7 @@ class MiInterpreterExecTestCase(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\"")          # Run to BP_return @@ -117,7 +123,7 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-break-insert main.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"2\"")          self.runCmd("-exec-continue") -        self.expect("\^running"); +        self.expect("\^running")          # Test that arguments were passed properly          self.expect("@\"argc=5\\\\r\\\\n\"") @@ -130,12 +136,12 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Hit BP_return          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_process_launch(self):          """Test that 'lldb-mi --interpreter' can launch process by "process launch" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -152,12 +158,12 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that breakpoint hit          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_thread_step_in(self):          """Test that 'lldb-mi --interpreter' can step in by "thread step-in" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -173,20 +179,22 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that "thread step-in" steps into (or not) printf depending on debug info          # Note that message is different in Darwin and Linux:          # Darwin: "*stopped,reason=\"end-stepping-range\",frame={addr=\"0x[0-9a-f]+\",func=\"main\",args=[{name=\"argc\",value=\"1\"},{name=\"argv\",value="0x[0-9a-f]+\"}],file=\"main.cpp\",fullname=\".+main.cpp\",line=\"\d\"},thread-id=\"1\",stopped-threads=\"all\" -        # Linux:  "*stopped,reason=\"end-stepping-range\",frame={addr="0x[0-9a-f]+\",func=\"__printf\",args=[{name=\"format\",value=\"0x[0-9a-f]+\"}],file=\"printf.c\",fullname=\".+printf.c\",line="\d+"},thread-id=\"1\",stopped-threads=\"all\" +        # Linux: +        # "*stopped,reason=\"end-stepping-range\",frame={addr="0x[0-9a-f]+\",func=\"__printf\",args=[{name=\"format\",value=\"0x[0-9a-f]+\"}],file=\"printf.c\",fullname=\".+printf.c\",line="\d+"},thread-id=\"1\",stopped-threads=\"all\"          self.runCmd("-interpreter-exec console \"thread step-in\"")          self.expect("\^done") -        it = self.expect([ "@\"argc=1\\\\r\\\\n\"", -                           "\*stopped,reason=\"end-stepping-range\".+?func=\"(?!main).+?\"" ]) +        it = self.expect(["@\"argc=1\\\\r\\\\n\"", +                          "\*stopped,reason=\"end-stepping-range\".+?func=\"(?!main).+?\""])          if it == 0: -            self.expect("\*stopped,reason=\"end-stepping-range\".+?func=\"main\"") +            self.expect( +                "\*stopped,reason=\"end-stepping-range\".+?func=\"main\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_thread_step_over(self):          """Test that 'lldb-mi --interpreter' can step over by "thread step-over" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -205,13 +213,13 @@ class MiInterpreterExecTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("@\"argc=1\\\\r\\\\n\"")          self.expect("\*stopped,reason=\"end-stepping-range\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      @expectedFlakeyLinux("llvm.org/pr25470")      def test_lldbmi_thread_continue(self):          """Test that 'lldb-mi --interpreter' can continue execution by "thread continue" command.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/lldbmi_testcase.py b/packages/Python/lldbsuite/test/tools/lldb-mi/lldbmi_testcase.py index 277ffe70c1ca..a862609d6978 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/lldbmi_testcase.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/lldbmi_testcase.py @@ -5,9 +5,9 @@ Base class for lldb-mi test cases.  from __future__ import print_function -  from lldbsuite.test.lldbtest import * +  class MiTestCaseBase(Base):      mydir = None @@ -43,7 +43,7 @@ class MiTestCaseBase(Base):          self.child.setecho(True)          self.child.logfile_read = open(self.mylog, "w")          # wait until lldb-mi has started up and is ready to go -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)      def runCmd(self, cmd):          self.child.sendline(cmd) diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/signal/TestMiSignal.py b/packages/Python/lldbsuite/test/tools/lldb-mi/signal/TestMiSignal.py index 197bfa80b3a0..e4cd98b22928 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/signal/TestMiSignal.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/signal/TestMiSignal.py @@ -5,22 +5,22 @@ Test that the lldb-mi handles signals properly.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Fails on FreeBSD apparently due to thread race conditions +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Fails on FreeBSD apparently due to thread race conditions      def test_lldbmi_stopped_when_interrupt(self):          """Test that 'lldb-mi --interpreter' interrupt and resume a looping app.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -41,23 +41,25 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -exec-interrupt can interrupt an execution          self.runCmd("-exec-interrupt") -        self.expect("\*stopped,reason=\"signal-received\",signal-name=\"SIGINT\",signal-meaning=\"Interrupt\",.+?thread-id=\"1\",stopped-threads=\"all\"") +        self.expect( +            "\*stopped,reason=\"signal-received\",signal-name=\"SIGINT\",signal-meaning=\"Interrupt\",.+?thread-id=\"1\",stopped-threads=\"all\"")          # Continue (to loop forever)          self.runCmd("-exec-continue")          self.expect("\^running")          # Test that Ctrl+C can interrupt an execution -        self.child.sendintr() #FIXME: here uses self.child directly -        self.expect("\*stopped,reason=\"signal-received\",signal-name=\"SIGINT\",signal-meaning=\"Interrupt\",.*thread-id=\"1\",stopped-threads=\"all\"") +        self.child.sendintr()  # FIXME: here uses self.child directly +        self.expect( +            "\*stopped,reason=\"signal-received\",signal-name=\"SIGINT\",signal-meaning=\"Interrupt\",.*thread-id=\"1\",stopped-threads=\"all\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Fails on FreeBSD apparently due to thread race conditions -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Fails on FreeBSD apparently due to thread race conditions +    @skipIfLinux  # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots      def test_lldbmi_stopped_when_stopatentry_local(self):          """Test that 'lldb-mi --interpreter' notifies after it was stopped on entry (local).""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -70,9 +72,12 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that *stopped is printed          # Note that message is different in Darwin and Linux:          # Darwin: "*stopped,reason=\"signal-received\",signal-name=\"SIGSTOP\",signal-meaning=\"Stop\",frame={level=\"0\",addr=\"0x[0-9a-f]+\",func=\"_dyld_start\",file=\"??\",fullname=\"??\",line=\"-1\"},thread-id=\"1\",stopped-threads=\"all\" -        # Linux:  "*stopped,reason=\"end-stepping-range\",frame={addr=\"0x[0-9a-f]+\",func=\"??\",args=[],file=\"??\",fullname=\"??\",line=\"-1\"},thread-id=\"1\",stopped-threads=\"all\" -        self.expect([ "\*stopped,reason=\"signal-received\",signal-name=\"SIGSTOP\",signal-meaning=\"Stop\",frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"_dyld_start\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\"\},thread-id=\"1\",stopped-threads=\"all\"", -                      "\*stopped,reason=\"end-stepping-range\",frame={addr=\"0x[0-9a-f]+\",func=\"\?\?\",args=\[\],file=\"\?\?\",fullname=\"\?\?\",line=\"-1\"},thread-id=\"1\",stopped-threads=\"all\"" ]) +        # Linux: +        # "*stopped,reason=\"end-stepping-range\",frame={addr=\"0x[0-9a-f]+\",func=\"??\",args=[],file=\"??\",fullname=\"??\",line=\"-1\"},thread-id=\"1\",stopped-threads=\"all\" +        self.expect( +            [ +                "\*stopped,reason=\"signal-received\",signal-name=\"SIGSTOP\",signal-meaning=\"Stop\",frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"_dyld_start\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\"\},thread-id=\"1\",stopped-threads=\"all\"", +                "\*stopped,reason=\"end-stepping-range\",frame={addr=\"0x[0-9a-f]+\",func=\"\?\?\",args=\[\],file=\"\?\?\",fullname=\"\?\?\",line=\"-1\"},thread-id=\"1\",stopped-threads=\"all\""])          # Run to main to make sure we have not exited the application          self.runCmd("-break-insert -f main") @@ -81,7 +86,7 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows      @skipUnlessDarwin      def test_lldbmi_stopped_when_stopatentry_remote(self):          """Test that 'lldb-mi --interpreter' notifies after it was stopped on entry (remote).""" @@ -93,19 +98,25 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):              self.skipTest("debugserver exe not found")          hostname = "localhost"          import random -        port = 12000 + random.randint(0,3999) # the same as GdbRemoteTestCaseBase.get_next_port +        # the same as GdbRemoteTestCaseBase.get_next_port +        port = 12000 + random.randint(0, 3999)          import pexpect -        debugserver_child = pexpect.spawn("%s %s:%d" % (debugserver_exe, hostname, port)) -        self.addTearDownHook(lambda: debugserver_child.terminate(force = True)) +        debugserver_child = pexpect.spawn( +            "%s %s:%d" % +            (debugserver_exe, hostname, port)) +        self.addTearDownHook(lambda: debugserver_child.terminate(force=True)) -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Connect to debugserver -        self.runCmd("-interpreter-exec command \"platform select remote-macosx --sysroot /\"") +        self.runCmd( +            "-interpreter-exec command \"platform select remote-macosx --sysroot /\"")          self.expect("\^done")          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done") -        self.runCmd("-interpreter-exec command \"process connect connect://%s:%d\"" % (hostname, port)) +        self.runCmd( +            "-interpreter-exec command \"process connect connect://%s:%d\"" % +            (hostname, port))          self.expect("\^done")          # Run with stop-at-entry flag @@ -113,19 +124,20 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^done")          # Test that *stopped is printed -        self.expect("\*stopped,reason=\"signal-received\",signal-name=\"SIGSTOP\",signal-meaning=\"Stop\",.+?thread-id=\"1\",stopped-threads=\"all\"") +        self.expect( +            "\*stopped,reason=\"signal-received\",signal-name=\"SIGSTOP\",signal-meaning=\"Stop\",.+?thread-id=\"1\",stopped-threads=\"all\"")          # Exit          self.runCmd("-gdb-exit")          self.expect("\^exit") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_stopped_when_segfault_local(self):          """Test that 'lldb-mi --interpreter' notifies after it was stopped when segfault occurred (local).""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -147,9 +159,11 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that *stopped is printed          # Note that message is different in Darwin and Linux:          # Darwin: "*stopped,reason=\"exception-received\",exception=\"EXC_BAD_ACCESS (code=1, address=0x0)\",thread-id=\"1\",stopped-threads=\"all\"" -        # Linux:  "*stopped,reason=\"exception-received\",exception=\"invalid address (fault address: 0x0)\",thread-id=\"1\",stopped-threads=\"all\"" -        self.expect([ "\*stopped,reason=\"exception-received\",exception=\"EXC_BAD_ACCESS \(code=1, address=0x0\)\",thread-id=\"1\",stopped-threads=\"all\"", -                      "\*stopped,reason=\"exception-received\",exception=\"invalid address \(fault address: 0x0\)\",thread-id=\"1\",stopped-threads=\"all\"" ]) +        # Linux:  "*stopped,reason=\"exception-received\",exception=\"invalid +        # address (fault address: +        # 0x0)\",thread-id=\"1\",stopped-threads=\"all\"" +        self.expect(["\*stopped,reason=\"exception-received\",exception=\"EXC_BAD_ACCESS \(code=1, address=0x0\)\",thread-id=\"1\",stopped-threads=\"all\"", +                     "\*stopped,reason=\"exception-received\",exception=\"invalid address \(fault address: 0x0\)\",thread-id=\"1\",stopped-threads=\"all\""])      @skipUnlessDarwin      def test_lldbmi_stopped_when_segfault_remote(self): @@ -162,27 +176,34 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):              self.skipTest("debugserver exe not found")          hostname = "localhost"          import random -        port = 12000 + random.randint(0,3999) # the same as GdbRemoteTestCaseBase.get_next_port +        # the same as GdbRemoteTestCaseBase.get_next_port +        port = 12000 + random.randint(0, 3999)          import pexpect -        debugserver_child = pexpect.spawn("%s %s:%d" % (debugserver_exe, hostname, port)) -        self.addTearDownHook(lambda: debugserver_child.terminate(force = True)) +        debugserver_child = pexpect.spawn( +            "%s %s:%d" % +            (debugserver_exe, hostname, port)) +        self.addTearDownHook(lambda: debugserver_child.terminate(force=True)) -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Connect to debugserver -        self.runCmd("-interpreter-exec command \"platform select remote-macosx --sysroot /\"") +        self.runCmd( +            "-interpreter-exec command \"platform select remote-macosx --sysroot /\"")          self.expect("\^done")          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done") -        self.runCmd("-interpreter-exec command \"process connect connect://%s:%d\"" % (hostname, port)) +        self.runCmd( +            "-interpreter-exec command \"process connect connect://%s:%d\"" % +            (hostname, port))          self.expect("\^done")          # Run to main          self.runCmd("-break-insert -f main")          self.expect("\^done,bkpt={number=\"1\"") -        #FIXME -exec-run doesn't work -        self.runCmd("-interpreter-exec command \"process launch\"") #FIXME: self.runCmd("-exec-run") -        self.expect("\^done")                                       #FIXME: self.expect("\^running") +        # FIXME -exec-run doesn't work +        # FIXME: self.runCmd("-exec-run") +        self.runCmd("-interpreter-exec command \"process launch\"") +        self.expect("\^done")  # FIXME: self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"")          # Set do_segfault=1 and run (to cause a segfault error) @@ -192,7 +213,8 @@ class MiSignalTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          # Test that *stopped is printed -        self.expect("\*stopped,reason=\"exception-received\",exception=\"EXC_BAD_ACCESS \(code=1, address=0x0\)\",thread-id=\"1\",stopped-threads=\"all\"") +        self.expect( +            "\*stopped,reason=\"exception-received\",exception=\"EXC_BAD_ACCESS \(code=1, address=0x0\)\",thread-id=\"1\",stopped-threads=\"all\"")          # Exit          self.runCmd("-gdb-exit") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/stack/TestMiStack.py b/packages/Python/lldbsuite/test/tools/lldb-mi/stack/TestMiStack.py index 54ed91951333..454597c1c5dd 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/stack/TestMiStack.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/stack/TestMiStack.py @@ -5,22 +5,22 @@ Test lldb-mi -stack-xxx commands.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_stack_list_arguments(self):          """Test that 'lldb-mi --interpreter' can shows arguments.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -33,55 +33,66 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -        # Test that -stack-list-arguments lists empty stack arguments if range is empty +        # Test that -stack-list-arguments lists empty stack arguments if range +        # is empty          self.runCmd("-stack-list-arguments 0 1 0")          self.expect("\^done,stack-args=\[\]")          # Test that -stack-list-arguments lists stack arguments without values          # (and that low-frame and high-frame are optional)          self.runCmd("-stack-list-arguments 0") -        self.expect("\^done,stack-args=\[frame={level=\"0\",args=\[name=\"argc\",name=\"argv\"\]}") +        self.expect( +            "\^done,stack-args=\[frame={level=\"0\",args=\[name=\"argc\",name=\"argv\"\]}")          self.runCmd("-stack-list-arguments --no-values") -        self.expect("\^done,stack-args=\[frame={level=\"0\",args=\[name=\"argc\",name=\"argv\"\]}") +        self.expect( +            "\^done,stack-args=\[frame={level=\"0\",args=\[name=\"argc\",name=\"argv\"\]}")          # Test that -stack-list-arguments lists stack arguments with all values          self.runCmd("-stack-list-arguments 1 0 0") -        self.expect("\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",value=\"1\"},{name=\"argv\",value=\".*\"}\]}\]") +        self.expect( +            "\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",value=\"1\"},{name=\"argv\",value=\".*\"}\]}\]")          self.runCmd("-stack-list-arguments --all-values 0 0") -        self.expect("\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",value=\"1\"},{name=\"argv\",value=\".*\"}\]}\]") +        self.expect( +            "\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",value=\"1\"},{name=\"argv\",value=\".*\"}\]}\]") -        # Test that -stack-list-arguments lists stack arguments with simple values +        # Test that -stack-list-arguments lists stack arguments with simple +        # values          self.runCmd("-stack-list-arguments 2 0 1") -        self.expect("\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",type=\"int\",value=\"1\"},{name=\"argv\",type=\"const char \*\*\",value=\".*\"}\]}") +        self.expect( +            "\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",type=\"int\",value=\"1\"},{name=\"argv\",type=\"const char \*\*\",value=\".*\"}\]}")          self.runCmd("-stack-list-arguments --simple-values 0 1") -        self.expect("\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",type=\"int\",value=\"1\"},{name=\"argv\",type=\"const char \*\*\",value=\".*\"}\]}") +        self.expect( +            "\^done,stack-args=\[frame={level=\"0\",args=\[{name=\"argc\",type=\"int\",value=\"1\"},{name=\"argv\",type=\"const char \*\*\",value=\".*\"}\]}") -        # Test that an invalid low-frame is handled  +        # Test that an invalid low-frame is handled          # FIXME: -1 is treated as unsigned int          self.runCmd("-stack-list-arguments 0 -1 0") -        #self.expect("\^error") +        # self.expect("\^error")          self.runCmd("-stack-list-arguments 0 0") -        self.expect("\^error,msg=\"Command 'stack-list-arguments'\. Thread frame range invalid\"") +        self.expect( +            "\^error,msg=\"Command 'stack-list-arguments'\. Thread frame range invalid\"")          # Test that an invalid high-frame is handled          # FIXME: -1 is treated as unsigned int          self.runCmd("-stack-list-arguments 0 0 -1") -        #self.expect("\^error") +        # self.expect("\^error")          # Test that a missing low-frame or high-frame is handled          self.runCmd("-stack-list-arguments 0 0") -        self.expect("\^error,msg=\"Command 'stack-list-arguments'\. Thread frame range invalid\"") +        self.expect( +            "\^error,msg=\"Command 'stack-list-arguments'\. Thread frame range invalid\"") -        # Test that an invalid low-frame is handled  +        # Test that an invalid low-frame is handled          self.runCmd("-stack-list-arguments 0 0") -        self.expect("\^error,msg=\"Command 'stack-list-arguments'\. Thread frame range invalid\"") +        self.expect( +            "\^error,msg=\"Command 'stack-list-arguments'\. Thread frame range invalid\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_stack_list_locals(self):          """Test that 'lldb-mi --interpreter' can shows local variables.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -111,16 +122,20 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -stack-list-locals: use 1 or --all-values          self.runCmd("-stack-list-locals 1") -        self.expect("\^done,locals=\[{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]")          self.runCmd("-stack-list-locals --all-values") -        self.expect("\^done,locals=\[{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]")          # Test -stack-list-locals: use 2 or --simple-values          self.runCmd("-stack-list-locals 2") -        self.expect("\^done,locals=\[{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]")          self.runCmd("-stack-list-locals --simple-values") -        self.expect("\^done,locals=\[{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]") -         +        self.expect( +            "\^done,locals=\[{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]") +          # Test struct local variable:          # Run to BP_local_struct_test          line = line_number('main.cpp', '// BP_local_struct_test') @@ -129,7 +144,7 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Test -stack-list-locals: use 0 or --no-values          self.runCmd("-stack-list-locals 0")          self.expect("\^done,locals=\[name=\"var_c\"\]") @@ -138,16 +153,18 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -stack-list-locals: use 1 or --all-values          self.runCmd("-stack-list-locals 1") -        self.expect("\^done,locals=\[{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]")          self.runCmd("-stack-list-locals --all-values") -        self.expect("\^done,locals=\[{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]")          # Test -stack-list-locals: use 2 or --simple-values          self.runCmd("-stack-list-locals 2")          self.expect("\^done,locals=\[{name=\"var_c\",type=\"my_type\"}\]")          self.runCmd("-stack-list-locals --simple-values")          self.expect("\^done,locals=\[{name=\"var_c\",type=\"my_type\"}\]") -         +          # Test array local variable:          # Run to BP_local_array_test          line = line_number('main.cpp', '// BP_local_array_test') @@ -156,7 +173,7 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Test -stack-list-locals: use 0 or --no-values          self.runCmd("-stack-list-locals 0")          self.expect("\^done,locals=\[name=\"array\"\]") @@ -165,16 +182,18 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -stack-list-locals: use 1 or --all-values          self.runCmd("-stack-list-locals 1") -        self.expect("\^done,locals=\[{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]")          self.runCmd("-stack-list-locals --all-values") -        self.expect("\^done,locals=\[{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]")          # Test -stack-list-locals: use 2 or --simple-values          self.runCmd("-stack-list-locals 2")          self.expect("\^done,locals=\[{name=\"array\",type=\"int \[3\]\"}\]")          self.runCmd("-stack-list-locals --simple-values")          self.expect("\^done,locals=\[{name=\"array\",type=\"int \[3\]\"}\]") -         +          # Test pointers as local variable:          # Run to BP_local_pointer_test          line = line_number('main.cpp', '// BP_local_pointer_test') @@ -183,26 +202,32 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Test -stack-list-locals: use 0 or --no-values          self.runCmd("-stack-list-locals 0") -        self.expect("\^done,locals=\[name=\"test_str\",name=\"var_e\",name=\"ptr\"\]") +        self.expect( +            "\^done,locals=\[name=\"test_str\",name=\"var_e\",name=\"ptr\"\]")          self.runCmd("-stack-list-locals --no-values") -        self.expect("\^done,locals=\[name=\"test_str\",name=\"var_e\",name=\"ptr\"\]") +        self.expect( +            "\^done,locals=\[name=\"test_str\",name=\"var_e\",name=\"ptr\"\]")          # Test -stack-list-locals: use 1 or --all-values          self.runCmd("-stack-list-locals 1") -        self.expect("\^done,locals=\[{name=\"test_str\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",value=\"24\"},{name=\"ptr\",value=\".*?\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"test_str\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",value=\"24\"},{name=\"ptr\",value=\".*?\"}\]")          self.runCmd("-stack-list-locals --all-values") -        self.expect("\^done,locals=\[{name=\"test_str\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",value=\"24\"},{name=\"ptr\",value=\".*?\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"test_str\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",value=\"24\"},{name=\"ptr\",value=\".*?\"}\]")          # Test -stack-list-locals: use 2 or --simple-values          self.runCmd("-stack-list-locals 2") -        self.expect("\^done,locals=\[{name=\"test_str\",type=\"const char \*\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",type=\"int\",value=\"24\"},{name=\"ptr\",type=\"int \*\",value=\".*?\"}\]") +        self.expect( +            "\^done,locals=\[{name=\"test_str\",type=\"const char \*\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",type=\"int\",value=\"24\"},{name=\"ptr\",type=\"int \*\",value=\".*?\"}\]")          self.runCmd("-stack-list-locals --simple-values") -        self.expect("\^done,locals=\[{name=\"test_str\",type=\"const char \*\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",type=\"int\",value=\"24\"},{name=\"ptr\",type=\"int \*\",value=\".*?\"}\]") -         -        # Test -stack-list-locals in a function with catch clause,  +        self.expect( +            "\^done,locals=\[{name=\"test_str\",type=\"const char \*\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",type=\"int\",value=\"24\"},{name=\"ptr\",type=\"int \*\",value=\".*?\"}\]") + +        # Test -stack-list-locals in a function with catch clause,          # having unnamed parameter          # Run to BP_catch_unnamed          line = line_number('main.cpp', '// BP_catch_unnamed') @@ -215,12 +240,13 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -stack-list-locals: use --no-values          self.runCmd("-stack-list-locals --no-values")          self.expect("\^done,locals=\[name=\"i\",name=\"j\"\]") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races + +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_stack_list_variables(self):          """Test that 'lldb-mi --interpreter' can shows local variables and arguments.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -244,22 +270,28 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test -stack-list-variables: use 0 or --no-values          self.runCmd("-stack-list-variables 0") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"c\"},{arg=\"1\",name=\"d\"},{name=\"a\"},{name=\"b\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"c\"},{arg=\"1\",name=\"d\"},{name=\"a\"},{name=\"b\"}\]")          self.runCmd("-stack-list-variables --no-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"c\"},{arg=\"1\",name=\"d\"},{name=\"a\"},{name=\"b\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"c\"},{arg=\"1\",name=\"d\"},{name=\"a\"},{name=\"b\"}\]")          # Test -stack-list-variables: use 1 or --all-values          self.runCmd("-stack-list-variables 1") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"c\",value=\"30\"},{arg=\"1\",name=\"d\",value=\"40\"},{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"c\",value=\"30\"},{arg=\"1\",name=\"d\",value=\"40\"},{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]")          self.runCmd("-stack-list-variables --all-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"c\",value=\"30\"},{arg=\"1\",name=\"d\",value=\"40\"},{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"c\",value=\"30\"},{arg=\"1\",name=\"d\",value=\"40\"},{name=\"a\",value=\"10\"},{name=\"b\",value=\"20\"}\]")          # Test -stack-list-variables: use 2 or --simple-values          self.runCmd("-stack-list-variables 2") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"c\",type=\"int\",value=\"30\"},{arg=\"1\",name=\"d\",type=\"int\",value=\"40\"},{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"c\",type=\"int\",value=\"30\"},{arg=\"1\",name=\"d\",type=\"int\",value=\"40\"},{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]")          self.runCmd("-stack-list-variables --simple-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"c\",type=\"int\",value=\"30\"},{arg=\"1\",name=\"d\",type=\"int\",value=\"40\"},{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]") -         +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"c\",type=\"int\",value=\"30\"},{arg=\"1\",name=\"d\",type=\"int\",value=\"40\"},{name=\"a\",type=\"int\",value=\"10\"},{name=\"b\",type=\"int\",value=\"20\"}\]") +          # Test struct local variable:          # Run to BP_local_struct_test          line = line_number('main.cpp', '// BP_local_struct_test_with_args') @@ -268,25 +300,31 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Test -stack-list-variables: use 0 or --no-values          self.runCmd("-stack-list-variables 0") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"var_e\"},{name=\"var_c\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"var_e\"},{name=\"var_c\"}\]")          self.runCmd("-stack-list-variables --no-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"var_e\"},{name=\"var_c\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"var_e\"},{name=\"var_c\"}\]")          # Test -stack-list-variables: use 1 or --all-values          self.runCmd("-stack-list-variables 1") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"var_e\",value=\"{var_a = 20, var_b = 98 'b', inner_ = {var_d = 40}}\"},{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"var_e\",value=\"{var_a = 20, var_b = 98 'b', inner_ = {var_d = 40}}\"},{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]")          self.runCmd("-stack-list-variables --all-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"var_e\",value=\"{var_a = 20, var_b = 98 'b', inner_ = {var_d = 40}}\"},{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"var_e\",value=\"{var_a = 20, var_b = 98 'b', inner_ = {var_d = 40}}\"},{name=\"var_c\",value=\"{var_a = 10, var_b = 97 'a', inner_ = {var_d = 30}}\"}\]")          # Test -stack-list-variables: use 2 or --simple-values          self.runCmd("-stack-list-variables 2") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"var_e\",type=\"my_type\"},{name=\"var_c\",type=\"my_type\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"var_e\",type=\"my_type\"},{name=\"var_c\",type=\"my_type\"}\]")          self.runCmd("-stack-list-variables --simple-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"var_e\",type=\"my_type\"},{name=\"var_c\",type=\"my_type\"}\]") -         +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"var_e\",type=\"my_type\"},{name=\"var_c\",type=\"my_type\"}\]") +          # Test array local variable:          # Run to BP_local_array_test          line = line_number('main.cpp', '// BP_local_array_test_with_args') @@ -295,25 +333,31 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Test -stack-list-variables: use 0 or --no-values          self.runCmd("-stack-list-variables 0") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"other_array\"},{name=\"array\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"other_array\"},{name=\"array\"}\]")          self.runCmd("-stack-list-variables --no-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"other_array\"},{name=\"array\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"other_array\"},{name=\"array\"}\]")          # Test -stack-list-variables: use 1 or --all-values          self.runCmd("-stack-list-variables 1") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"other_array\",value=\".*?\"},{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"other_array\",value=\".*?\"},{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]")          self.runCmd("-stack-list-variables --all-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"other_array\",value=\".*?\"},{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"other_array\",value=\".*?\"},{name=\"array\",value=\"{\[0\] = 100, \[1\] = 200, \[2\] = 300}\"}\]")          # Test -stack-list-variables: use 2 or --simple-values          self.runCmd("-stack-list-variables 2") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"other_array\",type=\"int \*\",value=\".*?\"},{name=\"array\",type=\"int \[3\]\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"other_array\",type=\"int \*\",value=\".*?\"},{name=\"array\",type=\"int \[3\]\"}\]")          self.runCmd("-stack-list-variables --simple-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"other_array\",type=\"int \*\",value=\".*?\"},{name=\"array\",type=\"int \[3\]\"}\]") -         +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"other_array\",type=\"int \*\",value=\".*?\"},{name=\"array\",type=\"int \[3\]\"}\]") +          # Test pointers as local variable:          # Run to BP_local_pointer_test          line = line_number('main.cpp', '// BP_local_pointer_test_with_args') @@ -322,12 +366,14 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-exec-continue")          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Test -stack-list-variables: use 0 or --no-values          self.runCmd("-stack-list-variables 0") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"arg_str\"},{arg=\"1\",name=\"arg_ptr\"},{name=\"test_str\"},{name=\"var_e\"},{name=\"ptr\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"arg_str\"},{arg=\"1\",name=\"arg_ptr\"},{name=\"test_str\"},{name=\"var_e\"},{name=\"ptr\"}\]")          self.runCmd("-stack-list-variables --no-values") -        self.expect("\^done,variables=\[{arg=\"1\",name=\"arg_str\"},{arg=\"1\",name=\"arg_ptr\"},{name=\"test_str\"},{name=\"var_e\"},{name=\"ptr\"}\]") +        self.expect( +            "\^done,variables=\[{arg=\"1\",name=\"arg_str\"},{arg=\"1\",name=\"arg_ptr\"},{name=\"test_str\"},{name=\"var_e\"},{name=\"ptr\"}\]")          # Test -stack-list-variables: use 1 or --all-values          self.runCmd("-stack-list-variables 1") @@ -340,13 +386,13 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^done,variables=\[{arg=\"1\",name=\"arg_str\",type=\"const char \*\",value=\".*?String.*?\"},{arg=\"1\",name=\"arg_ptr\",type=\"int \*\",value=\".*?\"},{name=\"test_str\",type=\"const char \*\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",type=\"int\",value=\"24\"},{name=\"ptr\",type=\"int \*\",value=\".*?\"}\]")          self.runCmd("-stack-list-variables --simple-values")          self.expect("\^done,variables=\[{arg=\"1\",name=\"arg_str\",type=\"const char \*\",value=\".*?String.*?\"},{arg=\"1\",name=\"arg_ptr\",type=\"int \*\",value=\".*?\"},{name=\"test_str\",type=\"const char \*\",value=\".*?Rakaposhi.*?\"},{name=\"var_e\",type=\"int\",value=\"24\"},{name=\"ptr\",type=\"int \*\",value=\".*?\"}\]") -         -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races + +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_stack_info_depth(self):          """Test that 'lldb-mi --interpreter' can shows depth of the stack.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -365,26 +411,27 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^done,depth=\"[1-9]\"")          # Test that max-depth restricts check of stack depth -        #FIXME: max-depth argument is ignored +        # FIXME: max-depth argument is ignored          self.runCmd("-stack-info-depth 1") -        #self.expect("\^done,depth=\"1\"") +        # self.expect("\^done,depth=\"1\"")          # Test that invalid max-depth argument is handled -        #FIXME: max-depth argument is ignored +        # FIXME: max-depth argument is ignored          self.runCmd("-stack-info-depth -1") -        #self.expect("\^error") +        # self.expect("\^error") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      @skipUnlessDarwin      def test_lldbmi_stack_info_frame(self):          """Test that 'lldb-mi --interpreter' can show information about current frame.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Test that -stack-info-frame fails when program isn't running          self.runCmd("-stack-info-frame") -        self.expect("\^error,msg=\"Command 'stack-info-frame'\. Invalid process during debug session\"") +        self.expect( +            "\^error,msg=\"Command 'stack-info-frame'\. Invalid process during debug session\"")          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -399,7 +446,8 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -stack-info-frame works when program was stopped on BP          self.runCmd("-stack-info-frame") -        self.expect("\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}") +        self.expect( +            "\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}")          # Select frame #1          self.runCmd("-stack-select-frame 1") @@ -407,19 +455,20 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -stack-info-frame works when specified frame was selected          self.runCmd("-stack-info-frame") -        self.expect("\^done,frame=\{level=\"1\",addr=\"0x[0-9a-f]+\",func=\".+?\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\"\}") +        self.expect( +            "\^done,frame=\{level=\"1\",addr=\"0x[0-9a-f]+\",func=\".+?\",file=\"\?\?\",fullname=\"\?\?\",line=\"-1\"\}")          # Test that -stack-info-frame fails when an argument is specified -        #FIXME: unknown argument is ignored +        # FIXME: unknown argument is ignored          self.runCmd("-stack-info-frame unknown_arg") -        #self.expect("\^error") +        # self.expect("\^error") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_stack_list_frames(self):          """Test that 'lldb-mi --interpreter' can lists the frames on the stack.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -434,14 +483,15 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test stack frame: get frame #0 info          self.runCmd("-stack-list-frames 0 0") -        self.expect("\^done,stack=\[frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}\]") +        self.expect( +            "\^done,stack=\[frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}\]") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_stack_select_frame(self):          """Test that 'lldb-mi --interpreter' can choose current frame.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -456,15 +506,18 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -stack-select-frame requires 1 mandatory argument          self.runCmd("-stack-select-frame") -        self.expect("\^error,msg=\"Command 'stack-select-frame'\. Command Args\. Validation failed. Mandatory args not found: frame_id\"") +        self.expect( +            "\^error,msg=\"Command 'stack-select-frame'\. Command Args\. Validation failed. Mandatory args not found: frame_id\"")          # Test that -stack-select-frame fails on invalid frame number          self.runCmd("-stack-select-frame 99") -        self.expect("\^error,msg=\"Command 'stack-select-frame'\. Frame ID invalid\"") +        self.expect( +            "\^error,msg=\"Command 'stack-select-frame'\. Frame ID invalid\"")          # Test that current frame is #0          self.runCmd("-stack-info-frame") -        self.expect("\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}") +        self.expect( +            "\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}")          # Test that -stack-select-frame can select the selected frame          self.runCmd("-stack-select-frame 0") @@ -472,7 +525,8 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that current frame is still #0          self.runCmd("-stack-info-frame") -        self.expect("\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}") +        self.expect( +            "\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}")          # Test that -stack-select-frame can select frame #1 (parent frame)          self.runCmd("-stack-select-frame 1") @@ -481,9 +535,11 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that current frame is #1          # Note that message is different in Darwin and Linux:          # Darwin: "^done,frame={level=\"1\",addr=\"0x[0-9a-f]+\",func=\"start\",file=\"??\",fullname=\"??\",line=\"-1\"}" -        # Linux:  "^done,frame={level=\"1\",addr=\"0x[0-9a-f]+\",func=\".+\",file=\".+\",fullname=\".+\",line=\"\d+\"}" +        # Linux: +        # "^done,frame={level=\"1\",addr=\"0x[0-9a-f]+\",func=\".+\",file=\".+\",fullname=\".+\",line=\"\d+\"}"          self.runCmd("-stack-info-frame") -        self.expect("\^done,frame=\{level=\"1\",addr=\"0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\"\}") +        self.expect( +            "\^done,frame=\{level=\"1\",addr=\"0x[0-9a-f]+\",func=\".+?\",file=\".+?\",fullname=\".+?\",line=\"(-1|\d+)\"\}")          # Test that -stack-select-frame can select frame #0 (child frame)          self.runCmd("-stack-select-frame 0") @@ -491,4 +547,5 @@ class MiStackTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that current frame is #0 and it has the same information          self.runCmd("-stack-info-frame") -        self.expect("\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}") +        self.expect( +            "\^done,frame=\{level=\"0\",addr=\"0x[0-9a-f]+\",func=\"main\",file=\"main\.cpp\",fullname=\".+?main\.cpp\",line=\"\d+\"\}") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/startup_options/TestMiStartupOptions.py b/packages/Python/lldbsuite/test/tools/lldb-mi/startup_options/TestMiStartupOptions.py index 8ddb6b3a1509..7673846d6df5 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/startup_options/TestMiStartupOptions.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/startup_options/TestMiStartupOptions.py @@ -9,23 +9,24 @@ from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_executable_option_file(self):          """Test that 'lldb-mi --interpreter %s' loads executable file.""" -        self.spawnLldbMi(args = "%s" % self.myexe) +        self.spawnLldbMi(args="%s" % self.myexe)          # Test that the executable is loaded when file was specified          self.expect("-file-exec-and-symbols \"%s\"" % self.myexe)          self.expect("\^done")          # Test that lldb-mi is ready when executable was loaded -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Run to main          self.runCmd("-break-insert -f main") @@ -39,25 +40,27 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_executable_option_unknown_file(self):          """Test that 'lldb-mi --interpreter %s' fails on unknown executable file."""          # Prepare path to executable          path = "unknown_file" -        self.spawnLldbMi(args = "%s" % path) +        self.spawnLldbMi(args="%s" % path)          # Test that the executable isn't loaded when unknown file was specified          self.expect("-file-exec-and-symbols \"%s\"" % path) -        self.expect("\^error,msg=\"Command 'file-exec-and-symbols'. Target binary '%s' is invalid. error: unable to find executable for '%s'\"" % (path, path)) +        self.expect( +            "\^error,msg=\"Command 'file-exec-and-symbols'. Target binary '%s' is invalid. error: unable to find executable for '%s'\"" % +            (path, path))          # Test that lldb-mi is ready when executable was loaded -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_executable_option_absolute_path(self):          """Test that 'lldb-mi --interpreter %s' loads executable which is specified via absolute path.""" @@ -65,69 +68,74 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          import os          path = os.path.join(os.getcwd(), self.myexe) -        self.spawnLldbMi(args = "%s" % path) +        self.spawnLldbMi(args="%s" % path) -        # Test that the executable is loaded when file was specified using absolute path +        # Test that the executable is loaded when file was specified using +        # absolute path          self.expect("-file-exec-and-symbols \"%s\"" % path)          self.expect("\^done")          # Test that lldb-mi is ready when executable was loaded -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Run          self.runCmd("-exec-run")          self.expect("\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_executable_option_relative_path(self):          """Test that 'lldb-mi --interpreter %s' loads executable which is specified via relative path."""          # Prepare path to executable          path = "./%s" % self.myexe -        self.spawnLldbMi(args = "%s" % path) +        self.spawnLldbMi(args="%s" % path) -        # Test that the executable is loaded when file was specified using relative path +        # Test that the executable is loaded when file was specified using +        # relative path          self.expect("-file-exec-and-symbols \"%s\"" % path)          self.expect("\^done")          # Test that lldb-mi is ready when executable was loaded -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Run          self.runCmd("-exec-run")          self.expect("\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_executable_option_unknown_path(self):          """Test that 'lldb-mi --interpreter %s' fails on executable file which is specified via unknown path."""          # Prepare path to executable          path = "unknown_dir/%s" % self.myexe -        self.spawnLldbMi(args = "%s" % path) +        self.spawnLldbMi(args="%s" % path) -        # Test that the executable isn't loaded when file was specified using unknown path +        # Test that the executable isn't loaded when file was specified using +        # unknown path          self.expect("-file-exec-and-symbols \"%s\"" % path) -        self.expect("\^error,msg=\"Command 'file-exec-and-symbols'. Target binary '%s' is invalid. error: unable to find executable for '%s'\"" % (path, path)) +        self.expect( +            "\^error,msg=\"Command 'file-exec-and-symbols'. Target binary '%s' is invalid. error: unable to find executable for '%s'\"" % +            (path, path))          # Test that lldb-mi is ready when executable was loaded -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_source_option_start_script(self):          """Test that 'lldb-mi --interpreter' can execute user's commands after initial commands were executed."""          # Prepared source file          sourceFile = "start_script" -        self.spawnLldbMi(args = "--source %s" % sourceFile) +        self.spawnLldbMi(args="--source %s" % sourceFile)          # After '-file-exec-and-symbols a.out'          self.expect("-file-exec-and-symbols %s" % self.myexe) @@ -153,23 +161,23 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\*stopped,reason=\"breakpoint-hit\"")          # Test that lldb-mi is ready after execution of --source start_script -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Try to evaluate 'a' expression          self.runCmd("-data-evaluate-expression a")          self.expect("\^done,value=\"10\"") -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_source_option_start_script_exit(self):          """Test that 'lldb-mi --interpreter' can execute a prepared file which passed via --source option."""          # Prepared source file          sourceFile = "start_script_exit" -        self.spawnLldbMi(args = "--source %s" % sourceFile) +        self.spawnLldbMi(args="--source %s" % sourceFile)          # After '-file-exec-and-symbols a.out'          self.expect("-file-exec-and-symbols %s" % self.myexe) @@ -203,15 +211,15 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^exit")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_source_option_start_script_error(self):          """Test that 'lldb-mi --interpreter' stops execution of initial commands in case of error."""          # Prepared source file          sourceFile = "start_script_error" -        self.spawnLldbMi(args = "--source %s" % sourceFile) +        self.spawnLldbMi(args="--source %s" % sourceFile)          # After '-file-exec-and-symbols a.out'          self.expect("-file-exec-and-symbols %s" % self.myexe) @@ -222,22 +230,22 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^error")          # Test that lldb-mi is ready after execution of --source start_script -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_log_option(self):          """Test that 'lldb-mi --log' creates a log file in the current directory.""" -     +          logDirectory = "." -        self.spawnLldbMi(args = "%s --log" % self.myexe) +        self.spawnLldbMi(args="%s --log" % self.myexe)          # Test that the executable is loaded when file was specified          self.expect("-file-exec-and-symbols \"%s\"" % self.myexe)          self.expect("\^done")          # Test that lldb-mi is ready when executable was loaded -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Run          self.runCmd("-exec-run") @@ -245,7 +253,8 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\*stopped,reason=\"exited-normally\"")          # Check log file is created -        import glob,os +        import glob +        import os          logFile = glob.glob(logDirectory + "/lldb-mi-*.log")          if not logFile: @@ -255,23 +264,25 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          for f in logFile:              os.remove(f) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_log_directory_option(self):          """Test that 'lldb-mi --log --log-dir' creates a log file in the directory specified by --log-dir.""" -     +          # Create log in temp directory          import tempfile          logDirectory = tempfile.gettempdir() -        self.spawnLldbMi(args = "%s --log --log-dir=%s" % (self.myexe,logDirectory)) +        self.spawnLldbMi( +            args="%s --log --log-dir=%s" % +            (self.myexe, logDirectory))          # Test that the executable is loaded when file was specified          self.expect("-file-exec-and-symbols \"%s\"" % self.myexe)          self.expect("\^done")          # Test that lldb-mi is ready when executable was loaded -        self.expect(self.child_prompt, exactly = True) +        self.expect(self.child_prompt, exactly=True)          # Run          self.runCmd("-exec-run") @@ -279,12 +290,13 @@ class MiStartupOptionsTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\*stopped,reason=\"exited-normally\"")          # Check log file is created -        import glob,os +        import glob +        import os          logFile = glob.glob(logDirectory + "/lldb-mi-*.log")          if not logFile: -            self.fail("log file not found")              -    +            self.fail("log file not found") +          # Delete log          for f in logFile:              os.remove(f) diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/symbol/TestMiSymbol.py b/packages/Python/lldbsuite/test/tools/lldb-mi/symbol/TestMiSymbol.py index 859c096e336d..23374330ba1f 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/symbol/TestMiSymbol.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/symbol/TestMiSymbol.py @@ -5,23 +5,25 @@ Test lldb-mi -symbol-xxx commands.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiSymbolTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @expectedFailureAll(oslist=["linux"], bugnumber="new failure after r256863") +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["linux"], +        bugnumber="new failure after r256863")      def test_lldbmi_symbol_list_lines_file(self):          """Test that 'lldb-mi --interpreter' works for -symbol-list-lines when file exists.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -36,22 +38,31 @@ class MiSymbolTestCase(lldbmi_testcase.MiTestCaseBase):          # Get address of main and its line          self.runCmd("-data-evaluate-expression main") -        self.expect("\^done,value=\"0x[0-9a-f]+ \(a.out`main at main.cpp:[0-9]+\)\"") +        self.expect( +            "\^done,value=\"0x[0-9a-f]+ \(a.out`main at main.cpp:[0-9]+\)\"")          addr = int(self.child.after.split("\"")[1].split(" ")[0], 16)          line = line_number('main.cpp', '// FUNC_main')          # Test that -symbol-list-lines works on valid data          self.runCmd("-symbol-list-lines main.cpp") -        self.expect("\^done,lines=\[\{pc=\"0x0*%x\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"\d+\"\})+\]" % (addr, line)) +        self.expect( +            "\^done,lines=\[\{pc=\"0x0*%x\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"\d+\"\})+\]" % +            (addr, line))          # Test that -symbol-list-lines doesn't include lines from other sources          # by checking the first and last line, and making sure the other lines          # are between 30 and 39. -        sline = line_number('symbol_list_lines_inline_test2.cpp', '// FUNC_gfunc2') -        eline = line_number('symbol_list_lines_inline_test2.cpp', '// END_gfunc2') +        sline = line_number( +            'symbol_list_lines_inline_test2.cpp', +            '// FUNC_gfunc2') +        eline = line_number( +            'symbol_list_lines_inline_test2.cpp', +            '// END_gfunc2')          self.runCmd("-symbol-list-lines symbol_list_lines_inline_test2.cpp") -        self.expect("\^done,lines=\[\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"3\d\"\})*,\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"3\d\"\})*\]" % (sline, eline)) -        ##FIXME: This doesn't work for symbol_list_lines_inline_test.cpp due to clang bug llvm.org/pr24716 (fixed in newer versions of clang) +        self.expect( +            "\^done,lines=\[\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"3\d\"\})*,\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"3\d\"\})*\]" % +            (sline, eline)) +        # FIXME: This doesn't work for symbol_list_lines_inline_test.cpp due to clang bug llvm.org/pr24716 (fixed in newer versions of clang)          ##sline = line_number('symbol_list_lines_inline_test.cpp', '// FUNC_gfunc')          ##eline = line_number('symbol_list_lines_inline_test.cpp', '// STRUCT_s')          ##self.runCmd("-symbol-list-lines symbol_list_lines_inline_test.cpp") @@ -62,22 +73,31 @@ class MiSymbolTestCase(lldbmi_testcase.MiTestCaseBase):          sline = line_number('symbol_list_lines_inline_test.h', '// FUNC_ifunc')          eline = line_number('symbol_list_lines_inline_test.h', '// FUNC_mfunc')          self.runCmd("-symbol-list-lines symbol_list_lines_inline_test.h") -        self.expect("\^done,lines=\[\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"\d\"\})*(,\{pc=\"0x[0-9a-f]+\",line=\"1\d\"\})*,\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"2\d\"\})*\]" % (sline, eline)) +        self.expect( +            "\^done,lines=\[\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"\d\"\})*(,\{pc=\"0x[0-9a-f]+\",line=\"1\d\"\})*,\{pc=\"0x[0-9a-f]+\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"2\d\"\})*\]" % +            (sline, eline))          # Test that -symbol-list-lines fails when file doesn't exist          self.runCmd("-symbol-list-lines unknown_file") -        self.expect("\^error,message=\"error: No source filenames matched 'unknown_file'\. \"") +        self.expect( +            "\^error,message=\"error: No source filenames matched 'unknown_file'\. \"") -        # Test that -symbol-list-lines fails when file is specified using relative path +        # Test that -symbol-list-lines fails when file is specified using +        # relative path          self.runCmd("-symbol-list-lines ./main.cpp") -        self.expect("\^error,message=\"error: No source filenames matched '\./main\.cpp'\. \"") +        self.expect( +            "\^error,message=\"error: No source filenames matched '\./main\.cpp'\. \"") -        # Test that -symbol-list-lines works when file is specified using absolute path +        # Test that -symbol-list-lines works when file is specified using +        # absolute path          import os          path = os.path.join(os.getcwd(), "main.cpp")          self.runCmd("-symbol-list-lines \"%s\"" % path) -        self.expect("\^done,lines=\[\{pc=\"0x0*%x\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"\d+\"\})+\]" % (addr, line)) +        self.expect( +            "\^done,lines=\[\{pc=\"0x0*%x\",line=\"%d\"\}(,\{pc=\"0x[0-9a-f]+\",line=\"\d+\"\})+\]" % +            (addr, line))          # Test that -symbol-list-lines fails when file doesn't exist          self.runCmd("-symbol-list-lines unknown_dir/main.cpp") -        self.expect("\^error,message=\"error: No source filenames matched 'unknown_dir/main\.cpp'\. \"") +        self.expect( +            "\^error,message=\"error: No source filenames matched 'unknown_dir/main\.cpp'\. \"") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/syntax/TestMiSyntax.py b/packages/Python/lldbsuite/test/tools/lldb-mi/syntax/TestMiSyntax.py index a40e49f70e7e..02059080f305 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/syntax/TestMiSyntax.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/syntax/TestMiSyntax.py @@ -5,22 +5,23 @@ Test that the lldb-mi driver understands MI command syntax.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +from functools import reduce +  class MiSyntaxTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_tokens(self):          """Test that 'lldb-mi --interpreter' prints command tokens.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("000-file-exec-and-symbols %s" % self.myexe) @@ -38,8 +39,8 @@ class MiSyntaxTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("0000000000000000000003\^running")          self.expect("\*stopped,reason=\"exited-normally\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_specialchars(self):          """Test that 'lldb-mi --interpreter' handles complicated strings.""" @@ -48,10 +49,12 @@ class MiSyntaxTestCase(lldbmi_testcase.MiTestCaseBase):          os.symlink(self.myexe, complicated_myexe)          self.addTearDownHook(lambda: os.unlink(complicated_myexe)) -        self.spawnLldbMi(args = "\"%s\"" % complicated_myexe) +        self.spawnLldbMi(args="\"%s\"" % complicated_myexe)          # Test that the executable was loaded -        self.expect("-file-exec-and-symbols \"%s\"" % complicated_myexe, exactly = True) +        self.expect( +            "-file-exec-and-symbols \"%s\"" % +            complicated_myexe, exactly=True)          self.expect("\^done")          # Check that it was loaded correctly @@ -61,13 +64,15 @@ class MiSyntaxTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\^running")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @expectedFailureAll(oslist=["linux"], bugnumber="Failing in ~6/600 dosep runs (build 3120-3122)") +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll( +        oslist=["linux"], +        bugnumber="Failing in ~6/600 dosep runs (build 3120-3122)")      def test_lldbmi_process_output(self):          """Test that 'lldb-mi --interpreter' wraps process output correctly.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -80,3 +85,104 @@ class MiSyntaxTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that a process output is wrapped correctly          self.expect("\@\"'\\\\r\\\\n\"")          self.expect("\@\"` - it's \\\\\\\\n\\\\x12\\\\\"\\\\\\\\\\\\\"") + +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @expectedFailureAll(oslist=["macosx"], bugnumber="rdar://28805064") +    def test_lldbmi_output_grammar(self): +        """Test that 'lldb-mi --interpreter' uses standard output syntax.""" + +        self.spawnLldbMi(args=None) +        self.child.setecho(False) + +        # Run all commands simultaneously +        self.runCmd("-unknown-command") +        self.runCmd("-file-exec-and-symbols %s" % self.myexe) +        self.runCmd("-break-insert -f main") +        self.runCmd("-gdb-set target-async off") +        self.runCmd("-exec-run") +        self.runCmd("-gdb-set target-async on") +        self.runCmd("-exec-continue") +        self.runCmd("-gdb-exit") + +        # Test that the program's output matches to the following pattern: +        # ( async-record | stream-record )* [ result-record ] "(gdb)" nl +        async_record = "^[0-9]*(\*|\+|=).+?\n"  # 1 +        stream_record = "^(~|@|&).+?\n"         # 2 +        result_record = "^[0-9]*\^.+?\n"        # 3 +        prompt = "^\(gdb\)\r\n"                 # 4 +        command = "^\r\n"                       # 5 (it looks like empty line for pexpect) +        error = "^.+?\n"                        # 6 +        import pexpect                          # 7 (EOF) +        all_patterns = [ +            async_record, +            stream_record, +            result_record, +            prompt, +            command, +            error, +            pexpect.EOF] + +        # Routines to get a bit-mask for the specified list of patterns +        def get_bit(pattern): return all_patterns.index(pattern) +        def get_mask(pattern): return 1 << get_bit(pattern) +        def or_op(x, y): return x | y +        def get_state(*args): return reduce(or_op, map(get_mask, args)) + +        next_state = get_state(command) +        while True: +            it = self.expect(all_patterns) +            matched_pattern = all_patterns[it] + +            # Check that state is acceptable +            if not (next_state & get_mask(matched_pattern)): +                self.fail( +                    "error: inconsistent pattern '%s' for state %#x (matched string: %s)" % +                    (repr(matched_pattern), next_state, self.child.after)) +            elif matched_pattern == async_record or matched_pattern == stream_record: +                next_state = get_state( +                    async_record, +                    stream_record, +                    result_record, +                    prompt) +            elif matched_pattern == result_record: +                # FIXME lldb-mi prints async-records out of turn +                # ``` +                #   ^done +                #   (gdb) +                #   ^running +                #   =thread-group-started,id="i1",pid="13875" +                #   (gdb) +                # ``` +                # Therefore to pass that test I changed the grammar's rule: +                #   next_state = get_state(prompt) +                # to: +                next_state = get_state(async_record, prompt) +            elif matched_pattern == prompt: +                # FIXME lldb-mi prints the prompt out of turn +                # ``` +                #   ^done +                #   (gdb) +                #   ^running +                #   (gdb) +                #   (gdb) +                # ``` +                # Therefore to pass that test I changed the grammar's rule: +                #   next_state = get_state(async_record, stream_record, result_record, command, pexpect.EOF) +                # to: +                next_state = get_state( +                    async_record, +                    stream_record, +                    result_record, +                    prompt, +                    command, +                    pexpect.EOF) +            elif matched_pattern == command: +                next_state = get_state( +                    async_record, +                    stream_record, +                    result_record) +            elif matched_pattern == pexpect.EOF: +                break +            else: +                self.fail("error: pexpect returned an unknown state") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/target/TestMiTarget.py b/packages/Python/lldbsuite/test/tools/lldb-mi/target/TestMiTarget.py index 2d47db03637c..31a05ff402ed 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/target/TestMiTarget.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/target/TestMiTarget.py @@ -9,117 +9,121 @@ from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiTargetTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # cannot attach to process on linux +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfLinux  # cannot attach to process on linux      def test_lldbmi_target_attach_wait_for(self):          """Test that 'lldb-mi --interpreter' works for -target-attach -n <name> --waitfor.""" -            +          # Build target executable with unique name          exeName = self.testMethodName          d = {'EXE': exeName}          self.buildProgram("test_attach.cpp", exeName)          self.addTearDownCleanup(dictionary=d) -         -        self.spawnLldbMi(args = None) -         + +        self.spawnLldbMi(args=None) +          # Load executable -        # FIXME: -file-exec-and-sybmols is not required for target attach, but the test will not pass without this +        # FIXME: -file-exec-and-sybmols is not required for target attach, but +        # the test will not pass without this          self.runCmd("-file-exec-and-symbols %s" % exeName)          self.expect("\^done") -         +          # Set up attach          self.runCmd("-target-attach -n %s --waitfor" % exeName) -        time.sleep(4) # Give attach time to setup -               +        time.sleep(4)  # Give attach time to setup +          # Start target process -        self.spawnSubprocess(os.path.join(os.path.dirname(__file__), exeName)); +        self.spawnSubprocess(os.path.join(os.path.dirname(__file__), exeName))          self.addTearDownHook(self.cleanupSubprocesses)          self.expect("\^done") -         +          # Set breakpoint on printf          line = line_number('test_attach.cpp', '// BP_i++')          self.runCmd("-break-insert -f test_attach.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"1\"") -         +          # Continue to breakpoint          self.runCmd("-exec-continue")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Detach          self.runCmd("-target-detach")          self.expect("\^done") -         -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # cannot attach to process on linux + +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfLinux  # cannot attach to process on linux      def test_lldbmi_target_attach_name(self):          """Test that 'lldb-mi --interpreter' works for -target-attach -n <name>.""" -            +          # Build target executable with unique name          exeName = self.testMethodName          d = {'EXE': exeName}          self.buildProgram("test_attach.cpp", exeName)          self.addTearDownCleanup(dictionary=d) -         +          # Start target process -        targetProcess = self.spawnSubprocess(os.path.join(os.path.dirname(__file__), exeName)); +        targetProcess = self.spawnSubprocess( +            os.path.join(os.path.dirname(__file__), exeName))          self.addTearDownHook(self.cleanupSubprocesses) -         -        self.spawnLldbMi(args = None) -         + +        self.spawnLldbMi(args=None) +          # Set up atatch          self.runCmd("-target-attach -n %s" % exeName)          self.expect("\^done") -         +          # Set breakpoint on printf          line = line_number('test_attach.cpp', '// BP_i++')          self.runCmd("-break-insert -f test_attach.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"1\"") -         +          # Continue to breakpoint          self.runCmd("-exec-continue")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Detach          self.runCmd("-target-detach")          self.expect("\^done") -         -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # cannot attach to process on linux + +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfLinux  # cannot attach to process on linux      def test_lldbmi_target_attach_pid(self):          """Test that 'lldb-mi --interpreter' works for -target-attach <pid>.""" -            +          # Build target executable with unique name          exeName = self.testMethodName          d = {'EXE': exeName}          self.buildProgram("test_attach.cpp", exeName)          self.addTearDownCleanup(dictionary=d) -         +          # Start target process -        targetProcess = self.spawnSubprocess(os.path.join(os.path.dirname(__file__), exeName)); +        targetProcess = self.spawnSubprocess( +            os.path.join(os.path.dirname(__file__), exeName))          self.addTearDownHook(self.cleanupSubprocesses) -         -        self.spawnLldbMi(args = None) -         + +        self.spawnLldbMi(args=None) +          # Set up atatch          self.runCmd("-target-attach %d" % targetProcess.pid)          self.expect("\^done") -         +          # Set breakpoint on printf          line = line_number('test_attach.cpp', '// BP_i++')          self.runCmd("-break-insert -f test_attach.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"1\"") -         +          # Continue to breakpoint          self.runCmd("-exec-continue")          self.expect("\*stopped,reason=\"breakpoint-hit\"") -         +          # Detach          self.runCmd("-target-detach")          self.expect("\^done") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/threadinfo/TestMiThreadInfo.py b/packages/Python/lldbsuite/test/tools/lldb-mi/threadinfo/TestMiThreadInfo.py index 7226f2e8d320..729674e6e111 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/threadinfo/TestMiThreadInfo.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/threadinfo/TestMiThreadInfo.py @@ -9,16 +9,17 @@ from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiThreadInfoTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows # pthreads not supported on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # pthreads not supported on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_thread_info(self):          """Test that -thread-info prints thread info and the current-thread-id""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -33,7 +34,7 @@ class MiThreadInfoTestCase(lldbmi_testcase.MiTestCaseBase):          self.expect("\*stopped,reason=\"breakpoint-hit\"")          self.runCmd("-thread-info") -        self.expect("\^done,threads=\[\{id=\"1\",(.*)\},\{id=\"2\",(.*)\],current-thread-id=\"2\"") +        self.expect( +            "\^done,threads=\[\{id=\"1\",(.*)\},\{id=\"2\",(.*)\],current-thread-id=\"2\"")          self.runCmd("-gdb-quit") -    diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiGdbSetShowPrint.py b/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiGdbSetShowPrint.py index 5ce2b99bbdee..61d54cab055a 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiGdbSetShowPrint.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiGdbSetShowPrint.py @@ -1,4 +1,4 @@ -#coding=utf8 +# coding=utf8  """  Test lldb-mi -gdb-set and -gdb-show commands for 'print option-name'.  """ @@ -6,12 +6,12 @@ Test lldb-mi -gdb-set and -gdb-show commands for 'print option-name'.  from __future__ import print_function -  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__) @@ -19,28 +19,34 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):      # evaluates array when char-array-as-string is off      def eval_and_check_array(self, var, typ, length):          self.runCmd("-var-create - * %s" % var) -        self.expect('\^done,name="var\d+",numchild="%d",value="\[%d\]",type="%s \[%d\]",thread-id="1",has_more="0"' % (length, length, typ, length)) +        self.expect( +            '\^done,name="var\d+",numchild="%d",value="\[%d\]",type="%s \[%d\]",thread-id="1",has_more="0"' % +            (length, length, typ, length))      # evaluates any type which can be represented as string of characters      def eval_and_match_string(self, var, value, typ): -        value=value.replace("\\", "\\\\").replace("\"", "\\\"") +        value = value.replace("\\", "\\\\").replace("\"", "\\\"")          self.runCmd("-var-create - * " + var) -        self.expect('\^done,name="var\d+",numchild="[0-9]+",value="%s",type="%s",thread-id="1",has_more="0"' % (value, typ)) +        self.expect( +            '\^done,name="var\d+",numchild="[0-9]+",value="%s",type="%s",thread-id="1",has_more="0"' % +            (value, typ)) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi working on 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_show_print_char_array_as_string(self):          """Test that 'lldb-mi --interpreter' can print array of chars as string.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          # Run to BP_gdb_set_show_print_char_array_as_string_test -        line = line_number('main.cpp', '// BP_gdb_set_show_print_char_array_as_string_test') +        line = line_number( +            'main.cpp', +            '// BP_gdb_set_show_print_char_array_as_string_test')          self.runCmd("-break-insert main.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"1\"")          self.runCmd("-exec-run") @@ -51,23 +57,38 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-show print char-array-as-string")          self.expect("\^done,value=\"off\"") -        # Test that a char* is expanded to string when print char-array-as-string is "off" -        self.eval_and_match_string("cp", r'0x[0-9a-f]+ \"\\t\\\"hello\\\"\\n\"', r'const char \*') - -        # Test that a char[] isn't expanded to string when print char-array-as-string is "off" -        self.eval_and_check_array("ca", "const char", 10); - -        # Test that a char16_t* is expanded to string when print char-array-as-string is "off" -        self.eval_and_match_string("u16p", r'0x[0-9a-f]+ u\"\\t\\\"hello\\\"\\n\"', r'const char16_t \*') - -        # Test that a char16_t[] isn't expanded to string when print char-array-as-string is "off" -        self.eval_and_check_array("u16a", "const char16_t", 10); - -        # Test that a char32_t* is expanded to string when print char-array-as-string is "off" -        self.eval_and_match_string("u32p", r'0x[0-9a-f]+ U\"\\t\\\"hello\\\"\\n\"', r'const char32_t \*') - -        # Test that a char32_t[] isn't expanded to string when print char-array-as-string is "off" -        self.eval_and_check_array("u32a", "const char32_t", 10); +        # Test that a char* is expanded to string when print +        # char-array-as-string is "off" +        self.eval_and_match_string( +            "cp", +            r'0x[0-9a-f]+ \"\\t\\\"hello\\\"\\n\"', +            r'const char \*') + +        # Test that a char[] isn't expanded to string when print +        # char-array-as-string is "off" +        self.eval_and_check_array("ca", "const char", 10) + +        # Test that a char16_t* is expanded to string when print +        # char-array-as-string is "off" +        self.eval_and_match_string( +            "u16p", +            r'0x[0-9a-f]+ u\"\\t\\\"hello\\\"\\n\"', +            r'const char16_t \*') + +        # Test that a char16_t[] isn't expanded to string when print +        # char-array-as-string is "off" +        self.eval_and_check_array("u16a", "const char16_t", 10) + +        # Test that a char32_t* is expanded to string when print +        # char-array-as-string is "off" +        self.eval_and_match_string( +            "u32p", +            r'0x[0-9a-f]+ U\"\\t\\\"hello\\\"\\n\"', +            r'const char32_t \*') + +        # Test that a char32_t[] isn't expanded to string when print +        # char-array-as-string is "off" +        self.eval_and_check_array("u32a", "const char32_t", 10)          # Test that -gdb-set can set print char-array-as-string flag          self.runCmd("-gdb-set print char-array-as-string on") @@ -77,52 +98,94 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-show print char-array-as-string")          self.expect("\^done,value=\"on\"") -        # Test that a char* with escape chars is expanded to string when print char-array-as-string is "on" -        self.eval_and_match_string("cp", r'0x[0-9a-f]+ \"\\t\\\"hello\\\"\\n\"', r'const char \*') -         -        # Test that a char[] with escape chars is expanded to string when print char-array-as-string is "on" -        self.eval_and_match_string("ca", r'\"\\t\\\"hello\\\"\\n\"', r'const char \[10\]') -         -        # Test that a char16_t* with escape chars is expanded to string when print char-array-as-string is "on" -        self.eval_and_match_string("u16p", r'0x[0-9a-f]+ u\"\\t\\\"hello\\\"\\n\"', r'const char16_t \*') -         -        # Test that a char16_t[] with escape chars is expanded to string when print char-array-as-string is "on" -        self.eval_and_match_string("u16a", r'u\"\\t\\\"hello\\\"\\n\"', r'const char16_t \[10\]') -         -        # Test that a char32_t* with escape chars is expanded to string when print char-array-as-string is "on" -        self.eval_and_match_string("u32p", r'0x[0-9a-f]+ U\"\\t\\\"hello\\\"\\n\"', r'const char32_t \*') -         -        # Test that a char32_t[] with escape chars is expanded to string when print char-array-as-string is "on" -        self.eval_and_match_string("u32a", r'U\"\\t\\\"hello\\\"\\n\"', r'const char32_t \[10\]') +        # Test that a char* with escape chars is expanded to string when print +        # char-array-as-string is "on" +        self.eval_and_match_string( +            "cp", +            r'0x[0-9a-f]+ \"\\t\\\"hello\\\"\\n\"', +            r'const char \*') + +        # Test that a char[] with escape chars is expanded to string when print +        # char-array-as-string is "on" +        self.eval_and_match_string( +            "ca", +            r'\"\\t\\\"hello\\\"\\n\"', +            r'const char \[10\]') + +        # Test that a char16_t* with escape chars is expanded to string when +        # print char-array-as-string is "on" +        self.eval_and_match_string( +            "u16p", +            r'0x[0-9a-f]+ u\"\\t\\\"hello\\\"\\n\"', +            r'const char16_t \*') + +        # Test that a char16_t[] with escape chars is expanded to string when +        # print char-array-as-string is "on" +        self.eval_and_match_string( +            "u16a", +            r'u\"\\t\\\"hello\\\"\\n\"', +            r'const char16_t \[10\]') + +        # Test that a char32_t* with escape chars is expanded to string when +        # print char-array-as-string is "on" +        self.eval_and_match_string( +            "u32p", +            r'0x[0-9a-f]+ U\"\\t\\\"hello\\\"\\n\"', +            r'const char32_t \*') + +        # Test that a char32_t[] with escape chars is expanded to string when +        # print char-array-as-string is "on" +        self.eval_and_match_string( +            "u32a", +            r'U\"\\t\\\"hello\\\"\\n\"', +            r'const char32_t \[10\]')          # Test russian unicode strings -        self.eval_and_match_string("u16p_rus", r'0x[0-9a-f]+ u\"\\\\Аламо-сквер\"', r'const char16_t \*') -        self.eval_and_match_string("u16a_rus", r'u\"\\\\Бейвью\"', r'const char16_t \[8\]') -        self.eval_and_match_string("u32p_rus", r'0x[0-9a-f]+ U\"\\\\Чайнатаун\"', r'const char32_t \*') -        self.eval_and_match_string("u32a_rus", r'U\"\\\\Догпатч\"', r'const char32_t \[9\]') - -        # Test that -gdb-set print char-array-as-string fails if "on"/"off" isn't specified +        self.eval_and_match_string( +            "u16p_rus", +            r'0x[0-9a-f]+ u\"\\\\Аламо-сквер\"', +            r'const char16_t \*') +        self.eval_and_match_string( +            "u16a_rus", +            r'u\"\\\\Бейвью\"', +            r'const char16_t \[8\]') +        self.eval_and_match_string( +            "u32p_rus", +            r'0x[0-9a-f]+ U\"\\\\Чайнатаун\"', +            r'const char32_t \*') +        self.eval_and_match_string( +            "u32a_rus", +            r'U\"\\\\Догпатч\"', +            r'const char32_t \[9\]') + +        # Test that -gdb-set print char-array-as-string fails if "on"/"off" +        # isn't specified          self.runCmd("-gdb-set print char-array-as-string") -        self.expect("\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") +        self.expect( +            "\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") -        # Test that -gdb-set print char-array-as-string fails when option is unknown +        # Test that -gdb-set print char-array-as-string fails when option is +        # unknown          self.runCmd("-gdb-set print char-array-as-string unknown") -        self.expect("\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") +        self.expect( +            "\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi working on Windows +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi working on Windows      @expectedFailureAll(compiler="gcc", bugnumber="llvm.org/pr23357") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_gdb_set_show_print_expand_aggregates(self):          """Test that 'lldb-mi --interpreter' can expand aggregates everywhere.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          # Run to BP_gdb_set_show_print_expand_aggregates -        line = line_number('main.cpp', '// BP_gdb_set_show_print_expand_aggregates') +        line = line_number( +            'main.cpp', +            '// BP_gdb_set_show_print_expand_aggregates')          self.runCmd("-break-insert main.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"1\"")          self.runCmd("-exec-run") @@ -133,16 +196,21 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-show print expand-aggregates")          self.expect("\^done,value=\"off\"") -        # Test that composite type isn't expanded when print expand-aggregates is "off" +        # Test that composite type isn't expanded when print expand-aggregates +        # is "off"          self.runCmd("-var-create var1 * complx") -        self.expect("\^done,name=\"var1\",numchild=\"3\",value=\"{\.\.\.}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var1\",numchild=\"3\",value=\"{\.\.\.}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") -        # Test that composite type[] isn't expanded when print expand-aggregates is "off" +        # Test that composite type[] isn't expanded when print +        # expand-aggregates is "off"          self.eval_and_check_array("complx_array", "complex_type", 2) -        # Test that a struct with a char first element is not formatted as a string +        # Test that a struct with a char first element is not formatted as a +        # string          self.runCmd("-var-create - * &nstr") -        self.expect("\^done,name=\"var\d+\",numchild=\"2\",value=\"0x[0-9a-f]+\",type=\"not_str \*\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var\d+\",numchild=\"2\",value=\"0x[0-9a-f]+\",type=\"not_str \*\",thread-id=\"1\",has_more=\"0\"")          # Test that -gdb-set can set print expand-aggregates flag          self.runCmd("-gdb-set print expand-aggregates on") @@ -152,36 +220,46 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-show print expand-aggregates")          self.expect("\^done,value=\"on\"") -        # Test that composite type is expanded when print expand-aggregates is "on" +        # Test that composite type is expanded when print expand-aggregates is +        # "on"          self.runCmd("-var-create var3 * complx") -        self.expect("\^done,name=\"var3\",numchild=\"3\",value=\"{i = 3, inner = {l = 3}, complex_ptr = 0x[0-9a-f]+}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var3\",numchild=\"3\",value=\"{i = 3, inner = {l = 3}, complex_ptr = 0x[0-9a-f]+}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") -        # Test that composite type[] is expanded when print expand-aggregates is "on" +        # Test that composite type[] is expanded when print expand-aggregates +        # is "on"          self.runCmd("-var-create var4 * complx_array") -        self.expect("\^done,name=\"var4\",numchild=\"2\",value=\"{\[0\] = {i = 4, inner = {l = 4}, complex_ptr = 0x[0-9a-f]+}, \[1\] = {i = 5, inner = {l = 5}, complex_ptr = 0x[0-9a-f]+}}\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var4\",numchild=\"2\",value=\"{\[0\] = {i = 4, inner = {l = 4}, complex_ptr = 0x[0-9a-f]+}, \[1\] = {i = 5, inner = {l = 5}, complex_ptr = 0x[0-9a-f]+}}\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"") -        # Test that -gdb-set print expand-aggregates fails if "on"/"off" isn't specified +        # Test that -gdb-set print expand-aggregates fails if "on"/"off" isn't +        # specified          self.runCmd("-gdb-set print expand-aggregates") -        self.expect("\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") +        self.expect( +            "\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") -        # Test that -gdb-set print expand-aggregates fails when option is unknown +        # Test that -gdb-set print expand-aggregates fails when option is +        # unknown          self.runCmd("-gdb-set print expand-aggregates unknown") -        self.expect("\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") +        self.expect( +            "\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi working on Windows +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi working on Windows      @expectedFailureAll(compiler="gcc", bugnumber="llvm.org/pr23357") -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_gdb_set_show_print_aggregate_field_names(self):          """Test that 'lldb-mi --interpreter' can expand aggregates everywhere.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe)          self.expect("\^done")          # Run to BP_gdb_set_show_print_aggregate_field_names -        line = line_number('main.cpp', '// BP_gdb_set_show_print_aggregate_field_names') +        line = line_number( +            'main.cpp', +            '// BP_gdb_set_show_print_aggregate_field_names')          self.runCmd("-break-insert main.cpp:%d" % line)          self.expect("\^done,bkpt={number=\"1\"")          self.runCmd("-exec-run") @@ -196,13 +274,17 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-set print expand-aggregates on")          self.expect("\^done") -        # Test that composite type is expanded with field name when print aggregate-field-names is "on" +        # Test that composite type is expanded with field name when print +        # aggregate-field-names is "on"          self.runCmd("-var-create var1 * complx") -        self.expect("\^done,name=\"var1\",numchild=\"3\",value=\"{i = 3, inner = {l = 3}, complex_ptr = 0x[0-9a-f]+}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var1\",numchild=\"3\",value=\"{i = 3, inner = {l = 3}, complex_ptr = 0x[0-9a-f]+}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") -        # Test that composite type[] is expanded with field name when print aggregate-field-names is "on" +        # Test that composite type[] is expanded with field name when print +        # aggregate-field-names is "on"          self.runCmd("-var-create var2 * complx_array") -        self.expect("\^done,name=\"var2\",numchild=\"2\",value=\"{\[0\] = {i = 4, inner = {l = 4}, complex_ptr = 0x[0-9a-f]+}, \[1\] = {i = 5, inner = {l = 5}, complex_ptr = 0x[0-9a-f]+}}\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var2\",numchild=\"2\",value=\"{\[0\] = {i = 4, inner = {l = 4}, complex_ptr = 0x[0-9a-f]+}, \[1\] = {i = 5, inner = {l = 5}, complex_ptr = 0x[0-9a-f]+}}\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"")          # Test that -gdb-set can set print aggregate-field-names flag          self.runCmd("-gdb-set print aggregate-field-names off") @@ -212,18 +294,26 @@ class MiGdbSetShowTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-gdb-show print aggregate-field-names")          self.expect("\^done,value=\"off\"") -        # Test that composite type is expanded without field name when print aggregate-field-names is "off" +        # Test that composite type is expanded without field name when print +        # aggregate-field-names is "off"          self.runCmd("-var-create var3 * complx") -        self.expect("\^done,name=\"var3\",numchild=\"3\",value=\"{3,\{3\},0x[0-9a-f]+}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var3\",numchild=\"3\",value=\"{3,\{3\},0x[0-9a-f]+}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") -        # Test that composite type[] is expanded without field name when print aggregate-field-names is "off" +        # Test that composite type[] is expanded without field name when print +        # aggregate-field-names is "off"          self.runCmd("-var-create var4 * complx_array") -        self.expect("\^done,name=\"var4\",numchild=\"2\",value=\"{{4,\{4\},0x[0-9a-f]+},{5,\{5\},0x[0-9a-f]+}}\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var4\",numchild=\"2\",value=\"{{4,\{4\},0x[0-9a-f]+},{5,\{5\},0x[0-9a-f]+}}\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"") -        # Test that -gdb-set print aggregate-field-names fails if "on"/"off" isn't specified +        # Test that -gdb-set print aggregate-field-names fails if "on"/"off" +        # isn't specified          self.runCmd("-gdb-set print aggregate-field-names") -        self.expect("\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") +        self.expect( +            "\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") -        # Test that -gdb-set print aggregate-field-names fails when option is unknown +        # Test that -gdb-set print aggregate-field-names fails when option is +        # unknown          self.runCmd("-gdb-set print aggregate-field-names unknown") -        self.expect("\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") +        self.expect( +            "\^error,msg=\"The request ''print' expects option-name and \"on\" or \"off\"' failed.\"") diff --git a/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiVar.py b/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiVar.py index 51f02b9e4a74..b76b59ab97e3 100644 --- a/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiVar.py +++ b/packages/Python/lldbsuite/test/tools/lldb-mi/variable/TestMiVar.py @@ -5,22 +5,22 @@ Test lldb-mi -var-xxx commands.  from __future__ import print_function -  import lldbmi_testcase  from lldbsuite.test.decorators import *  from lldbsuite.test.lldbtest import *  from lldbsuite.test import lldbutil +  class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):      mydir = TestBase.compute_mydir(__file__) -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_eval(self):          """Test that 'lldb-mi --interpreter' works for evaluating.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -36,15 +36,18 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Print non-existant variable          self.runCmd("-var-create var1 * undef") -        self.expect("\^error,msg=\"error: use of undeclared identifier \'undef\'\\\\n\"") +        self.expect( +            "\^error,msg=\"error: use of undeclared identifier \'undef\'\\\\n\"")          self.runCmd("-data-evaluate-expression undef") -        self.expect("\^error,msg=\"error: use of undeclared identifier \'undef\'\\\\n\"") +        self.expect( +            "\^error,msg=\"error: use of undeclared identifier \'undef\'\\\\n\"")          # Print global "g_MyVar", modify, delete and create again          self.runCmd("-data-evaluate-expression g_MyVar")          self.expect("\^done,value=\"3\"")          self.runCmd("-var-create var2 * g_MyVar") -        self.expect("\^done,name=\"var2\",numchild=\"0\",value=\"3\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var2\",numchild=\"0\",value=\"3\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-evaluate-expression var2")          self.expect("\^done,value=\"3\"")          self.runCmd("-var-show-attributes var2") @@ -57,17 +60,20 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-data-evaluate-expression \"g_MyVar=30\"")          self.expect("\^done,value=\"30\"")          self.runCmd("-var-update --all-values var2") -        #self.expect("\^done,changelist=\[\{name=\"var2\",value=\"30\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") #FIXME -var-update doesn't work +        # self.expect("\^done,changelist=\[\{name=\"var2\",value=\"30\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") +        # FIXME -var-update doesn't work          self.runCmd("-var-delete var2")          self.expect("\^done")          self.runCmd("-var-create var2 * g_MyVar") -        self.expect("\^done,name=\"var2\",numchild=\"0\",value=\"30\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var2\",numchild=\"0\",value=\"30\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          # Print static "s_MyVar", modify, delete and create again          self.runCmd("-data-evaluate-expression s_MyVar")          self.expect("\^done,value=\"30\"")          self.runCmd("-var-create var3 * s_MyVar") -        self.expect("\^done,name=\"var3\",numchild=\"0\",value=\"30\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var3\",numchild=\"0\",value=\"30\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-evaluate-expression var3")          self.expect("\^done,value=\"30\"")          self.runCmd("-var-show-attributes var3") @@ -77,17 +83,20 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-data-evaluate-expression \"s_MyVar=3\"")          self.expect("\^done,value=\"3\"")          self.runCmd("-var-update --all-values var3") -        #self.expect("\^done,changelist=\[\{name=\"var3\",value=\"3\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") #FIXME -var-update doesn't work +        # self.expect("\^done,changelist=\[\{name=\"var3\",value=\"3\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") +        # FIXME -var-update doesn't work          self.runCmd("-var-delete var3")          self.expect("\^done")          self.runCmd("-var-create var3 * s_MyVar") -        self.expect("\^done,name=\"var3\",numchild=\"0\",value=\"3\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var3\",numchild=\"0\",value=\"3\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          # Print local "b", modify, delete and create again          self.runCmd("-data-evaluate-expression b")          self.expect("\^done,value=\"20\"")          self.runCmd("-var-create var4 * b") -        self.expect("\^done,name=\"var4\",numchild=\"0\",value=\"20\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var4\",numchild=\"0\",value=\"20\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-evaluate-expression var4")          self.expect("\^done,value=\"20\"")          self.runCmd("-var-show-attributes var4") @@ -97,44 +106,62 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-data-evaluate-expression \"b=2\"")          self.expect("\^done,value=\"2\"")          self.runCmd("-var-update --all-values var4") -        #self.expect("\^done,changelist=\[\{name=\"var4\",value=\"2\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") #FIXME -var-update doesn't work +        # self.expect("\^done,changelist=\[\{name=\"var4\",value=\"2\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") +        # FIXME -var-update doesn't work          self.runCmd("-var-delete var4")          self.expect("\^done")          self.runCmd("-var-create var4 * b") -        self.expect("\^done,name=\"var4\",numchild=\"0\",value=\"2\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var4\",numchild=\"0\",value=\"2\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          # Print temp "a + b"          self.runCmd("-data-evaluate-expression \"a + b\"")          self.expect("\^done,value=\"12\"")          self.runCmd("-var-create var5 * \"a + b\"") -        self.expect("\^done,name=\"var5\",numchild=\"0\",value=\"12\",type=\"int\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var5\",numchild=\"0\",value=\"12\",type=\"int\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-evaluate-expression var5")          self.expect("\^done,value=\"12\"")          self.runCmd("-var-show-attributes var5") -        self.expect("\^done,status=\"editable\"") #FIXME editable or not? +        self.expect("\^done,status=\"editable\"")  # FIXME editable or not?          self.runCmd("-var-list-children var5")          self.expect("\^done,numchild=\"0\",has_more=\"0\"")          # Print argument "argv[0]"          self.runCmd("-data-evaluate-expression \"argv[0]\"") -        self.expect("\^done,value=\"0x[0-9a-f]+ \\\\\\\".*?%s\\\\\\\"\"" % self.myexe) +        self.expect( +            "\^done,value=\"0x[0-9a-f]+ \\\\\\\".*?%s\\\\\\\"\"" % +            self.myexe)          self.runCmd("-var-create var6 * \"argv[0]\"") -        self.expect("\^done,name=\"var6\",numchild=\"1\",value=\"0x[0-9a-f]+ \\\\\\\".*?%s\\\\\\\"\",type=\"const char \*\",thread-id=\"1\",has_more=\"0\"" % self.myexe) +        self.expect( +            "\^done,name=\"var6\",numchild=\"1\",value=\"0x[0-9a-f]+ \\\\\\\".*?%s\\\\\\\"\",type=\"const char \*\",thread-id=\"1\",has_more=\"0\"" % +            self.myexe)          self.runCmd("-var-evaluate-expression var6") -        self.expect("\^done,value=\"0x[0-9a-f]+ \\\\\\\".*?%s\\\\\\\"\"" % self.myexe) +        self.expect( +            "\^done,value=\"0x[0-9a-f]+ \\\\\\\".*?%s\\\\\\\"\"" % +            self.myexe)          self.runCmd("-var-show-attributes var6")          self.expect("\^done,status=\"editable\"")          self.runCmd("-var-list-children --all-values var6")          # FIXME: The name below is not correct. It should be "var.*argv[0]". -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var6\.\*\$[0-9]+\",exp=\"\*\$[0-9]+\",numchild=\"0\",type=\"const char\",thread-id=\"4294967295\",value=\"47 '/'\",has_more=\"0\"\}\],has_more=\"0\"") #FIXME -var-list-children shows invalid thread-id +        # FIXME -var-list-children shows invalid thread-id +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var6\.\*\$[0-9]+\",exp=\"\*\$[0-9]+\",numchild=\"0\",type=\"const char\",thread-id=\"4294967295\",value=\"47 '/'\",has_more=\"0\"\}\],has_more=\"0\"") + +        # Print an expression with spaces and optional arguments +        self.runCmd("-data-evaluate-expression \"a + b\"") +        self.expect("\^done,value=\"12\"") +        self.runCmd("-var-create var7 * \"a + b\" --thread 1 --frame 0") +        self.expect( +            "\^done,name=\"var7\",numchild=\"0\",value=\"12\",type=\"int\",thread-id=\"1\",has_more=\"0\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_var_update(self):          """Test that 'lldb-mi --interpreter' works for -var-update.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -150,11 +177,14 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Setup variables          self.runCmd("-var-create var_l * l") -        self.expect("\^done,name=\"var_l\",numchild=\"0\",value=\"1\",type=\"long\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var_l\",numchild=\"0\",value=\"1\",type=\"long\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-create var_complx * complx") -        self.expect("\^done,name=\"var_complx\",numchild=\"3\",value=\"\{\.\.\.\}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var_complx\",numchild=\"3\",value=\"\{\.\.\.\}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-create var_complx_array * complx_array") -        self.expect("\^done,name=\"var_complx_array\",numchild=\"2\",value=\"\[2\]\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var_complx_array\",numchild=\"2\",value=\"\[2\]\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"")          # Go to BP_var_update_test_l          line = line_number('main.cpp', '// BP_var_update_test_l') @@ -166,7 +196,8 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that var_l was updated          self.runCmd("-var-update --all-values var_l") -        self.expect("\^done,changelist=\[\{name=\"var_l\",value=\"0\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") +        self.expect( +            "\^done,changelist=\[\{name=\"var_l\",value=\"0\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]")          # Go to BP_var_update_test_complx          line = line_number('main.cpp', '// BP_var_update_test_complx') @@ -178,7 +209,8 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that var_complx was updated          self.runCmd("-var-update --all-values var_complx") -        self.expect("\^done,changelist=\[\{name=\"var_complx\",value=\"\{\.\.\.\}\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") +        self.expect( +            "\^done,changelist=\[\{name=\"var_complx\",value=\"\{\.\.\.\}\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]")          # Go to BP_var_update_test_complx_array          line = line_number('main.cpp', '// BP_var_update_test_complx_array') @@ -190,14 +222,15 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that var_complex_array was updated          self.runCmd("-var-update --all-values var_complx_array") -        self.expect("\^done,changelist=\[\{name=\"var_complx_array\",value=\"\[2\]\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") +        self.expect( +            "\^done,changelist=\[\{name=\"var_complx_array\",value=\"\[2\]\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\]") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on Windows +    @skipIfFreeBSD  # llvm.org/pr22411: Failure presumably due to known thread races      def test_lldbmi_var_create_register(self):          """Test that 'lldb-mi --interpreter' works for -var-create $regname.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -218,26 +251,29 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Create variable for register 0          # Note that message is different in Darwin and Linux:          # Darwin: "^done,name=\"var_reg\",numchild=\"0\",value=\"0x[0-9a-f]+\",type=\"unsigned long\",thread-id=\"1\",has_more=\"0\" -        # Linux:  "^done,name=\"var_reg\",numchild=\"0\",value=\"0x[0-9a-f]+\",type=\"unsigned int\",thread-id=\"1\",has_more=\"0\" +        # Linux: +        # "^done,name=\"var_reg\",numchild=\"0\",value=\"0x[0-9a-f]+\",type=\"unsigned +        # int\",thread-id=\"1\",has_more=\"0\"          self.runCmd("-var-create var_reg * $%s" % register_name) -        self.expect("\^done,name=\"var_reg\",numchild=\"0\",value=\"0x[0-9a-f]+\",type=\"unsigned (long|int)\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var_reg\",numchild=\"0\",value=\"0x[0-9a-f]+\",type=\"unsigned (long|int)\",thread-id=\"1\",has_more=\"0\"")          # Assign value to variable          self.runCmd("-var-assign var_reg \"6\"") -        #FIXME: the output has different format for 32bit and 64bit values +        # FIXME: the output has different format for 32bit and 64bit values          self.expect("\^done,value=\"0x0*?6\"")          # Assert register 0 updated          self.runCmd("-data-list-register-values d 0")          self.expect("\^done,register-values=\[{number=\"0\",value=\"6\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi tests working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi tests working on 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_var_list_children(self):          """Test that 'lldb-mi --interpreter' works for -var-list-children.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -253,13 +289,17 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Create variable          self.runCmd("-var-create var_complx * complx") -        self.expect("\^done,name=\"var_complx\",numchild=\"3\",value=\"\{\.\.\.\}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var_complx\",numchild=\"3\",value=\"\{\.\.\.\}\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-create var_complx_array * complx_array") -        self.expect("\^done,name=\"var_complx_array\",numchild=\"2\",value=\"\[2\]\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var_complx_array\",numchild=\"2\",value=\"\[2\]\",type=\"complex_type \[2\]\",thread-id=\"1\",has_more=\"0\"")          self.runCmd("-var-create var_pcomplx * pcomplx") -        self.expect("\^done,name=\"var_pcomplx\",numchild=\"2\",value=\"\{\.\.\.\}\",type=\"pcomplex_type\",thread-id=\"1\",has_more=\"0\"") +        self.expect( +            "\^done,name=\"var_pcomplx\",numchild=\"2\",value=\"\{\.\.\.\}\",type=\"pcomplex_type\",thread-id=\"1\",has_more=\"0\"") -        # Test that -var-evaluate-expression can evaluate the children of created varobj +        # Test that -var-evaluate-expression can evaluate the children of +        # created varobj          self.runCmd("-var-list-children var_complx")          self.runCmd("-var-evaluate-expression var_complx.i")          self.expect("\^done,value=\"3\"") @@ -282,37 +322,50 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that -var-list-children lists all children with their values          # (and that from and to are optional)          self.runCmd("-var-list-children --all-values var_complx") -        self.expect("\^done,numchild=\"3\",children=\[child=\{name=\"var_complx\.i\",exp=\"i\",numchild=\"0\",type=\"int\",thread-id=\"1\",value=\"3\",has_more=\"0\"\},child=\{name=\"var_complx\.inner\",exp=\"inner\",numchild=\"1\",type=\"complex_type::\(anonymous struct\)\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\},child=\{name=\"var_complx\.complex_ptr\",exp=\"complex_ptr\",numchild=\"3\",type=\"complex_type \*\",thread-id=\"1\",value=\"0x[0-9a-f]+\",has_more=\"0\"\}\],has_more=\"0\"") +        self.expect( +            "\^done,numchild=\"3\",children=\[child=\{name=\"var_complx\.i\",exp=\"i\",numchild=\"0\",type=\"int\",thread-id=\"1\",value=\"3\",has_more=\"0\"\},child=\{name=\"var_complx\.inner\",exp=\"inner\",numchild=\"1\",type=\"complex_type::\(anonymous struct\)\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\},child=\{name=\"var_complx\.complex_ptr\",exp=\"complex_ptr\",numchild=\"3\",type=\"complex_type \*\",thread-id=\"1\",value=\"0x[0-9a-f]+\",has_more=\"0\"\}\],has_more=\"0\"")          self.runCmd("-var-list-children --simple-values var_complx_array") -        self.expect("\^done,numchild=\"2\",children=\[child=\{name=\"var_complx_array\.\[0\]\",exp=\"\[0\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\},child=\{name=\"var_complx_array\.\[1\]\",exp=\"\[1\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"") +        self.expect( +            "\^done,numchild=\"2\",children=\[child=\{name=\"var_complx_array\.\[0\]\",exp=\"\[0\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\},child=\{name=\"var_complx_array\.\[1\]\",exp=\"\[1\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"")          self.runCmd("-var-list-children 0 var_pcomplx") -        self.expect("\^done,numchild=\"2\",children=\[child=\{name=\"var_pcomplx\.complex_type\",exp=\"complex_type\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\},child={name=\"var_pcomplx\.complx\",exp=\"complx\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"") +        self.expect( +            "\^done,numchild=\"2\",children=\[child=\{name=\"var_pcomplx\.complex_type\",exp=\"complex_type\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\},child={name=\"var_pcomplx\.complx\",exp=\"complx\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"")          # Test that -var-list-children lists children without values          self.runCmd("-var-list-children 0 var_complx 0 1") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.i\",exp=\"i\",numchild=\"0\",type=\"int\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.i\",exp=\"i\",numchild=\"0\",type=\"int\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"")          self.runCmd("-var-list-children --no-values var_complx 0 1") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.i\",exp=\"i\",numchild=\"0\",type=\"int\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.i\",exp=\"i\",numchild=\"0\",type=\"int\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"")          self.runCmd("-var-list-children --no-values var_complx_array 0 1") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx_array\.\[0\]\",exp=\"\[0\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx_array\.\[0\]\",exp=\"\[0\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"")          self.runCmd("-var-list-children --no-values var_pcomplx 0 1") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_pcomplx\.complex_type\",exp=\"complex_type\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_pcomplx\.complex_type\",exp=\"complex_type\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"1\"")          # Test that -var-list-children lists children with all values          self.runCmd("-var-list-children 1 var_complx 1 2") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.inner\",exp=\"inner\",numchild=\"1\",type=\"complex_type::\(anonymous struct\)\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"1\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.inner\",exp=\"inner\",numchild=\"1\",type=\"complex_type::\(anonymous struct\)\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"1\"")          self.runCmd("-var-list-children --all-values var_complx 1 2") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.inner\",exp=\"inner\",numchild=\"1\",type=\"complex_type::\(anonymous struct\)\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"1\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.inner\",exp=\"inner\",numchild=\"1\",type=\"complex_type::\(anonymous struct\)\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"1\"")          self.runCmd("-var-list-children --all-values var_complx_array 1 2") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx_array\.\[1\]\",exp=\"\[1\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"0\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx_array\.\[1\]\",exp=\"\[1\]\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"0\"")          self.runCmd("-var-list-children --all-values var_pcomplx 1 2") -        self.expect("\^done,numchild=\"1\",children=\[child={name=\"var_pcomplx\.complx\",exp=\"complx\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"0\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child={name=\"var_pcomplx\.complx\",exp=\"complx\",numchild=\"3\",type=\"complex_type\",thread-id=\"1\",value=\"\{\.\.\.\}\",has_more=\"0\"\}\],has_more=\"0\"")          # Test that -var-list-children lists children with simple values          self.runCmd("-var-list-children 2 var_complx 2 4") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.complex_ptr\",exp=\"complex_ptr\",numchild=\"3\",type=\"complex_type \*\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.complex_ptr\",exp=\"complex_ptr\",numchild=\"3\",type=\"complex_type \*\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"")          self.runCmd("-var-list-children --simple-values var_complx 2 4") -        self.expect("\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.complex_ptr\",exp=\"complex_ptr\",numchild=\"3\",type=\"complex_type \*\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"") +        self.expect( +            "\^done,numchild=\"1\",children=\[child=\{name=\"var_complx\.complex_ptr\",exp=\"complex_ptr\",numchild=\"3\",type=\"complex_type \*\",thread-id=\"1\",has_more=\"0\"\}\],has_more=\"0\"")          self.runCmd("-var-list-children --simple-values var_complx_array 2 4")          self.expect("\^done,numchild=\"0\",has_more=\"0\"")          self.runCmd("-var-list-children --simple-values var_pcomplx 2 4") @@ -330,15 +383,16 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Test that a missing low-frame or high-frame is handled          self.runCmd("-var-list-children 0 var_complx 0") -        self.expect("\^error,msg=\"Command 'var-list-children'. Variable children range invalid\"") +        self.expect( +            "\^error,msg=\"Command 'var-list-children'. Variable children range invalid\"") -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi working on 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_var_create_for_stl_types(self):          """Test that 'lldb-mi --interpreter' print summary for STL types.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -354,15 +408,16 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Test for std::string          self.runCmd("-var-create - * std_string") -        self.expect('\^done,name="var\d+",numchild="[0-9]+",value="\\\\"hello\\\\"",type="std::[\S]*?string",thread-id="1",has_more="0"') -  -    @skipIfWindows #llvm.org/pr24452: Get lldb-mi working on Windows -    @skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races -    @skipIfLinux # llvm.org/pr22841: lldb-mi tests fail on all Linux buildbots +        self.expect( +            '\^done,name="var\d+",numchild="[0-9]+",value="\\\\"hello\\\\"",type="std::[\S]*?string",thread-id="1",has_more="0"') + +    @skipIfWindows  # llvm.org/pr24452: Get lldb-mi working on 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_var_create_for_unnamed_objects(self):          """Test that 'lldb-mi --interpreter' can expand unnamed structures and unions.""" -        self.spawnLldbMi(args = None) +        self.spawnLldbMi(args=None)          # Load executable          self.runCmd("-file-exec-and-symbols %s" % self.myexe) @@ -378,15 +433,16 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          # Evaluate struct_with_unions type and its children          self.runCmd("-var-create v0 * swu") -        self.expect('\^done,name="v0",numchild="2",value="\{\.\.\.\}",type="struct_with_unions",thread-id="1",has_more="0"') -        +        self.expect( +            '\^done,name="v0",numchild="2",value="\{\.\.\.\}",type="struct_with_unions",thread-id="1",has_more="0"') +          self.runCmd("-var-list-children v0") -         +          # inspect the first unnamed union          self.runCmd("-var-list-children v0.$0")          self.runCmd("-var-evaluate-expression v0.$0.u_i")          self.expect('\^done,value="1"') -         +          # inspect the second unnamed union          self.runCmd("-var-list-children v0.$1")          self.runCmd("-var-evaluate-expression v0.$1.u1") @@ -395,4 +451,3 @@ class MiVarTestCase(lldbmi_testcase.MiTestCaseBase):          self.runCmd("-var-list-children v0.$1.$1")          self.runCmd("-var-evaluate-expression v0.$1.$1.s1")          self.expect('\^done,value="-1"') - | 
