Browse Source

feat: update answers and hint for 24/25 and test

pull/2199/head
natdeanlewissoftwire 2 years ago
parent
commit
34515fb999
  1. 27
      app/models/form/lettings/questions/ethnic_white.rb
  2. 27
      app/models/form/sales/questions/buyer1_ethnic_background_white.rb
  3. 80
      spec/models/form/lettings/questions/ethnic_white_spec.rb
  4. 48
      spec/models/form/sales/questions/buyer1_ethnic_background_white_spec.rb

27
app/models/form/lettings/questions/ethnic_white.rb

@ -6,15 +6,26 @@ class Form::Lettings::Questions::EthnicWhite < ::Form::Question
@header = "Which of the following best describes the lead tenant’s White background?" @header = "Which of the following best describes the lead tenant’s White background?"
@type = "radio" @type = "radio"
@check_answers_card_number = 1 @check_answers_card_number = 1
@hint_text = "The lead tenant is the person in the household who does the most paid work. If several people do the same paid work, the lead tenant is whoever is the oldest." @hint_text = form.start_year_after_2024? ? "" : "The lead tenant is the person in the household who does the most paid work. If several people do the same paid work, the lead tenant is whoever is the oldest."
@answer_options = ANSWER_OPTIONS
@question_number = 35 @question_number = 35
end end
ANSWER_OPTIONS = { def answer_options
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" }, if form.start_year_after_2024?
"2" => { "value" => "Irish" }, {
"18" => { "value" => "Gypsy or Irish Traveller" }, "1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"3" => { "value" => "Any other White background" }, "2" => { "value" => "Irish" },
}.freeze "18" => { "value" => "Gypsy or Irish Traveller" },
"20" => { "value" => "Roma" },
"3" => { "value" => "Any other White background" },
}.freeze
else
{
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"2" => { "value" => "Irish" },
"18" => { "value" => "Gypsy or Irish Traveller" },
"3" => { "value" => "Any other White background" },
}.freeze
end
end
end end

27
app/models/form/sales/questions/buyer1_ethnic_background_white.rb

@ -5,16 +5,27 @@ class Form::Sales::Questions::Buyer1EthnicBackgroundWhite < ::Form::Question
@check_answer_label = "Buyer 1’s ethnic background" @check_answer_label = "Buyer 1’s ethnic background"
@header = "Which of the following best describes buyer 1’s White background?" @header = "Which of the following best describes buyer 1’s White background?"
@type = "radio" @type = "radio"
@answer_options = ANSWER_OPTIONS @hint_text = form.start_year_after_2024? ? "" : "Buyer 1 is the person in the household who does the most paid work. If it’s a joint purchase and the buyers do the same amount of paid work, buyer 1 is whoever is the oldest."
@hint_text = "Buyer 1 is the person in the household who does the most paid work. If it’s a joint purchase and the buyers do the same amount of paid work, buyer 1 is whoever is the oldest."
@check_answers_card_number = 1 @check_answers_card_number = 1
@question_number = 23 @question_number = 23
end end
ANSWER_OPTIONS = { def answer_options
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" }, if form.start_year_after_2024?
"2" => { "value" => "Irish" }, {
"18" => { "value" => "Gypsy or Irish Traveller" }, "1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"3" => { "value" => "Any other White background" }, "2" => { "value" => "Irish" },
}.freeze "18" => { "value" => "Gypsy or Irish Traveller" },
"20" => { "value" => "Roma" },
"3" => { "value" => "Any other White background" },
}.freeze
else
{
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"2" => { "value" => "Irish" },
"18" => { "value" => "Gypsy or Irish Traveller" },
"3" => { "value" => "Any other White background" },
}.freeze
end
end
end end

80
spec/models/form/lettings/questions/ethnic_white_spec.rb

@ -0,0 +1,80 @@
require "rails_helper"
RSpec.describe Form::Lettings::Questions::EthnicWhite, 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) }
let(:subsection) { instance_double(Form::Subsection) }
let(:form) { instance_double(Form) }
before do
allow(form).to receive(:start_year_after_2024?).and_return(false)
allow(page).to receive(:subsection).and_return(subsection)
allow(subsection).to receive(:form).and_return(form)
end
it "has correct page" do
expect(question.page).to eq(page)
end
it "has the correct id" do
expect(question.id).to eq("ethnic")
end
it "has the correct header" do
expect(question.header).to eq("Which of the following best describes the lead tenant’s White background?")
end
it "has the correct check_answer_label" do
expect(question.check_answer_label).to eq("Lead tenant’s ethnic background")
end
it "has the correct type" do
expect(question.type).to eq("radio")
end
it "is not marked as derived" do
expect(question.derived?).to be false
end
context "with 2023/24 form" do
it "has the correct answer_options" do
expect(question.answer_options).to eq({
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"2" => { "value" => "Irish" },
"18" => { "value" => "Gypsy or Irish Traveller" },
"3" => { "value" => "Any other White background" },
})
end
it "has the correct hint_text" do
expect(question.hint_text).to eq("The lead tenant is the person in the household who does the most paid work. If several people do the same paid work, the lead tenant is whoever is the oldest.")
end
end
context "with 2024/25 form" do
before do
allow(form).to receive(:start_year_after_2024?).and_return(true)
end
it "has the correct answer_options" do
expect(question.answer_options).to eq({
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"2" => { "value" => "Irish" },
"18" => { "value" => "Gypsy or Irish Traveller" },
"20" => { "value" => "Roma" },
"3" => { "value" => "Any other White background" },
})
end
it "has the correct hint_text" do
expect(question.hint_text).to eq("")
end
end
it "has the correct check_answers_card_number" do
expect(question.check_answers_card_number).to eq(1)
end
end

48
spec/models/form/sales/questions/buyer1_ethnic_background_white_spec.rb

@ -6,6 +6,14 @@ RSpec.describe Form::Sales::Questions::Buyer1EthnicBackgroundWhite, type: :model
let(:question_id) { nil } let(:question_id) { nil }
let(:question_definition) { nil } let(:question_definition) { nil }
let(:page) { instance_double(Form::Page) } let(:page) { instance_double(Form::Page) }
let(:subsection) { instance_double(Form::Subsection) }
let(:form) { instance_double(Form) }
before do
allow(form).to receive(:start_year_after_2024?).and_return(false)
allow(page).to receive(:subsection).and_return(subsection)
allow(subsection).to receive(:form).and_return(form)
end
it "has correct page" do it "has correct page" do
expect(question.page).to eq(page) expect(question.page).to eq(page)
@ -31,17 +39,39 @@ RSpec.describe Form::Sales::Questions::Buyer1EthnicBackgroundWhite, type: :model
expect(question.derived?).to be false expect(question.derived?).to be false
end end
it "has the correct hint_text" do context "with 2023/24 form" do
expect(question.hint_text).to eq("Buyer 1 is the person in the household who does the most paid work. If it’s a joint purchase and the buyers do the same amount of paid work, buyer 1 is whoever is the oldest.") it "has the correct answer_options" do
expect(question.answer_options).to eq({
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"2" => { "value" => "Irish" },
"18" => { "value" => "Gypsy or Irish Traveller" },
"3" => { "value" => "Any other White background" },
})
end
it "has the correct hint_text" do
expect(question.hint_text).to eq("Buyer 1 is the person in the household who does the most paid work. If it’s a joint purchase and the buyers do the same amount of paid work, buyer 1 is whoever is the oldest.")
end
end end
it "has the correct answer_options" do context "with 2024/25 form" do
expect(question.answer_options).to eq({ before do
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" }, allow(form).to receive(:start_year_after_2024?).and_return(true)
"18" => { "value" => "Gypsy or Irish Traveller" }, end
"2" => { "value" => "Irish" },
"3" => { "value" => "Any other White background" }, it "has the correct answer_options" do
}) expect(question.answer_options).to eq({
"1" => { "value" => "English, Welsh, Northern Irish, Scottish or British" },
"2" => { "value" => "Irish" },
"18" => { "value" => "Gypsy or Irish Traveller" },
"20" => { "value" => "Roma" },
"3" => { "value" => "Any other White background" },
})
end
it "has the correct hint_text" do
expect(question.hint_text).to eq("")
end
end end
it "has the correct check_answers_card_number" do it "has the correct check_answers_card_number" do

Loading…
Cancel
Save