Allow testing packages under a different build path

This commit is contained in:
Roman Yurchak 2018-10-02 10:39:25 +02:00
parent 27d135e61d
commit c5c87b41b7
1 changed files with 27 additions and 19 deletions

View File

@ -13,15 +13,21 @@ import queue
import sys import sys
import shutil import shutil
try:
import pytest
except ImportError:
pytest = None
TEST_PATH = pathlib.Path(__file__).parents[0].resolve() TEST_PATH = pathlib.Path(__file__).parents[0].resolve()
BUILD_PATH = TEST_PATH / '..' / 'build' BUILD_PATH = TEST_PATH / '..' / 'build'
try:
import pytest
def pytest_addoption(parser):
group = parser.getgroup("general")
group.addoption(
'--build-dir', action="store", default=BUILD_PATH,
help="Path to the build directory")
except ImportError:
pytest = None
class PyodideInited: class PyodideInited:
def __call__(self, driver): def __call__(self, driver):
@ -49,16 +55,16 @@ def _display_driver_logs(browser, driver):
class SeleniumWrapper: class SeleniumWrapper:
def __init__(self, server_port, server_hostname='127.0.0.1', def __init__(self, build_dir, server_port, server_hostname='127.0.0.1',
server_log=None): server_log=None):
from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.support.wait import WebDriverWait
from selenium.common.exceptions import TimeoutException from selenium.common.exceptions import TimeoutException
driver = self.get_driver() driver = self.get_driver()
wait = WebDriverWait(driver, timeout=20) wait = WebDriverWait(driver, timeout=20)
if not (BUILD_PATH / 'test.html').exists(): if not (pathlib.Path(build_dir) / 'test.html').exists():
# selenium does not expose HTTP response codes # selenium does not expose HTTP response codes
raise ValueError(f"{(BUILD_PATH / 'test.html').resolve()} " raise ValueError(f"{(build_dir / 'test.html').resolve()} "
f"does not exist!") f"does not exist!")
driver.get(f'http://{server_hostname}:{server_port}/test.html') driver.get(f'http://{server_hostname}:{server_port}/test.html')
try: try:
@ -166,7 +172,8 @@ if pytest is not None:
cls = FirefoxWrapper cls = FirefoxWrapper
elif request.param == 'chrome': elif request.param == 'chrome':
cls = ChromeWrapper cls = ChromeWrapper
selenium = cls(server_port=server_port, selenium = cls(build_dir=request.config.option.build_dir,
server_port=server_port,
server_hostname=server_hostname, server_hostname=server_hostname,
server_log=server_log) server_log=server_log)
try: try:
@ -203,24 +210,25 @@ if pytest is not None:
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
def web_server_main(): def web_server_main(request):
with spawn_web_server() as output: with spawn_web_server(request.config.option.build_dir) as output:
yield output yield output
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
def web_server_secondary(): def web_server_secondary(request):
with spawn_web_server() as output: with spawn_web_server(request.config.option.build_dir) as output:
yield output yield output
@contextlib.contextmanager @contextlib.contextmanager
def spawn_web_server(): def spawn_web_server(build_dir):
tmp_dir = tempfile.mkdtemp() tmp_dir = tempfile.mkdtemp()
log_path = pathlib.Path(tmp_dir) / 'http-server.log' log_path = pathlib.Path(tmp_dir) / 'http-server.log'
q = multiprocessing.Queue() q = multiprocessing.Queue()
p = multiprocessing.Process(target=run_web_server, args=(q, log_path)) p = multiprocessing.Process(target=run_web_server,
args=(q, log_path, build_dir))
try: try:
p.start() p.start()
@ -236,7 +244,7 @@ def spawn_web_server():
shutil.rmtree(tmp_dir) shutil.rmtree(tmp_dir)
def run_web_server(q, log_filepath): def run_web_server(q, log_filepath, build_dir):
"""Start the HTTP web server """Start the HTTP web server
Parameters Parameters
@ -249,7 +257,7 @@ def run_web_server(q, log_filepath):
import http.server import http.server
import socketserver import socketserver
os.chdir(BUILD_PATH) os.chdir(build_dir)
log_fh = log_filepath.open('w', buffering=1) log_fh = log_filepath.open('w', buffering=1)
sys.stdout = log_fh sys.stdout = log_fh
@ -303,7 +311,7 @@ def run_web_server(q, log_filepath):
if (__name__ == '__main__' if (__name__ == '__main__'
and multiprocessing.current_process().name == 'MainProcess' and multiprocessing.current_process().name == 'MainProcess'
and not hasattr(sys, "_pytest_session")): and not hasattr(sys, "_pytest_session")):
with spawn_web_server(): with spawn_web_server(BUILD_PATH):
# run forever # run forever
while True: while True:
time.sleep(1) time.sleep(1)