Create separate test workflow for docker
This expands on the current testing suite a bit by introducing a new workflow for testing functionality within the docker container. It runs the same test suite as the regular "test" workflow, but also performs a health check after running the app for 10 seconds to ensure functionality. The buildx workflow now waits for the docker test script to finish successfully, rather than the regular test workflow. This will hopefully avoid situations where new images are pushed with issues that aren't detected in regular testing of the app.main
parent
6f5f3d8ca7
commit
5a27d748d1
|
@ -2,7 +2,7 @@ name: buildx
|
|||
|
||||
on:
|
||||
workflow_run:
|
||||
workflows: ["tests"]
|
||||
workflows: ["docker_tests"]
|
||||
branches: [main]
|
||||
types:
|
||||
- completed
|
||||
|
|
|
@ -0,0 +1,19 @@
|
|||
name: docker_tests
|
||||
|
||||
on: [push, pull_request]
|
||||
|
||||
jobs:
|
||||
test:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: checkout code
|
||||
uses: actions/checkout@v2
|
||||
- name: build and test
|
||||
run: |
|
||||
docker build --tag whoogle-search:test .
|
||||
TEST_CONTAINER=$(docker run --entrypoint=/bin/bash --detach whoogle-search:test)
|
||||
docker cp test "$TEST_CONTAINER":/whoogle/test
|
||||
docker exec "$TEST_CONTAINER" ./run test
|
||||
docker exec --detach "$TEST_CONTAINER" ./run
|
||||
sleep 10
|
||||
docker exec "$TEST_CONTAINER" curl -f http://localhost:5000/healthz || exit 1
|
|
@ -28,7 +28,6 @@ from requests.models import PreparedRequest
|
|||
# Load DDG bang json files only on init
|
||||
bang_json = json.load(open(app.config['BANG_FILE']))
|
||||
|
||||
|
||||
# Check the newest version of WHOOGLE
|
||||
update = bsoup(get(app.config['RELEASES_URL']).text, 'html.parser')
|
||||
newest_version = update.select_one('[class="Link--primary"]').string[1:]
|
||||
|
@ -113,10 +112,10 @@ def before_request_func():
|
|||
session['uuid'] = str(uuid.uuid4())
|
||||
session['key'] = generate_user_key()
|
||||
|
||||
# Skip checking for session on /autocomplete searches,
|
||||
# since they can be done from the browser search bar (aka
|
||||
# no ability to initialize a session)
|
||||
if not Endpoint.autocomplete.in_path(request.path):
|
||||
# Skip checking for session on any searches that don't
|
||||
# require a valid session
|
||||
if (not Endpoint.autocomplete.in_path(request.path) and
|
||||
not Endpoint.healthz.in_path(request.path)):
|
||||
return redirect(url_for(
|
||||
'session_check',
|
||||
session_id=session['uuid'],
|
||||
|
|
Loading…
Reference in New Issue