Browse Source

Add mortgage value check page

pull/1079/head
Kat 4 years ago
parent
commit
29d7501831
  1. 21
      app/models/form/sales/pages/mortgage_value_check.rb
  2. 25
      app/models/form/sales/questions/mortgage_value_check.rb
  3. 1
      app/models/form/sales/subsections/income_benefits_and_savings.rb
  4. 4
      app/models/validations/sales/soft_validations.rb
  5. 2
      spec/factories/sales_log.rb
  6. 33
      spec/models/form/sales/pages/mortgage_value_check_spec.rb
  7. 61
      spec/models/form/sales/questions/mortgage_value_check_spec.rb
  8. 1
      spec/models/form/sales/subsections/income_benefits_and_savings_spec.rb
  9. 4
      spec/models/form_handler_spec.rb

21
app/models/form/sales/pages/mortgage_value_check.rb

@ -0,0 +1,21 @@
class Form::Sales::Pages::MortgageValueCheck < ::Form::Page
def initialize(id, hsh, subsection)
super
@id = "mortgage_value_check"
@header = ""
@description = ""
@subsection = subsection
@depends_on = [
{
"mortgage_over_soft_max?" => true,
},
]
@informative_text = {}
end
def questions
@questions ||= [
Form::Sales::Questions::MortgageValueCheck.new(nil, nil, self),
]
end
end

25
app/models/form/sales/questions/mortgage_value_check.rb

@ -0,0 +1,25 @@
class Form::Sales::Questions::MortgageValueCheck < ::Form::Question
def initialize(id, hsh, page)
super
@id = "mortgage_value_check"
@check_answer_label = "Mortgage confirmation"
@header = "Are you sure that the mortgage is more than 5 times the income used for the mortgage application?"
@type = "interruption_screen"
@answer_options = {
"0" => { "value" => "Yes" },
"1" => { "value" => "No" },
}
@hidden_in_check_answers = {
"depends_on" => [
{
"mortgage_value_check" => 0,
},
{
"mortgage_value_check" => 1,
},
],
}
@check_answers_card_number = 1
@page = page
end
end

1
app/models/form/sales/subsections/income_benefits_and_savings.rb

@ -13,6 +13,7 @@ class Form::Sales::Subsections::IncomeBenefitsAndSavings < ::Form::Subsection
Form::Sales::Pages::Buyer1IncomeValueCheck.new(nil, nil, self), Form::Sales::Pages::Buyer1IncomeValueCheck.new(nil, nil, self),
Form::Sales::Pages::Buyer1Mortgage.new(nil, nil, self), Form::Sales::Pages::Buyer1Mortgage.new(nil, nil, self),
Form::Sales::Pages::Buyer2Income.new(nil, nil, self), Form::Sales::Pages::Buyer2Income.new(nil, nil, self),
Form::Sales::Pages::MortgageValueCheck.new(nil, nil, self),
Form::Sales::Pages::Savings.new(nil, nil, self), Form::Sales::Pages::Savings.new(nil, nil, self),
Form::Sales::Pages::PreviousOwnership.new(nil, nil, self), Form::Sales::Pages::PreviousOwnership.new(nil, nil, self),
] ]

4
app/models/validations/sales/soft_validations.rb

@ -12,4 +12,8 @@ module Validations::Sales::SoftValidations
income1 < ALLOWED_INCOME_RANGES[ecstat1][:soft_min] income1 < ALLOWED_INCOME_RANGES[ecstat1][:soft_min]
end end
def mortgage_over_soft_max?
true
end
end end

2
spec/factories/sales_log.rb

@ -56,11 +56,13 @@ FactoryBot.define do
inc1mort { 1 } inc1mort { 1 }
income2nk { 0 } income2nk { 0 }
income2 { 10_000 } income2 { 10_000 }
inc2mort { 1 }
la_known { "1" } la_known { "1" }
la { "E09000003" } la { "E09000003" }
savingsnk { 1 } savingsnk { 1 }
prevown { 1 } prevown { 1 }
sex3 { "X" } sex3 { "X" }
mortgage { 20_000 }
end end
end end
end end

33
spec/models/form/sales/pages/mortgage_value_check_spec.rb

@ -0,0 +1,33 @@
require "rails_helper"
RSpec.describe Form::Sales::Pages::MortgageValueCheck, type: :model do
subject(:page) { described_class.new(page_id, page_definition, subsection) }
let(:page_id) { nil }
let(:page_definition) { nil }
let(:subsection) { instance_double(Form::Subsection) }
it "has correct subsection" do
expect(page.subsection).to eq(subsection)
end
it "has correct questions" do
expect(page.questions.map(&:id)).to eq(%w[mortgage_value_check])
end
it "has the correct id" do
expect(page.id).to eq("mortgage_value_check")
end
it "has the correct header" do
expect(page.header).to eq("")
end
it "has correct depends_on" do
expect(page.depends_on).to eq([
{
"mortgage_over_soft_max?" => true,
},
])
end
end

61
spec/models/form/sales/questions/mortgage_value_check_spec.rb

@ -0,0 +1,61 @@
require "rails_helper"
RSpec.describe Form::Sales::Questions::MortgageValueCheck, type: :model do
subject(:question) { described_class.new(question_id, question_definition, page) }
let(:question_id) { nil }
let(:question_definition) { nil }
let(:page) { instance_double(Form::Page) }
it "has correct page" do
expect(question.page).to eq(page)
end
it "has the correct id" do
expect(question.id).to eq("mortgage_value_check")
end
it "has the correct header" do
expect(question.header).to eq("Are you sure that the mortgage is more than 5 times the income used for the mortgage application?")
end
it "has the correct check_answer_label" do
expect(question.check_answer_label).to eq("Mortgage confirmation")
end
it "has the correct type" do
expect(question.type).to eq("interruption_screen")
end
it "is not marked as derived" do
expect(question.derived?).to be false
end
it "has the correct hint" do
expect(question.hint_text).to be_nil
end
it "has a correct check_answers_card_number" do
expect(question.check_answers_card_number).to eq(1)
end
it "has the correct answer_options" do
expect(question.answer_options).to eq({
"0" => { "value" => "Yes" },
"1" => { "value" => "No" },
})
end
it "has the correct hidden_in_check_answers" do
expect(question.hidden_in_check_answers).to eq({
"depends_on" => [
{
"mortgage_value_check" => 0,
},
{
"mortgage_value_check" => 1,
},
],
})
end
end

1
spec/models/form/sales/subsections/income_benefits_and_savings_spec.rb

@ -18,6 +18,7 @@ RSpec.describe Form::Sales::Subsections::IncomeBenefitsAndSavings, type: :model
buyer_1_income_value_check buyer_1_income_value_check
buyer_1_mortgage buyer_1_mortgage
buyer_2_income buyer_2_income
mortgage_value_check
savings savings
previous_ownership previous_ownership
], ],

4
spec/models/form_handler_spec.rb

@ -52,14 +52,14 @@ RSpec.describe FormHandler do
it "is able to load a current sales form" do it "is able to load a current sales form" do
form = form_handler.get_form("current_sales") form = form_handler.get_form("current_sales")
expect(form).to be_a(Form) expect(form).to be_a(Form)
expect(form.pages.count).to eq(52) expect(form.pages.count).to eq(53)
expect(form.name).to eq("2022_2023_sales") expect(form.name).to eq("2022_2023_sales")
end end
it "is able to load a previous sales form" do it "is able to load a previous sales form" do
form = form_handler.get_form("previous_sales") form = form_handler.get_form("previous_sales")
expect(form).to be_a(Form) expect(form).to be_a(Form)
expect(form.pages.count).to eq(52) expect(form.pages.count).to eq(53)
expect(form.name).to eq("2021_2022_sales") expect(form.name).to eq("2021_2022_sales")
end end
end end

Loading…
Cancel
Save