Browse Source
* Add accessibility tests * Add accessibiliy tests to CI * Lint and refactor * Adjust and update paths * Add some more page testspull/2528/head^2
kosiakkatrina
5 months ago
committed by
GitHub
6 changed files with 282 additions and 3 deletions
@ -0,0 +1,194 @@ |
|||||||
|
require "rails_helper" |
||||||
|
|
||||||
|
RSpec.describe "Accessibility", js: true do |
||||||
|
let(:user) { create(:user, :support) } |
||||||
|
let!(:other_user) { create(:user, name: "new user", organisation: user.organisation, email: "new_user@example.com", confirmation_token: "abc") } |
||||||
|
|
||||||
|
def find_routes(type, resource, subresource) |
||||||
|
routes = Rails.application.routes.routes.select do |route| |
||||||
|
route.verb == "GET" && route.path.spec.to_s.start_with?("/#{type}") |
||||||
|
end |
||||||
|
|
||||||
|
routes.map do |route| |
||||||
|
route_path = route.path.spec.to_s |
||||||
|
route_path |
||||||
|
.gsub("/#{type}s/:id", "/#{type}s/#{resource.id}") |
||||||
|
.gsub(":#{type.underscore}_id", resource.id.to_s) |
||||||
|
.gsub(":id", subresource.id.to_s) |
||||||
|
.gsub("(.:format)", "") |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
before do |
||||||
|
allow(user).to receive(:need_two_factor_authentication?).and_return(false) |
||||||
|
sign_in(user) |
||||||
|
end |
||||||
|
|
||||||
|
context "when viewing user pages" do |
||||||
|
let(:user_paths) do |
||||||
|
Rails.application.routes.routes.select { |route| route.verb == "GET" && route.path.spec.to_s.start_with?("/user") }.map { |route| |
||||||
|
route_path = route.path.spec.to_s |
||||||
|
route_path.gsub(":id", other_user.id.to_s).gsub(":user_id", other_user.id.to_s).gsub("(.:format)", "") |
||||||
|
}.uniq |
||||||
|
end |
||||||
|
|
||||||
|
it "is has accessible pages" do |
||||||
|
user_paths.each do |path| |
||||||
|
visit(path) |
||||||
|
expect(page).to have_current_path(path) |
||||||
|
expect(page).to be_axe_clean.according_to :wcag2aa |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
context "when viewing organisation pages" do |
||||||
|
let(:parent_relationship) { create(:organisation_relationship, parent_organisation: other_user.organisation) } |
||||||
|
let(:child_relationship) { create(:organisation_relationship, child_organisation: other_user.organisation) } |
||||||
|
let(:organisation_paths) do |
||||||
|
routes = find_routes("organisation", other_user.organisation, other_user.organisation).reject do |route| |
||||||
|
route.match?(/\A\/organisations\/#{other_user.organisation_id}\z/) || |
||||||
|
route.include?("filters/update") |
||||||
|
end |
||||||
|
routes << "/organisations/#{other_user.organisation_id}/details" |
||||||
|
route_mappings = { |
||||||
|
"/schemes/csv-download" => "?download_type=combined", |
||||||
|
"logs/csv-download" => "?codes_only=false&years[]=2024", |
||||||
|
"filters/update" => "?codes_only=false", |
||||||
|
"stock-owners/remove" => "?target_organisation_id=#{child_relationship.parent_organisation.id}", |
||||||
|
"managing-agents/remove" => "?target_organisation_id=#{parent_relationship.child_organisation.id}", |
||||||
|
} |
||||||
|
|
||||||
|
routes.map do |route| |
||||||
|
additional_params = route_mappings.find { |pattern, _| route.include?(pattern) }&.last |
||||||
|
route += additional_params if additional_params |
||||||
|
route |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
it "is has accessible pages" do |
||||||
|
organisation_paths.each do |path| |
||||||
|
visit(path) |
||||||
|
expect(page).to have_current_path(path) |
||||||
|
expect(page).to be_axe_clean.according_to :wcag2aa |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
context "when viewing lettings log pages" do |
||||||
|
let(:bulk_upload) { create(:bulk_upload, user:) } |
||||||
|
let(:lettings_log) { create(:lettings_log, :completed, assigned_to: other_user, bulk_upload_id: bulk_upload.id) } |
||||||
|
let(:organisation_relationship) { create(:organisation_relationship, parent_organisation: user.organisation) } |
||||||
|
|
||||||
|
let(:lettings_log_paths) do |
||||||
|
routes = find_routes("lettings-log", lettings_log, bulk_upload) |
||||||
|
all_page_ids = FormHandler.instance.lettings_forms.values.flat_map(&:pages).map(&:id).uniq |
||||||
|
lettings_log_pages = lettings_log.form.pages |
||||||
|
other_form_page_ids = all_page_ids - lettings_log_pages.map(&:id) |
||||||
|
|
||||||
|
routes.reject { |path| |
||||||
|
path.include?("/edit") || path.include?("/new") || path.include?("*page") || path.include?("filters/update") || |
||||||
|
path.include?("local-authority/check-answers") || path.include?("declaration/check-answers") || |
||||||
|
path.include?("/lettings-logs/bulk-upload-logs/#{bulk_upload.id}") || |
||||||
|
path.include?("bulk-upload-soft-validations-check") || |
||||||
|
path == "/lettings-logs/bulk-upload-resume/#{bulk_upload.id}" || |
||||||
|
other_form_page_ids.any? { |page_id| path.include?(page_id.dasherize) } || |
||||||
|
lettings_log_pages.any? { |page| path.include?(page.id.dasherize) && !page.routed_to?(lettings_log, user) } |
||||||
|
}.uniq |
||||||
|
end |
||||||
|
|
||||||
|
before do |
||||||
|
lettings_log.dup.tap do |log| |
||||||
|
log.save(validate: false) |
||||||
|
end |
||||||
|
allow(FormHandler.instance).to receive(:in_crossover_period?).and_return(true) |
||||||
|
end |
||||||
|
|
||||||
|
it "is has accessible pages" do |
||||||
|
lettings_log_paths.each do |path| |
||||||
|
path += "?original_log_id=#{lettings_log.id}" if path.include?("duplicate") |
||||||
|
path += "?codes_only=true&years[]=2024" if path.include?("csv") |
||||||
|
path.gsub!("/start", "/prepare-your-file?form[year]=2024") if path.include?("bulk-upload-logs/start") |
||||||
|
path.gsub!("/start", "/fix-choice") if path.include?("/bulk-upload-resume/#{bulk_upload.id}/start") |
||||||
|
visit(path) |
||||||
|
expect(page).to have_current_path(path) |
||||||
|
expect(page).to be_axe_clean.according_to :wcag2aa |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
context "when viewing sales log pages" do |
||||||
|
let(:bulk_upload) { create(:bulk_upload, user:) } |
||||||
|
let(:sales_log) { create(:sales_log, :completed, assigned_to: other_user, bulk_upload_id: bulk_upload.id) } |
||||||
|
let(:organisation_relationship) { create(:organisation_relationship, parent_organisation: user.organisation) } |
||||||
|
|
||||||
|
let(:sales_log_paths) do |
||||||
|
all_page_ids = FormHandler.instance.sales_forms.values.flat_map(&:pages).map(&:id).uniq |
||||||
|
sales_log_pages = sales_log.form.pages |
||||||
|
other_form_page_ids = all_page_ids - sales_log_pages.map(&:id) |
||||||
|
|
||||||
|
routes = find_routes("sales-log", sales_log, bulk_upload) |
||||||
|
|
||||||
|
routes.reject { |path| |
||||||
|
path.include?("/edit") || path.include?("/new") || path.include?("*page") || |
||||||
|
path.include?("/sales-logs/bulk-upload-logs/#{bulk_upload.id}") || |
||||||
|
path.include?("bulk-upload-soft-validations-check") || path.include?("filters/update") || |
||||||
|
path == "/sales-logs/bulk-upload-resume/#{bulk_upload.id}" || |
||||||
|
path == "/sales-logs/bulk-upload-logs" || |
||||||
|
other_form_page_ids.any? { |page_id| path.include?(page_id.dasherize) } || |
||||||
|
sales_log_pages.any? { |page| path.include?(page.id.dasherize) && !page.routed_to?(sales_log, user) } |
||||||
|
}.uniq |
||||||
|
end |
||||||
|
|
||||||
|
it "is has accessible pages" do |
||||||
|
sales_log_paths.each do |path| |
||||||
|
path += "?original_log_id=#{sales_log.id}" if path.include?("duplicate") |
||||||
|
path += "?codes_only=true&years[]=2024" if path.include?("csv") |
||||||
|
path.gsub!("/start", "/prepare-your-file?form[year]=2024") if path.include?("bulk-upload-logs/start") |
||||||
|
path.gsub!("/start", "/fix-choice") if path.include?("/bulk-upload-resume/#{bulk_upload.id}/start") |
||||||
|
|
||||||
|
visit(path) |
||||||
|
expect(page).to have_current_path(path) |
||||||
|
expect(page).to be_axe_clean.according_to :wcag2aa |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
context "when viewing scheme pages" do |
||||||
|
let(:scheme) { create(:scheme, owning_organisation: other_user.organisation) } |
||||||
|
let!(:location) { create(:location, scheme:) } |
||||||
|
let(:scheme_paths) do |
||||||
|
routes = find_routes("scheme", scheme, location) |
||||||
|
|
||||||
|
routes.reject { |path| |
||||||
|
path.include?("/edit") || path.include?("/new") || path.include?("*page") || |
||||||
|
path.include?("reactivate") || path.include?("deactivate") |
||||||
|
}.uniq |
||||||
|
end |
||||||
|
|
||||||
|
before do |
||||||
|
allow(FormHandler.instance).to receive(:in_crossover_period?).and_return(true) |
||||||
|
end |
||||||
|
|
||||||
|
it "is has accessible pages" do |
||||||
|
scheme_paths.each do |path| |
||||||
|
visit(path) |
||||||
|
expect(page).to have_current_path(path) |
||||||
|
expect(page).to be_axe_clean.according_to :wcag2aa |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
context "when viewing other pages" do |
||||||
|
[{ path: "/", title: "homepage" }, |
||||||
|
{ path: "/guidance", title: "guidance" }, |
||||||
|
{ path: "/privacy-notice", title: "privacy notice" }, |
||||||
|
{ path: "/lettings-logs/bulk-upload-logs/guidance?form[year]=2024&referrer=home", title: "lettings BU guidance" }, |
||||||
|
{ path: "/sales-logs/bulk-upload-logs/guidance?form[year]=2024&referrer=home", title: "sales BU guidance" }].each do |test_case| |
||||||
|
it "is has accessible #{test_case[:title]} page" do |
||||||
|
visit(test_case[:path]) |
||||||
|
expect(page).to have_current_path(test_case[:path]) |
||||||
|
expect(page).to be_axe_clean.according_to :wcag2aa |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
end |
Loading…
Reference in new issue