##// END OF EJS Templates
Add wave2D example
Add wave2D example

File last commit:

r3655:e5c37613
r3656:1f490770
Show More
__init__.py
48 lines | 1.2 KiB | text/x-python | PythonLexer
"""toplevel setup/teardown for parallel tests."""
import tempfile
import time
from subprocess import Popen, PIPE, STDOUT
from IPython.zmq.parallel import client
processes = []
blackhole = tempfile.TemporaryFile()
# nose setup/teardown
def setup():
cp = Popen('ipcontrollerz --profile iptest -r --log-level 40'.split(), stdout=blackhole, stderr=STDOUT)
processes.append(cp)
time.sleep(.5)
add_engine()
c = client.Client(profile='iptest')
while not c.ids:
time.sleep(.1)
c.spin()
def add_engine(profile='iptest'):
ep = Popen(['ipenginez']+ ['--profile', profile, '--log-level', '40'], stdout=blackhole, stderr=STDOUT)
# ep.start()
processes.append(ep)
return ep
def teardown():
time.sleep(1)
while processes:
p = processes.pop()
if p.poll() is None:
try:
p.terminate()
except Exception, e:
print e
pass
if p.poll() is None:
time.sleep(.25)
if p.poll() is None:
try:
print 'killing'
p.kill()
except:
print "couldn't shutdown process: ", p