You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
456 lines
15 KiB
456 lines
15 KiB
3 months ago
|
require "rails_helper"
|
||
|
|
||
|
RSpec.describe CheckErrorsController, type: :request do
|
||
|
let(:page) { Capybara::Node::Simple.new(response.body) }
|
||
|
let(:user) { create(:user, :data_coordinator) }
|
||
|
let(:lettings_log) { create(:lettings_log, :setup_completed, assigned_to: user) }
|
||
|
let(:sales_log) { create(:sales_log, :shared_ownership_setup_complete, assigned_to: user) }
|
||
|
|
||
|
describe "check errors page" do
|
||
|
context "when user is not signed in" do
|
||
|
it "redirects to sign in page for lettings" do
|
||
|
post "/lettings-logs/#{lettings_log.id}/net-income", params: {}
|
||
|
expect(response).to redirect_to("/account/sign-in")
|
||
|
end
|
||
|
|
||
|
it "redirects to sign in page for sales" do
|
||
|
post "/sales-logs/#{sales_log.id}/buyer-1-income", params: {}
|
||
|
expect(response).to redirect_to("/account/sign-in")
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when the user is from different organisation" do
|
||
|
let(:other_user) { create(:user) }
|
||
|
|
||
|
before do
|
||
|
sign_in other_user
|
||
|
end
|
||
|
|
||
|
it "renders page not found for lettings" do
|
||
|
post "/lettings-logs/#{lettings_log.id}/net-income", params: {}
|
||
|
expect(response).to have_http_status(:not_found)
|
||
|
end
|
||
|
|
||
|
it "renders page not found for sales" do
|
||
|
post "/sales-logs/#{sales_log.id}/buyer-1-income", params: {}
|
||
|
expect(response).to have_http_status(:not_found)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when user is signed in" do
|
||
|
context "with multiple error fields and answered questions for lettings" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: lettings_log.id,
|
||
|
lettings_log: {
|
||
|
page: "income_amount",
|
||
|
earnings: "100000",
|
||
|
incfreq: "1",
|
||
|
},
|
||
|
check_errors: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
lettings_log.update!(needstype: 1, declaration: 1, ecstat1: 10, hhmemb: 2, net_income_known: 0, incfreq: nil, earnings: nil)
|
||
|
sign_in user
|
||
|
post "/lettings-logs/#{lettings_log.id}/income-amount", params: params
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_selector("input[type=submit][value='Clear']", count: 2)
|
||
|
expect(page).to have_button("Clear all")
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "with multiple error fields and answered questions for sales" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: sales_log.id,
|
||
|
sales_log: {
|
||
|
page: "buyer_1_income",
|
||
|
income1: "100000",
|
||
|
la: "E09000001",
|
||
|
ownershipsch: "1",
|
||
|
},
|
||
|
check_errors: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sales_log.update!(income1: 1000, la: "E09000001")
|
||
|
sign_in user
|
||
|
post "/sales-logs/#{sales_log.id}/buyer-1-income", params: params
|
||
|
end
|
||
|
|
||
|
it "displays correct clear and change links" do
|
||
|
expect(page.all(:button, value: "Clear").count).to eq(2)
|
||
|
expect(page).to have_link("Change", count: 1)
|
||
|
expect(page).to have_button("Clear all")
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe "confirm clear answer page" do
|
||
|
context "when user is not signed in" do
|
||
|
it "redirects to sign in page for lettings" do
|
||
|
post "/lettings-logs/#{lettings_log.id}/confirm-clear-answer", params: {}
|
||
|
expect(response).to redirect_to("/account/sign-in")
|
||
|
end
|
||
|
|
||
|
it "redirects to sign in page for sales" do
|
||
|
post "/sales-logs/#{sales_log.id}/confirm-clear-answer", params: {}
|
||
|
expect(response).to redirect_to("/account/sign-in")
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when the user is from different organisation" do
|
||
|
let(:other_user) { create(:user) }
|
||
|
|
||
|
before do
|
||
|
sign_in other_user
|
||
|
end
|
||
|
|
||
|
it "renders page not found for lettings" do
|
||
|
post "/lettings-logs/#{lettings_log.id}/confirm-clear-answer", params: {}
|
||
|
expect(response).to have_http_status(:not_found)
|
||
|
end
|
||
|
|
||
|
it "renders page not found for sales" do
|
||
|
post "/sales-logs/#{sales_log.id}/confirm-clear-answer", params: {}
|
||
|
expect(response).to have_http_status(:not_found)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when user is signed in" do
|
||
|
context "and clearing specific lettings question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: lettings_log.id,
|
||
|
lettings_log: {
|
||
|
earnings: "100000",
|
||
|
incfreq: "1",
|
||
|
hhmemb: "2",
|
||
|
page_id: "income_amount",
|
||
|
},
|
||
|
hhmemb: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/lettings-logs/#{lettings_log.id}/confirm-clear-answer", params:
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_content("Are you sure you want to clear Number of household members?")
|
||
|
expect(page).to have_content("Dependent answers related to this question may also get cleared. You will not be able to undo this action.")
|
||
|
expect(page).to have_link("Cancel")
|
||
|
expect(page).to have_button("Confirm and continue")
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and clearing specific sales question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: sales_log.id,
|
||
|
sales_log: {
|
||
|
income1: "100000",
|
||
|
la: "E09000001",
|
||
|
ownershipsch: "1",
|
||
|
page_id: "buyer_1_income",
|
||
|
},
|
||
|
income1: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/sales-logs/#{sales_log.id}/confirm-clear-answer", params:
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_content("Are you sure you want to clear Buyer 1’s gross annual income?")
|
||
|
expect(page).to have_content("Dependent answers related to this question may also get cleared. You will not be able to undo this action.")
|
||
|
expect(page).to have_link("Cancel")
|
||
|
expect(page).to have_button("Confirm and continue")
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe "confirm clear all answers" do
|
||
|
context "when user is signed in" do
|
||
|
context "and clearing all lettings questions" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: lettings_log.id,
|
||
|
clear_all: "Clear all",
|
||
|
lettings_log: {
|
||
|
earnings: "100000",
|
||
|
incfreq: "1",
|
||
|
hhmemb: "2",
|
||
|
page_id: "income_amount",
|
||
|
},
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/lettings-logs/#{lettings_log.id}/confirm-clear-answer", params:
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_content("Are you sure you want to clear all")
|
||
|
expect(page).to have_content("You've selected 5 answers to clear")
|
||
|
expect(page).to have_content("You will not be able to undo this action")
|
||
|
expect(page).to have_link("Cancel")
|
||
|
expect(page).to have_button("Confirm and continue")
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and clearing all sales question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: sales_log.id,
|
||
|
clear_all: "Clear all",
|
||
|
sales_log: {
|
||
|
income1: "100000",
|
||
|
la: "E09000001",
|
||
|
ownershipsch: "1",
|
||
|
page_id: "buyer_1_income",
|
||
|
},
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/sales-logs/#{sales_log.id}/confirm-clear-answer", params:
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_content("Are you sure you want to clear all")
|
||
|
expect(page).to have_content("You've selected 3 answers to clear")
|
||
|
expect(page).to have_content("You will not be able to undo this action")
|
||
|
expect(page).to have_link("Cancel")
|
||
|
expect(page).to have_button("Confirm and continue")
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe "clear answer" do
|
||
|
context "when user is not signed in" do
|
||
|
it "redirects to sign in page for lettings" do
|
||
|
post "/lettings-logs/#{lettings_log.id}/income-amount", params: {}
|
||
|
expect(response).to redirect_to("/account/sign-in")
|
||
|
end
|
||
|
|
||
|
it "redirects to sign in page for sales" do
|
||
|
post "/sales-logs/#{sales_log.id}/buyer-1-income", params: {}
|
||
|
expect(response).to redirect_to("/account/sign-in")
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when the user is from different organisation" do
|
||
|
let(:other_user) { create(:user) }
|
||
|
|
||
|
before do
|
||
|
sign_in other_user
|
||
|
end
|
||
|
|
||
|
it "renders page not found for lettings" do
|
||
|
post "/lettings-logs/#{lettings_log.id}/income-amount", params: {}
|
||
|
expect(response).to have_http_status(:not_found)
|
||
|
end
|
||
|
|
||
|
it "renders page not found for sales" do
|
||
|
post "/sales-logs/#{lettings_log.id}/buyer-1-income", params: {}
|
||
|
expect(response).to have_http_status(:not_found)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when user is signed in" do
|
||
|
context "and clearing specific lettings question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: lettings_log.id,
|
||
|
lettings_log: {
|
||
|
earnings: "100000",
|
||
|
incfreq: "1",
|
||
|
hhmemb: "2",
|
||
|
clear_question_ids: "hhmemb",
|
||
|
page: "income_amount",
|
||
|
},
|
||
|
check_errors: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/lettings-logs/#{lettings_log.id}/income-amount", params:
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_content("Make sure these answers are correct")
|
||
|
expect(page).to have_content("You didn’t answer this question")
|
||
|
expect(page).to have_link("Answer")
|
||
|
expect(lettings_log.reload.earnings).to eq(nil)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and clearing specific sales question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: sales_log.id,
|
||
|
sales_log: {
|
||
|
income1: "100000",
|
||
|
la: "E09000001",
|
||
|
ownershipsch: "1",
|
||
|
clear_question_ids: "income1",
|
||
|
page: "buyer_1_income",
|
||
|
},
|
||
|
check_errors: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/sales-logs/#{sales_log.id}/buyer-1-income", params:
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_content("Make sure these answers are correct")
|
||
|
expect(page).to have_content("You didn’t answer this question")
|
||
|
expect(page).to have_link("Answer")
|
||
|
expect(sales_log.reload.income1).to eq(nil)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe "answer incomplete question" do
|
||
|
context "when user is signed in" do
|
||
|
context "and answering specific lettings question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
original_page_id: "household_members",
|
||
|
referrer: "check_errors",
|
||
|
related_question_ids: %w[hhmemb ecstat1 earnings],
|
||
|
lettings_log: {
|
||
|
page: "household_members",
|
||
|
hhmemb: "2",
|
||
|
},
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/lettings-logs/#{lettings_log.id}/household-members", params:
|
||
|
end
|
||
|
|
||
|
it "maintains original check_errors data in query params" do
|
||
|
follow_redirect!
|
||
|
expect(request.query_parameters["check_errors"]).to eq("true")
|
||
|
expect(request.query_parameters["related_question_ids"]).to eq(%w[hhmemb ecstat1 earnings])
|
||
|
expect(page).to have_content("You have successfully updated Number of household members")
|
||
|
expect(page).to have_link("Confirm and continue", href: "/lettings-logs/#{lettings_log.id}/household-members")
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and answering specific sales question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
original_page_id: "buyer_1_income",
|
||
|
referrer: "check_errors",
|
||
|
related_question_ids: %w[income1 la ownershipsch],
|
||
|
sales_log: {
|
||
|
page: "buyer_1_income",
|
||
|
income1: "1000",
|
||
|
income1nk: "0",
|
||
|
},
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/sales-logs/#{sales_log.id}/buyer-1-income", params:
|
||
|
end
|
||
|
|
||
|
it "maintains original check_errors data in query params" do
|
||
|
follow_redirect!
|
||
|
expect(request.query_parameters["check_errors"]).to eq("true")
|
||
|
expect(request.query_parameters["related_question_ids"]).to eq(%w[income1 la ownershipsch])
|
||
|
expect(page).to have_content("You have successfully updated Buyer 1’s gross annual income known? and Buyer 1’s gross annual income")
|
||
|
expect(page).to have_link("Confirm and continue", href: "/sales-logs/#{sales_log.id}/buyer-1-income")
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe "clear all answers" do
|
||
|
context "when user is signed in" do
|
||
|
context "and clearing all lettings question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: lettings_log.id,
|
||
|
lettings_log: {
|
||
|
earnings: "100000",
|
||
|
incfreq: "1",
|
||
|
hhmemb: "2",
|
||
|
clear_question_ids: "earnings incfreq hhmemb",
|
||
|
page: "income_amount",
|
||
|
},
|
||
|
check_errors: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/lettings-logs/#{lettings_log.id}/income-amount", params:
|
||
|
end
|
||
|
|
||
|
it "correctly clears the values" do
|
||
|
expect(page).to have_content("Make sure these answers are correct")
|
||
|
expect(page).to have_content("You didn’t answer this question")
|
||
|
expect(page.all(:button, value: "Clear").count).to eq(0)
|
||
|
expect(lettings_log.reload.earnings).to eq(nil)
|
||
|
expect(lettings_log.reload.incfreq).to eq(nil)
|
||
|
expect(lettings_log.reload.hhmemb).to eq(nil)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and clearing all sales question" do
|
||
|
let(:params) do
|
||
|
{
|
||
|
id: sales_log.id,
|
||
|
sales_log: {
|
||
|
income1: "100000",
|
||
|
la: "E09000001",
|
||
|
ownershipsch: "1",
|
||
|
clear_question_ids: "income1 la ownershipsch",
|
||
|
page: "buyer_1_income",
|
||
|
},
|
||
|
check_errors: "",
|
||
|
}
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
sign_in user
|
||
|
post "/sales-logs/#{sales_log.id}/buyer-1-income", params:
|
||
|
end
|
||
|
|
||
|
it "displays correct clear links" do
|
||
|
expect(page).to have_content("Make sure these answers are correct")
|
||
|
expect(page).to have_content("You didn’t answer this question")
|
||
|
expect(page.all(:button, value: "Clear").count).to eq(0)
|
||
|
expect(sales_log.reload.income1).to eq(nil)
|
||
|
expect(sales_log.reload.la).to eq(nil)
|
||
|
expect(sales_log.reload.ownershipsch).not_to eq(nil)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|