[Lldb-commits] [lldb] r239973 - Add a test for expression evaluation while inferior is blocked in a syscall

Pavel Labath labath at google.com
Wed Jun 17 16:28:56 PDT 2015


Author: labath
Date: Wed Jun 17 18:28:55 2015
New Revision: 239973

URL: http://llvm.org/viewvc/llvm-project?rev=239973&view=rev
Log:
Add a test for expression evaluation while inferior is blocked in a syscall

Summary: The test is XFAILed for Linux x86_64 and i386 because of bug #23659.

Test Plan: NFC

Reviewers: tberghammer

Subscribers: lldb-commits, emaste

Differential Revision: http://reviews.llvm.org/D10519

Added:
    lldb/trunk/test/expression_command/expr-in-syscall/
    lldb/trunk/test/expression_command/expr-in-syscall/Makefile
    lldb/trunk/test/expression_command/expr-in-syscall/TestExpressionInSyscall.py
    lldb/trunk/test/expression_command/expr-in-syscall/main.c

Added: lldb/trunk/test/expression_command/expr-in-syscall/Makefile
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/expression_command/expr-in-syscall/Makefile?rev=239973&view=auto
==============================================================================
--- lldb/trunk/test/expression_command/expr-in-syscall/Makefile (added)
+++ lldb/trunk/test/expression_command/expr-in-syscall/Makefile Wed Jun 17 18:28:55 2015
@@ -0,0 +1,5 @@
+LEVEL = ../../make
+
+C_SOURCES := main.c
+
+include $(LEVEL)/Makefile.rules

Added: lldb/trunk/test/expression_command/expr-in-syscall/TestExpressionInSyscall.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/expression_command/expr-in-syscall/TestExpressionInSyscall.py?rev=239973&view=auto
==============================================================================
--- lldb/trunk/test/expression_command/expr-in-syscall/TestExpressionInSyscall.py (added)
+++ lldb/trunk/test/expression_command/expr-in-syscall/TestExpressionInSyscall.py Wed Jun 17 18:28:55 2015
@@ -0,0 +1,90 @@
+"""Test that we are able to evaluate expressions when the inferior is blocked in a syscall"""
+
+import os
+import unittest2
+import lldb
+from lldbtest import *
+import lldbutil
+
+
+class ExprSyscallTestCase(TestBase):
+
+    mydir = TestBase.compute_mydir(__file__)
+
+    @skipUnlessDarwin
+    @dsym_test
+    def test_setpgid_with_dsym(self):
+        self.buildDsym()
+        self.expr_syscall()
+
+    @expectedFailureAll("llvm.org/pr23659", oslist=["linux"], archs=["i386", "x86_64"])
+    @dwarf_test
+    def test_setpgid_with_dwarf(self):
+        self.buildDwarf()
+        self.expr_syscall()
+
+    def expr_syscall(self):
+        exe = os.path.join(os.getcwd(), 'a.out')
+
+        # Create a target by the debugger.
+        target = self.dbg.CreateTarget(exe)
+        self.assertTrue(target, VALID_TARGET)
+
+        listener = lldb.SBListener("my listener")
+
+        # launch the inferior and don't wait for it to stop
+        self.dbg.SetAsync(True)
+        error = lldb.SBError()
+        process = target.Launch (listener,
+                None,      # argv
+                None,      # envp
+                None,      # stdin_path
+                None,      # stdout_path
+                None,      # stderr_path
+                None,      # working directory
+                0,         # launch flags
+                False,     # Stop at entry
+                error)     # error
+
+        self.assertTrue(process and process.IsValid(), PROCESS_IS_VALID)
+
+        event = lldb.SBEvent()
+
+        # Give the child enough time to reach the syscall,
+        # while clearing out all the pending events.
+        # The last WaitForEvent call will time out after 2 seconds.
+        while listener.WaitForEvent(2, event):
+            pass
+
+        # now the process should be running (blocked in the syscall)
+        self.assertEqual(process.GetState(), lldb.eStateRunning, "Process is running")
+
+        # send the process a signal
+        process.SendAsyncInterrupt()
+        while listener.WaitForEvent(1, event):
+            pass
+
+        # as a result the process should stop
+        # in all likelihood we have stopped in the middle of the sleep() syscall
+        self.assertEqual(process.GetState(), lldb.eStateStopped, PROCESS_STOPPED)
+        thread = process.GetSelectedThread()
+
+        # try evaluating a couple of expressions in this state
+        self.expect("expr release_flag = 1", substrs = [" = 1"])
+        self.expect("print (int)getpid()", substrs = [str(process.GetProcessID())])
+
+        # and run the process to completion
+        process.Continue()
+
+        # process all events
+        while listener.WaitForEvent(1, event):
+            pass
+
+        self.assertEqual(process.GetState(), lldb.eStateExited)
+        self.assertEqual(process.GetExitStatus(), 0)
+
+if __name__ == '__main__':
+    import atexit
+    lldb.SBDebugger.Initialize()
+    atexit.register(lambda: lldb.SBDebugger.Terminate())
+    unittest2.main()

Added: lldb/trunk/test/expression_command/expr-in-syscall/main.c
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/expression_command/expr-in-syscall/main.c?rev=239973&view=auto
==============================================================================
--- lldb/trunk/test/expression_command/expr-in-syscall/main.c (added)
+++ lldb/trunk/test/expression_command/expr-in-syscall/main.c Wed Jun 17 18:28:55 2015
@@ -0,0 +1,11 @@
+#include <unistd.h>
+
+volatile int release_flag = 0;
+
+int main(int argc, char const *argv[])
+{
+    while (! release_flag) // Wait for debugger to attach
+        sleep(3);
+
+    return 0;
+}





More information about the lldb-commits mailing list