2016-12-16 09:07:29 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
from __future__ import print_function
|
2017-01-03 09:10:49 +01:00
|
|
|
import optparse
|
2016-12-16 09:07:29 +01:00
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import subprocess
|
|
|
|
|
|
|
|
import time
|
|
|
|
|
|
|
|
try:
|
|
|
|
# We don't actually need typing, but it's a good guard for being
|
|
|
|
# outside a Zulip virtualenv.
|
|
|
|
from typing import Iterable
|
|
|
|
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)
|
|
|
|
|
|
|
|
os.environ["EXTERNAL_HOST"] = "localhost:9981"
|
|
|
|
|
2017-01-03 09:10:49 +01:00
|
|
|
parser = optparse.OptionParser()
|
|
|
|
parser.add_option('--force', default=False,
|
|
|
|
action="store_true",
|
|
|
|
help='Run tests despite possible problems.')
|
|
|
|
(options, args) = parser.parse_args()
|
2016-12-16 09:07:29 +01:00
|
|
|
|
|
|
|
def assert_server_running(server):
|
|
|
|
# type: (subprocess.Popen) -> None
|
|
|
|
"""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 %s' % (LOG_FILE,))
|
|
|
|
|
|
|
|
|
|
|
|
def server_is_up(server):
|
|
|
|
# type: (subprocess.Popen) -> bool
|
|
|
|
assert_server_running(server)
|
|
|
|
try:
|
|
|
|
# We could get a 501 error if the reverse proxy is up but the Django app isn't.
|
|
|
|
return requests.get('http://127.0.0.1:9981/accounts/home').status_code == 200
|
|
|
|
except:
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
subprocess.check_call(['mkdir', '-p', 'var/help-documentation'])
|
|
|
|
|
|
|
|
LOG_FILE = 'var/help-documentation/server.log'
|
|
|
|
if os.path.exists(LOG_FILE) and os.path.getsize(LOG_FILE) < 100000:
|
|
|
|
log = open(LOG_FILE, 'a')
|
|
|
|
log.write('\n\n')
|
|
|
|
else:
|
|
|
|
log = open(LOG_FILE, 'w')
|
2017-01-03 09:10:49 +01:00
|
|
|
|
|
|
|
run_dev_server_command = ['tools/run-dev.py', '--test']
|
|
|
|
if options.force:
|
|
|
|
run_dev_server_command.append('--force')
|
|
|
|
server = subprocess.Popen(run_dev_server_command, stdout=log, stderr=log)
|
|
|
|
|
2016-12-16 09:07:29 +01:00
|
|
|
sys.stdout.write('Waiting for test server')
|
|
|
|
try:
|
|
|
|
while not server_is_up(server):
|
|
|
|
sys.stdout.write('.')
|
|
|
|
sys.stdout.flush()
|
|
|
|
time.sleep(0.1)
|
|
|
|
sys.stdout.write('\n')
|
|
|
|
|
|
|
|
ret = subprocess.call(('scrapy', 'crawl_with_status', 'help_documentation_crawler'),
|
|
|
|
cwd='tools/documentation_crawler')
|
|
|
|
finally:
|
|
|
|
assert_server_running(server)
|
|
|
|
server.terminate()
|
|
|
|
|
|
|
|
if ret != 0:
|
|
|
|
print("\033[0;91m")
|
|
|
|
print("Failed")
|
|
|
|
print("\033[0m")
|
|
|
|
else:
|
|
|
|
print("\033[0;92m")
|
|
|
|
print("Passed!")
|
|
|
|
print("\033[0m")
|
|
|
|
|
|
|
|
|
|
|
|
sys.exit(ret)
|