Add a test for expression parser crash which has been fixed.
llvm-svn: 118590
This commit is contained in:
parent
91bfeb10b5
commit
22c3f3028d
|
|
@ -0,0 +1,5 @@
|
|||
LEVEL = ../../make
|
||||
|
||||
C_SOURCES := main.c
|
||||
|
||||
include $(LEVEL)/Makefile.rules
|
||||
|
|
@ -0,0 +1,43 @@
|
|||
"""
|
||||
Test the robustness of lldb expression parser.
|
||||
"""
|
||||
|
||||
import os, time
|
||||
import unittest2
|
||||
import lldb
|
||||
from lldbtest import *
|
||||
|
||||
class Radar8638051TestCase(TestBase):
|
||||
|
||||
mydir = os.path.join("expression_command", "radar_8638051")
|
||||
|
||||
def test_expr_commands(self):
|
||||
"""The following expression commands should not crash."""
|
||||
self.buildDefault()
|
||||
|
||||
self.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
|
||||
|
||||
self.runCmd("breakpoint set -n c")
|
||||
|
||||
self.runCmd("run", RUN_SUCCEEDED)
|
||||
|
||||
self.expect("expression val",
|
||||
startstr = "(int) $0 = 1")
|
||||
# (int) $0 = 1
|
||||
|
||||
self.expect("expression *(&val)",
|
||||
startstr = "(int) $1 = 1")
|
||||
# (int) $1 = 1
|
||||
|
||||
# rdar://problem/8638051
|
||||
# lldb expression command: Could this crash be avoided
|
||||
self.expect("expression &val",
|
||||
startstr = "(int *) $2 = ")
|
||||
# (int *) $2 = 0x....
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
import atexit
|
||||
lldb.SBDebugger.Initialize()
|
||||
atexit.register(lambda: lldb.SBDebugger.Terminate())
|
||||
unittest2.main()
|
||||
|
|
@ -0,0 +1,54 @@
|
|||
//===-- main.c --------------------------------------------------*- C++ -*-===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
#include <stdio.h>
|
||||
|
||||
// This simple program is to demonstrate the capability of the lldb command
|
||||
// "breakpoint command add" to add a set of commands to a breakpoint to be
|
||||
// executed when the breakpoint is hit.
|
||||
//
|
||||
// In particular, we want to break within c(), but only if the immediate caller
|
||||
// is a().
|
||||
|
||||
int a(int);
|
||||
int b(int);
|
||||
int c(int);
|
||||
|
||||
int a(int val)
|
||||
{
|
||||
if (val <= 1)
|
||||
return b(val);
|
||||
else if (val >= 3)
|
||||
return c(val); // Find the line number where c's parent frame is a here.
|
||||
|
||||
return val;
|
||||
}
|
||||
|
||||
int b(int val)
|
||||
{
|
||||
return c(val);
|
||||
}
|
||||
|
||||
int c(int val)
|
||||
{
|
||||
return val + 3;
|
||||
}
|
||||
|
||||
int main (int argc, char const *argv[])
|
||||
{
|
||||
int A1 = a(1); // a(1) -> b(1) -> c(1)
|
||||
printf("a(1) returns %d\n", A1);
|
||||
|
||||
int B2 = b(2); // b(2) -> c(2)
|
||||
printf("b(2) returns %d\n", B2);
|
||||
|
||||
int A3 = a(3); // a(3) -> c(3)
|
||||
printf("a(3) returns %d\n", A3);
|
||||
|
||||
return 0;
|
||||
}
|
||||
Loading…
Reference in New Issue