mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-24 05:55:43 -04:00
466 lines
24 KiB
Python
466 lines
24 KiB
Python
"""
|
|
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
|
|
@skipIfRemote # We do not currently support remote debugging via the MI.
|
|
@skipIfDarwin
|
|
def test_lldbmi_eval(self):
|
|
"""Test that 'lldb-mi --interpreter' works for evaluating."""
|
|
|
|
self.spawnLldbMi(args=None)
|
|
|
|
# Load executable
|
|
self.runCmd("-file-exec-and-symbols %s" % self.myexe)
|
|
self.expect("\^done")
|
|
|
|
# Run to program return
|
|
line = line_number('main.cpp', '// BP_return')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"1\"")
|
|
self.runCmd("-exec-run")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# Print non-existant variable
|
|
self.runCmd("-var-create var1 * undef")
|
|
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\"")
|
|
|
|
# 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.runCmd("-var-evaluate-expression var2")
|
|
self.expect("\^done,value=\"3\"")
|
|
self.runCmd("-var-show-attributes var2")
|
|
self.expect("\^done,status=\"editable\"")
|
|
self.runCmd("-var-list-children var2")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"0\"")
|
|
# Ensure -var-list-children also works with quotes
|
|
self.runCmd("-var-list-children \"var2\"")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"0\"")
|
|
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.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\"")
|
|
|
|
# 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.runCmd("-var-evaluate-expression var3")
|
|
self.expect("\^done,value=\"30\"")
|
|
self.runCmd("-var-show-attributes var3")
|
|
self.expect("\^done,status=\"editable\"")
|
|
self.runCmd("-var-list-children var3")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"0\"")
|
|
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.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\"")
|
|
|
|
# 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.runCmd("-var-evaluate-expression var4")
|
|
self.expect("\^done,value=\"20\"")
|
|
self.runCmd("-var-show-attributes var4")
|
|
self.expect("\^done,status=\"editable\"")
|
|
self.runCmd("-var-list-children var4")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"0\"")
|
|
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.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\"")
|
|
|
|
# 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.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.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.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.runCmd("-var-evaluate-expression var6")
|
|
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]".
|
|
# 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
|
|
@skipIfDarwin
|
|
@skipIfRemote # We do not currently support remote debugging via the MI.
|
|
def test_lldbmi_var_update(self):
|
|
"""Test that 'lldb-mi --interpreter' works for -var-update."""
|
|
|
|
self.spawnLldbMi(args=None)
|
|
|
|
# Load executable
|
|
self.runCmd("-file-exec-and-symbols %s" % self.myexe)
|
|
self.expect("\^done")
|
|
|
|
# Run to BP_var_update_test_init
|
|
line = line_number('main.cpp', '// BP_var_update_test_init')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"1\"")
|
|
self.runCmd("-exec-run")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# 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.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.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\"")
|
|
|
|
# Go to BP_var_update_test_l
|
|
line = line_number('main.cpp', '// BP_var_update_test_l')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"2\"")
|
|
self.runCmd("-exec-continue")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# 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\"\}\]")
|
|
|
|
# Go to BP_var_update_test_complx
|
|
line = line_number('main.cpp', '// BP_var_update_test_complx')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"3\"")
|
|
self.runCmd("-exec-continue")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# 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\"\}\]")
|
|
|
|
# Go to BP_var_update_test_complx_array
|
|
line = line_number('main.cpp', '// BP_var_update_test_complx_array')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"4\"")
|
|
self.runCmd("-exec-continue")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# 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\"\}\]")
|
|
|
|
@skipIfWindows # llvm.org/pr24452: Get lldb-mi tests working on Windows
|
|
@skipIfFreeBSD # llvm.org/pr22411: Failure presumably due to known thread races
|
|
@skipIfRemote # We do not currently support remote debugging via the MI.
|
|
@skipIfDarwin
|
|
def test_lldbmi_var_create_register(self):
|
|
"""Test that 'lldb-mi --interpreter' works for -var-create $regname."""
|
|
|
|
self.spawnLldbMi(args=None)
|
|
|
|
# Load executable
|
|
self.runCmd("-file-exec-and-symbols %s" % self.myexe)
|
|
self.expect("\^done")
|
|
|
|
# Run to main
|
|
self.runCmd("-break-insert -f main")
|
|
self.expect("\^done,bkpt={number=\"1\"")
|
|
self.runCmd("-exec-run")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# Find name of register 0
|
|
self.runCmd("-data-list-register-names 0")
|
|
self.expect("\^done,register-names=\[\".+?\"\]")
|
|
register_name = self.child.after.split("\"")[1]
|
|
|
|
# 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\"
|
|
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\"")
|
|
|
|
# Assign value to variable
|
|
self.runCmd("-var-assign var_reg \"6\"")
|
|
# 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
|
|
@skipIfRemote # We do not currently support remote debugging via the MI.
|
|
@skipIfDarwin
|
|
def test_lldbmi_var_list_children(self):
|
|
"""Test that 'lldb-mi --interpreter' works for -var-list-children."""
|
|
|
|
self.spawnLldbMi(args=None)
|
|
|
|
# Load executable
|
|
self.runCmd("-file-exec-and-symbols %s" % self.myexe)
|
|
self.expect("\^done")
|
|
|
|
# Run to BP_var_list_children_test
|
|
line = line_number('main.cpp', '// BP_var_list_children_test')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"1\"")
|
|
self.runCmd("-exec-run")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# 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.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.runCmd("-var-create var_pcomplx * pcomplx")
|
|
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
|
|
self.runCmd("-var-list-children var_complx")
|
|
self.runCmd("-var-evaluate-expression var_complx.i")
|
|
self.expect("\^done,value=\"3\"")
|
|
self.runCmd("-var-list-children var_complx_array")
|
|
self.runCmd("-var-evaluate-expression var_complx_array.[0]")
|
|
self.expect("\^done,value=\"\{...\}\"")
|
|
self.runCmd("-var-list-children var_pcomplx")
|
|
self.runCmd("-var-evaluate-expression var_pcomplx.complex_type")
|
|
self.expect("\^done,value=\"\{...\}\"")
|
|
|
|
# Test that -var-list-children lists empty children if range is empty
|
|
# (and that print-values is optional)
|
|
self.runCmd("-var-list-children var_complx 0 0")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"1\"")
|
|
self.runCmd("-var-list-children var_complx 99 0")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"1\"")
|
|
self.runCmd("-var-list-children var_complx 99 3")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"0\"")
|
|
|
|
# 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.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.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\"")
|
|
|
|
# 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.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.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.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\"")
|
|
|
|
# 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.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.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.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\"")
|
|
|
|
# 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.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.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")
|
|
self.expect("\^done,numchild=\"0\",has_more=\"0\"")
|
|
|
|
# Test that an invalid from is handled
|
|
# FIXME: -1 is treated as unsigned int
|
|
self.runCmd("-var-list-children 0 var_complx -1 0")
|
|
#self.expect("\^error,msg=\"Command 'var-list-children'\. Variable children range invalid\"")
|
|
|
|
# Test that an invalid to is handled
|
|
# FIXME: -1 is treated as unsigned int
|
|
self.runCmd("-var-list-children 0 var_complx 0 -1")
|
|
#self.expect("\^error,msg=\"Command 'var-list-children'\. Variable children range invalid\"")
|
|
|
|
# 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\"")
|
|
|
|
@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
|
|
@skipIfRemote # We do not currently support remote debugging via the MI.
|
|
@skipIfDarwin
|
|
def test_lldbmi_var_create_for_stl_types(self):
|
|
"""Test that 'lldb-mi --interpreter' print summary for STL types."""
|
|
|
|
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_cpp_stl_types_test')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"1\"")
|
|
self.runCmd("-exec-run")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# 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
|
|
@skipIfRemote # We do not currently support remote debugging via the MI.
|
|
@skipIfDarwin
|
|
def test_lldbmi_var_create_for_unnamed_objects(self):
|
|
"""Test that 'lldb-mi --interpreter' can expand unnamed structures and unions."""
|
|
|
|
self.spawnLldbMi(args=None)
|
|
|
|
# Load executable
|
|
self.runCmd("-file-exec-and-symbols %s" % self.myexe)
|
|
self.expect("\^done")
|
|
|
|
# Run to breakpoint
|
|
line = line_number('main.cpp', '// BP_unnamed_objects_test')
|
|
self.runCmd("-break-insert main.cpp:%d" % line)
|
|
self.expect("\^done,bkpt={number=\"1\"")
|
|
self.runCmd("-exec-run")
|
|
self.expect("\^running")
|
|
self.expect("\*stopped,reason=\"breakpoint-hit\"")
|
|
|
|
# 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.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")
|
|
self.expect('\^done,value="-1"')
|
|
# inspect unnamed structure
|
|
self.runCmd("-var-list-children v0.$1.$1")
|
|
self.runCmd("-var-evaluate-expression v0.$1.$1.s1")
|
|
self.expect('\^done,value="-1"')
|