blob: 64efad7b659ea487b6168cd0648a4e7fd9cba654 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
import lldb
import re
import testutils as test
# bpmd -nofuturemodule <module name> <managed function name>
def runScenario(assembly, debugger, target):
process = target.GetProcess()
res = lldb.SBCommandReturnObject()
ci = debugger.GetCommandInterpreter()
# Process must be stopped here while libcoreclr loading.
# This test usually fails on release version of coreclr
# since we depend on 'LoadLibraryExW' symbol present.
test.assertEqual(process.GetState(), lldb.eStateStopped)
# The reason of this stop must be a breakpoint
test.assertEqual(process.GetSelectedThread().GetStopReason(),
lldb.eStopReasonBreakpoint)
ci.HandleCommand("bpmd -nofuturemodule " + assembly + " Test.Main", res)
out_msg = res.GetOutput()
err_msg = res.GetError()
print(out_msg)
print(err_msg)
# Interpreter must have this command and able to run it
test.assertTrue(res.Succeeded())
# Output is not empty
# Should be at least 'Adding pending breakpoints...'
test.assertTrue(len(out_msg) == 0)
# Error message is empty
test.assertTrue(len(err_msg) == 0)
process.Continue()
# Process must be exited because of -nofuturemodule flag
test.assertEqual(process.GetState(), lldb.eStateExited)
# The reason of this stop must be a breakpoint
test.assertEqual(process.GetSelectedThread().GetStopReason(),
lldb.eStopReasonNone)
#
# Delete all breakpoints, continue current process and checks its exit code
test.exit_lldb(debugger, assembly)
|