Skip to content

Commit

Permalink
test(selenium): run tests across multiple {browser, js} combinations
Browse files Browse the repository at this point in the history
  • Loading branch information
Restioson committed Nov 6, 2024
1 parent 7815149 commit c9f71f3
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 10 deletions.
10 changes: 8 additions & 2 deletions .github/workflows/testing.yml
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,13 @@ jobs:
cd app/
python manage.py check
selenium:
runs-on: ubuntu-latest
strategy:
matrix:
browser-and-os:
- [firefox, ubuntu-latest]
- [chrome, ubuntu-latest]
js: [js-enabled, js-disabled]
runs-on: ${{ matrix.browser-and-os[1] }}
services:
postgres:
image: postgres:16
Expand Down Expand Up @@ -101,7 +107,7 @@ jobs:
cp .env.testing app/.env
cd app/
mkdir -p static_files
python manage.py test --tag=selenium
BROWSER=${{ matrix.browser-and-os[0] }} ENABLE_JS=${{ matrix.js }} python manage.py test --tag=selenium
env:
DJANGO_SETTINGS_MODULE: app.settings
DATABASE_URL: postgres://sadilar:sadilar@localhost:5432/test_db
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ create-schema:
@docker compose run --rm web python manage.py graph_models -a -o schema/schema.png

test:
@docker compose run --rm web python manage.py test $(module)
@docker compose run --rm -e BROWSER -e JS_ENABLED web python manage.py test $(module)

ruff-check:
@docker compose run --rm web ruff check .
Expand Down
41 changes: 34 additions & 7 deletions app/general/tests/test_frontend.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,21 @@
import os

from django.contrib.staticfiles.testing import StaticLiveServerTestCase
from django.test import tag
from selenium.common import TimeoutException
from selenium.webdriver.chrome.webdriver import Options, WebDriver
from selenium.webdriver.chrome.webdriver import (
Options as ChromeOptions,
)
from selenium.webdriver.chrome.webdriver import (
WebDriver as ChromeWebDriver,
)
from selenium.webdriver.common.by import By
from selenium.webdriver.firefox.webdriver import (
Options as FirefoxOptions,
)
from selenium.webdriver.firefox.webdriver import (
WebDriver as FirefoxWebDriver,
)
from selenium.webdriver.support.wait import WebDriverWait

# Wait timeout in seconds
Expand All @@ -13,13 +26,27 @@
class TestFrontend(StaticLiveServerTestCase):
@classmethod
def setUpClass(cls):
opts = Options()
opts.add_argument("--headless")
opts.add_argument("--no-sandbox")
opts.add_argument("--disable-dev-shm-usage")
opts.add_argument("--window-size=1920,1080")
cls.driver = WebDriver(opts)
browser = os.environ.get("BROWSER", "chrome").lower()
js_enabled = os.environ.get("JS_ENABLED", "js-enabled") == "js-enabled"

print(
f"Running Selenium tests on {browser}. JS is {'enabled' if js_enabled else 'disabled'}."
)

if browser == "chrome":
opts = ChromeOptions()
opts.add_argument("--headless")
opts.add_argument("--no-sandbox")
opts.add_argument("--disable-dev-shm-usage")
opts.add_argument("--window-size=1920,1080")
cls.driver = ChromeWebDriver(opts)
elif browser == "firefox":
options = FirefoxOptions()
options.add_argument("-headless")
cls.driver = FirefoxWebDriver(options=options)

cls.driver.implicitly_wait(WAIT_TIMEOUT)

super().setUpClass()

@classmethod
Expand Down

0 comments on commit c9f71f3

Please sign in to comment.