2012-11-09 21:03:57 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
import subprocess
|
2012-11-13 23:54:08 +01:00
|
|
|
import requests
|
2012-11-09 21:03:57 +01:00
|
|
|
import time
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
from os import path
|
|
|
|
|
|
|
|
os.chdir(path.join(path.dirname(__file__), '../../..'))
|
|
|
|
|
|
|
|
subprocess.check_call('zephyr/tests/generate-fixtures')
|
|
|
|
|
|
|
|
log = open('zephyr/tests/frontend/server.log', 'w')
|
|
|
|
|
|
|
|
# Run this not through the shell, so that we have the actual PID.
|
|
|
|
server = subprocess.Popen(('tools/run-dev.py', '--test'),
|
|
|
|
stdout=log, stderr=log)
|
|
|
|
|
2012-11-14 20:04:31 +01:00
|
|
|
def assert_server_running():
|
|
|
|
# Get the exit code of the server, or None if it is still running.
|
|
|
|
if server.poll() is not None:
|
|
|
|
raise RuntimeError, 'Server died unexpectedly! Check zephyr/tests/frontend/server.log'
|
|
|
|
|
2012-11-13 23:54:08 +01:00
|
|
|
def server_is_up():
|
2012-11-14 20:04:31 +01:00
|
|
|
assert_server_running()
|
2012-11-13 23:54:08 +01:00
|
|
|
try:
|
|
|
|
# We could get a 501 error if the reverse proxy is up but the Django app isn't.
|
|
|
|
return requests.get('http://localhost:9981/accounts/home').status_code == 200
|
|
|
|
except:
|
|
|
|
return False
|
|
|
|
|
2012-11-14 00:01:43 +01:00
|
|
|
ret = 1
|
2012-11-09 21:03:57 +01:00
|
|
|
|
2012-11-14 00:01:43 +01:00
|
|
|
try:
|
|
|
|
# Wait for the server to start up.
|
2012-11-16 16:56:15 +01:00
|
|
|
sys.stdout.write('Waiting for test server')
|
2012-11-14 00:01:43 +01:00
|
|
|
while not server_is_up():
|
2012-11-16 16:56:15 +01:00
|
|
|
sys.stdout.write('.')
|
|
|
|
sys.stdout.flush()
|
2012-11-14 00:01:43 +01:00
|
|
|
time.sleep(0.1)
|
2012-11-16 16:56:15 +01:00
|
|
|
sys.stdout.write('\n')
|
2012-11-09 21:03:57 +01:00
|
|
|
|
2012-11-14 00:01:43 +01:00
|
|
|
ret = subprocess.call(
|
|
|
|
'zephyr/tests/frontend/casperjs/bin/casperjs zephyr/tests/frontend/tests.js',
|
|
|
|
shell=True)
|
|
|
|
finally:
|
2012-11-14 20:04:31 +01:00
|
|
|
assert_server_running()
|
2012-11-14 00:01:43 +01:00
|
|
|
server.terminate()
|
2012-11-09 21:03:57 +01:00
|
|
|
|
|
|
|
sys.exit(ret)
|