forked from OSchip/llvm-project
Make test_connect_remote() more robust by waiting on the server ready message
before issuing the 'process connect ...' command. test_comand_regex(): assign the spawned child to self.child so it gets automatically shutdown during TestBase.tearDown(self). llvm-svn: 130015
This commit is contained in:
parent
8a51be9e1b
commit
ea76c4f229
|
@ -22,6 +22,8 @@ class CommandRegexTestCase(TestBase):
|
|||
# Turn on logging for what the child sends back.
|
||||
if self.TraceOn():
|
||||
child.logfile_read = sys.stdout
|
||||
# So that the spawned lldb session gets shutdown durng teardown.
|
||||
self.child = child
|
||||
|
||||
# Substitute 'Help!' with 'help' using the 'commands regex' mechanism.
|
||||
child.expect(prompt)
|
||||
|
@ -33,7 +35,7 @@ class CommandRegexTestCase(TestBase):
|
|||
# Help!
|
||||
child.sendline('Help!')
|
||||
# If we see the familiar 'help' output, the test is done.
|
||||
child.expect('The following is a list of built-in, permanent debugger commands:')
|
||||
child.expect('The following is a list of built-in, permanent debugger commands:')
|
||||
|
||||
if __name__ == '__main__':
|
||||
import atexit
|
||||
|
|
|
@ -2,9 +2,10 @@
|
|||
Test lldb 'process connect' command.
|
||||
"""
|
||||
|
||||
import os, time
|
||||
import os
|
||||
import unittest2
|
||||
import lldb
|
||||
import pexpect
|
||||
from lldbtest import *
|
||||
|
||||
class ConnectRemoteTestCase(TestBase):
|
||||
|
@ -16,14 +17,21 @@ class ConnectRemoteTestCase(TestBase):
|
|||
"""Test "process connect connect:://localhost:12345"."""
|
||||
|
||||
# First, we'll start a fake debugserver (a simple echo server).
|
||||
import subprocess
|
||||
fakeserver = subprocess.Popen('./EchoServer.py')
|
||||
# This does the cleanup afterwards.
|
||||
def cleanup_fakeserver():
|
||||
fakeserver.kill()
|
||||
fakeserver.wait()
|
||||
self.addTearDownHook(cleanup_fakeserver)
|
||||
fakeserver = pexpect.spawn('./EchoServer.py')
|
||||
|
||||
# Turn on logging for what the child sends back.
|
||||
if self.TraceOn():
|
||||
fakeserver.logfile = sys.stdout
|
||||
|
||||
# Schedule the fake debugserver to be shut down during teardown.
|
||||
def shutdown_fakeserver():
|
||||
fakeserver.close()
|
||||
self.addTearDownHook(shutdown_fakeserver)
|
||||
|
||||
# Wait until we receive the server ready message before continuing.
|
||||
fakeserver.expect('Listening on localhost:12345')
|
||||
|
||||
# Connect to the fake server....
|
||||
self.runCmd("process connect connect://localhost:12345")
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue