From dc5dde138323c5cd78de150640258b7d3d02f84c Mon Sep 17 00:00:00 2001 From: Angelika Tyborska Date: Sun, 2 Jun 2024 17:48:45 +0200 Subject: [PATCH] Add smoke test --- .github/workflows/test.yml | 11 +++++- bin/smoke_test.exs | 39 +++++++++++++++++++ .../demo_web/integration/pages_hound_test.exs | 2 +- .../integration/pages_wallaby_test.exs | 2 +- 4 files changed, 50 insertions(+), 4 deletions(-) create mode 100755 bin/smoke_test.exs diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 9cc6f38..48de39e 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -77,8 +77,15 @@ jobs: - name: Run tests run: mix test -# - name: Run smoke tests -# run: elixir ./bin/smoke_test.exs + - name: Set up Chromedriver + uses: nanasess/setup-chromedriver@v2 + - run: | + export DISPLAY=:99 + chromedriver --url-base=/wd/hub & + sudo Xvfb -ac :99 -screen 0 1280x1024x24 > /dev/null 2>&1 & # optional + + - name: Run smoke tests + run: elixir ./bin/smoke_test.exs - name: Check for compilation warnings run: mix compile --force --no-warnings diff --git a/bin/smoke_test.exs b/bin/smoke_test.exs new file mode 100755 index 0000000..d5724cb --- /dev/null +++ b/bin/smoke_test.exs @@ -0,0 +1,39 @@ +# assumes Chromedriver is running + +IO.puts("Running smoke tests") +IO.puts("\n\n") + +check_output = fn (output, pattern) -> + if not (output =~ pattern) do + IO.puts("Expected test output to match pattern:") + IO.puts(pattern) + exit 1 + end +end + +demo_project_path = "./demo" +demo_test_files = + [ + "test/demo_web/integration/pages_wallaby_test.exs", + "test/demo_web/integration/pages_hound_test.exs" + ] + +Enum.each(demo_test_files, fn demo_test_file -> + IO.puts("checking #{demo_test_file}") + + {output, 2} = System.cmd("mix", ["test", demo_test_file], cd: demo_project_path) + + check_output.(output, ~r/3 (features|tests), 2 failures/) + check_output.(output, "invalid page with accessibility errors") + check_output.(output, "critical") + check_output.(output, "Images must have alternate text") + check_output.(output, "There is 1 node with this violation:") + check_output.(output, "dynamic invalid page with accessibility errors that only happen after interaction") + check_output.(output, "serious") + check_output.(output, "Elements must meet minimum color contrast ratio thresholds") + check_output.(output, "There are 13 nodes with this violation:") + check_output.(output, "1.

Angelika's Star Trek series ranking

") + check_output.(output, "... and 10 more nodes") +end) + +IO.puts("all good") diff --git a/demo/test/demo_web/integration/pages_hound_test.exs b/demo/test/demo_web/integration/pages_hound_test.exs index cfe597a..3c9a958 100644 --- a/demo/test/demo_web/integration/pages_hound_test.exs +++ b/demo/test/demo_web/integration/pages_hound_test.exs @@ -46,6 +46,6 @@ defmodule DemoWeb.PagesHoundTest do article = find_element(:css, "article") assert attribute_value(article, "style") == "background-color: rgb(34, 34, 34);" - A11yAudit.Hound.assert_no_violations() + A11yAudit.Hound.assert_no_violations(nodes_per_violation_print_limit: 3) end end diff --git a/demo/test/demo_web/integration/pages_wallaby_test.exs b/demo/test/demo_web/integration/pages_wallaby_test.exs index 8c0e6e6..ed55ae1 100644 --- a/demo/test/demo_web/integration/pages_wallaby_test.exs +++ b/demo/test/demo_web/integration/pages_wallaby_test.exs @@ -29,6 +29,6 @@ defmodule DemoWeb.PagesWallabyTest do |> find(Query.css("article"), fn article -> assert Element.attr(article, "style") == "background-color: rgb(34, 34, 34);" end) - |> A11yAudit.Wallaby.assert_no_violations() + |> A11yAudit.Wallaby.assert_no_violations(nodes_per_violation_print_limit: 3) end end