2016-04-07 15:03:22 +02:00
|
|
|
#!/usr/bin/env python
|
2016-03-10 17:15:34 +01:00
|
|
|
from __future__ import print_function
|
2012-11-09 21:03:57 +01:00
|
|
|
import subprocess
|
2013-05-21 23:09:08 +02:00
|
|
|
import optparse
|
2012-11-09 21:03:57 +01:00
|
|
|
import time
|
|
|
|
import sys
|
|
|
|
import os
|
2013-03-05 22:50:06 +01:00
|
|
|
import glob
|
2016-06-04 00:05:06 +02:00
|
|
|
try:
|
2016-06-06 22:40:30 +02:00
|
|
|
# We don't actually need typing, but it's a good guard for being
|
|
|
|
# outside a Zulip virtualenv.
|
2016-07-24 07:22:54 +02:00
|
|
|
from typing import Iterable
|
2016-06-04 00:05:06 +02:00
|
|
|
import requests
|
|
|
|
except ImportError as e:
|
|
|
|
print("ImportError: {}".format(e))
|
|
|
|
print("You need to run the Zulip tests inside a Zulip dev environment.")
|
|
|
|
print("If you are using Vagrant, you can `vagrant ssh` to enter the Vagrant guest.")
|
|
|
|
sys.exit(1)
|
2012-11-09 21:03:57 +01:00
|
|
|
|
2013-05-21 23:09:08 +02:00
|
|
|
#
|
|
|
|
# In order to use remote casperjs debugging, pass the --remote-debug flag
|
|
|
|
# This will start a remote debugging session listening on port 7777
|
|
|
|
#
|
2013-07-24 23:29:47 +02:00
|
|
|
# See https://wiki.zulip.net/wiki/Testing_the_app for more information
|
2013-05-21 23:09:08 +02:00
|
|
|
# on how to use remote debugging
|
|
|
|
#
|
|
|
|
|
2016-07-27 20:54:00 +02:00
|
|
|
os.environ["TORNADO_SERVER"] = "http://127.0.0.1:9983"
|
2013-01-10 19:05:53 +01:00
|
|
|
|
2016-06-27 23:15:20 +02:00
|
|
|
usage = """%prog [options]
|
|
|
|
test-js-with-casper # Run all test files
|
|
|
|
test-js-with-casper 09-navigation.js # Run a single test file
|
|
|
|
test-js-with-casper 01-login.js 03-narrow.js # Run a few test files"""
|
|
|
|
parser = optparse.OptionParser(usage)
|
2013-05-21 23:09:08 +02:00
|
|
|
|
|
|
|
parser.add_option('--remote-debug',
|
|
|
|
help='Whether or not to enable remote debugging on port 7777',
|
|
|
|
action="store_true",
|
|
|
|
default=False)
|
|
|
|
(options, args) = parser.parse_args()
|
|
|
|
|
2015-10-13 23:34:50 +02:00
|
|
|
os.chdir(os.path.join(os.path.dirname(os.path.realpath(__file__)), '..'))
|
2012-11-09 21:03:57 +01:00
|
|
|
|
2016-05-26 12:36:22 +02:00
|
|
|
subprocess.check_call('tools/setup/generate-test-credentials')
|
2015-08-20 02:57:30 +02:00
|
|
|
|
2013-03-05 22:50:06 +01:00
|
|
|
subprocess.check_call(['rm', '-f'] + glob.glob('/tmp/casper-failure*.png'))
|
|
|
|
|
2016-07-24 07:02:22 +02:00
|
|
|
subprocess.check_call(['mkdir', '-p', 'var/casper'])
|
|
|
|
|
|
|
|
log = open('var/casper/server.log', 'w')
|
2012-11-09 21:03:57 +01:00
|
|
|
|
2016-07-21 05:21:42 +02:00
|
|
|
def assert_server_running(server):
|
2016-07-24 07:22:54 +02:00
|
|
|
# type: (subprocess.Popen) -> None
|
2016-06-06 22:41:44 +02:00
|
|
|
"""Get the exit code of the server, or None if it is still running."""
|
2012-11-14 20:04:31 +01:00
|
|
|
if server.poll() is not None:
|
2016-07-24 07:02:22 +02:00
|
|
|
raise RuntimeError('Server died unexpectedly! Check var/casper/server.log')
|
2012-11-14 20:04:31 +01:00
|
|
|
|
2016-07-21 05:21:42 +02:00
|
|
|
def server_is_up(server):
|
2016-07-24 07:22:54 +02:00
|
|
|
# type: (subprocess.Popen) -> bool
|
2016-07-21 05:21:42 +02:00
|
|
|
assert_server_running(server)
|
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.
|
2016-07-27 20:54:00 +02:00
|
|
|
return requests.get('http://127.0.0.1:9981/accounts/home').status_code == 200
|
2012-11-13 23:54:08 +01:00
|
|
|
except:
|
|
|
|
return False
|
|
|
|
|
2016-07-21 05:23:07 +02:00
|
|
|
def run_tests(files):
|
2016-07-24 07:22:54 +02:00
|
|
|
# type: (Iterable[str]) -> None
|
2016-07-21 05:20:34 +02:00
|
|
|
test_files = []
|
2016-07-21 05:23:07 +02:00
|
|
|
for file in files:
|
2016-07-21 05:20:34 +02:00
|
|
|
if not os.path.exists(file):
|
|
|
|
file = os.path.join(os.path.dirname(__file__), '../frontend_tests/casper_tests', file)
|
|
|
|
test_files.append(os.path.abspath(file))
|
2016-07-21 05:17:40 +02:00
|
|
|
|
2016-07-21 05:20:34 +02:00
|
|
|
subprocess.check_call('tools/setup/generate-fixtures')
|
2016-07-21 05:17:40 +02:00
|
|
|
|
2016-07-21 05:26:45 +02:00
|
|
|
remote_debug = ""
|
|
|
|
if options.remote_debug:
|
|
|
|
remote_debug = "--remote-debugger-port=7777 --remote-debugger-autorun=yes"
|
|
|
|
|
|
|
|
cmd = "frontend_tests/casperjs/bin/casperjs %s test " % (remote_debug,)
|
|
|
|
if test_files:
|
|
|
|
cmd += ' '.join(test_files)
|
|
|
|
else:
|
|
|
|
cmd += 'frontend_tests/casper_tests'
|
|
|
|
|
2016-07-21 05:20:34 +02:00
|
|
|
# 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)
|
2016-07-21 05:17:40 +02:00
|
|
|
|
2016-07-21 05:20:34 +02:00
|
|
|
ret = 1
|
2012-11-09 21:03:57 +01:00
|
|
|
|
2016-07-21 05:20:34 +02:00
|
|
|
try:
|
|
|
|
# Wait for the server to start up.
|
|
|
|
sys.stdout.write('Waiting for test server')
|
|
|
|
while not server_is_up(server):
|
|
|
|
sys.stdout.write('.')
|
|
|
|
sys.stdout.flush()
|
|
|
|
time.sleep(0.1)
|
|
|
|
sys.stdout.write('\n')
|
|
|
|
|
|
|
|
print("Running %s" % (cmd,))
|
|
|
|
ret = subprocess.call(cmd, shell=True)
|
|
|
|
finally:
|
|
|
|
assert_server_running(server)
|
|
|
|
server.terminate()
|
|
|
|
|
|
|
|
if ret != 0:
|
|
|
|
print("""
|
2015-08-21 22:48:57 +02:00
|
|
|
Oops, the frontend tests failed. Tips for debugging:
|
2016-07-24 07:02:22 +02:00
|
|
|
* Check the frontend test server logs at var/casper/server.log
|
2015-08-21 22:48:57 +02:00
|
|
|
* Check the screenshots of failed tests at /tmp/casper-failure*.png
|
|
|
|
* Try remote debugging the test web browser as described in docs/testing.rst
|
2016-03-10 17:15:34 +01:00
|
|
|
""", file=sys.stderr)
|
2015-08-21 22:48:57 +02:00
|
|
|
|
2016-07-21 05:20:34 +02:00
|
|
|
sys.exit(ret)
|
|
|
|
|
2016-07-21 05:23:07 +02:00
|
|
|
run_tests(args)
|
2016-07-21 05:20:34 +02:00
|
|
|
sys.exit(0)
|