|
|
|
require "rails_helper"
|
|
|
|
require_relative "helpers"
|
|
|
|
|
|
|
|
RSpec.describe "Form Page Routing" do
|
|
|
|
include Helpers
|
|
|
|
let(:user) { FactoryBot.create(:user) }
|
|
|
|
let(:case_log) do
|
|
|
|
FactoryBot.create(
|
|
|
|
:case_log,
|
|
|
|
:in_progress,
|
|
|
|
owning_organisation: user.organisation,
|
|
|
|
managing_organisation: user.organisation,
|
|
|
|
)
|
|
|
|
end
|
|
|
|
let(:id) { case_log.id }
|
|
|
|
let(:validator) { case_log._validators[nil].first }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(validator).to receive(:validate_pregnancy).and_return(true)
|
|
|
|
sign_in user
|
|
|
|
end
|
|
|
|
|
|
|
|
it "can route the user to a different page based on their answer on the current page", js: true do
|
|
|
|
visit("/logs/#{id}/conditional-question")
|
|
|
|
# using a question name that is already in the db to avoid
|
|
|
|
# having to add a new column to the db for this test
|
|
|
|
choose("case-log-preg-occ-1-field", allow_label_click: true)
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/conditional-question-yes-page")
|
|
|
|
click_link(text: "Back")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/conditional-question")
|
|
|
|
choose("case-log-preg-occ-2-field", allow_label_click: true)
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/conditional-question-no-page")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "can route based on multiple conditions", js: true do
|
|
|
|
visit("/logs/#{id}/person-1-gender")
|
|
|
|
choose("case-log-sex1-f-field", allow_label_click: true)
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/person-1-working-situation")
|
|
|
|
visit("/logs/#{id}/conditional-question")
|
|
|
|
choose("case-log-preg-occ-2-field", allow_label_click: true)
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/conditional-question-no-page")
|
|
|
|
choose("case-log-cbl-0-field", allow_label_click: true)
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/conditional-question/check-answers")
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the answers are inferred", js: true do
|
|
|
|
it "shows question if the answer could not be inferred" do
|
|
|
|
visit("/logs/#{id}/property-postcode")
|
|
|
|
fill_in("case-log-postcode-full-field", with: "PO5 3TE")
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/do-you-know-the-local-authority")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows question if the answer could not be inferred from an empty input" do
|
|
|
|
visit("/logs/#{id}/property-postcode")
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/do-you-know-the-local-authority")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not show question if the answer could be inferred" do
|
|
|
|
stub_request(:get, /api.postcodes.io/)
|
|
|
|
.to_return(status: 200, body: "{\"status\":200,\"result\":{\"admin_district\":\"Manchester\", \"codes\":{\"admin_district\": \"E08000003\"}}}", headers: {})
|
|
|
|
|
|
|
|
visit("/logs/#{id}/property-postcode")
|
|
|
|
fill_in("case-log-postcode-full-field", with: "P0 5ST")
|
|
|
|
click_button("Save and continue")
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/property-wheelchair-accessible")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when answer is invalid" do
|
|
|
|
it "shows error with invalid value in the field" do
|
|
|
|
visit("/logs/#{id}/property-postcode")
|
|
|
|
fill_in("case-log-postcode-full-field", with: "fake_postcode")
|
|
|
|
click_button("Save and continue")
|
|
|
|
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/property-postcode")
|
|
|
|
expect(find("#case-log-postcode-full-field-error").value).to eq("fake_postcode")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not reset the displayed date" do
|
|
|
|
case_log.update!(startdate: "2021/10/13")
|
|
|
|
visit("/logs/#{id}/tenancy-start-date")
|
|
|
|
fill_in("case_log[startdate(1i)]", with: "202")
|
|
|
|
fill_in("case_log[startdate(2i)]", with: "32")
|
|
|
|
fill_in("case_log[startdate(3i)]", with: "0")
|
|
|
|
click_button("Save and continue")
|
|
|
|
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/tenancy-start-date")
|
|
|
|
expect(find_field("case_log[startdate(3i)]").value).to eq("13")
|
|
|
|
expect(find_field("case_log[startdate(2i)]").value).to eq("10")
|
|
|
|
expect(find_field("case_log[startdate(1i)]").value).to eq("2021")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not reset the displayed date if it's empty" do
|
|
|
|
case_log.update!(startdate: nil)
|
|
|
|
visit("/logs/#{id}/tenancy-start-date")
|
|
|
|
fill_in("case_log[startdate(1i)]", with: "202")
|
|
|
|
fill_in("case_log[startdate(2i)]", with: "32")
|
|
|
|
fill_in("case_log[startdate(3i)]", with: "0")
|
|
|
|
click_button("Save and continue")
|
|
|
|
|
|
|
|
expect(page).to have_current_path("/logs/#{id}/tenancy-start-date")
|
|
|
|
expect(find_field("case_log[startdate(3i)]").value).to eq(nil)
|
|
|
|
expect(find_field("case_log[startdate(2i)]").value).to eq(nil)
|
|
|
|
expect(find_field("case_log[startdate(1i)]").value).to eq(nil)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|