Browse Source

mark the beds question as derived when the log is a bedsit to stop it from being cleared

pull/2473/head
Arthur Campbell 2 years ago
parent
commit
5dc17264a5
  1. 4
      app/models/form/lettings/questions/beds.rb
  2. 62
      spec/models/form/lettings/questions/beds_spec.rb

4
app/models/form/lettings/questions/beds.rb

@ -13,6 +13,10 @@ class Form::Lettings::Questions::Beds < ::Form::Question
@question_number = QUESTION_NUMBER_FROM_YEAR[form.start_date.year] || QUESTION_NUMBER_FROM_YEAR[QUESTION_NUMBER_FROM_YEAR.keys.max] @question_number = QUESTION_NUMBER_FROM_YEAR[form.start_date.year] || QUESTION_NUMBER_FROM_YEAR[QUESTION_NUMBER_FROM_YEAR.keys.max]
end end
def derived?(log)
log.is_bedsit?
end
def hint_text def hint_text
form.start_year_after_2024? ? "If shared accommodation, enter the number of bedrooms occupied by this household." : "If shared accommodation, enter the number of bedrooms occupied by this household. A bedsit has 1 bedroom." form.start_year_after_2024? ? "If shared accommodation, enter the number of bedrooms occupied by this household." : "If shared accommodation, enter the number of bedrooms occupied by this household. A bedsit has 1 bedroom."
end end

62
spec/models/form/lettings/questions/beds_spec.rb

@ -1,65 +1,49 @@
require "rails_helper" require "rails_helper"
RSpec.describe Form::Lettings::Questions::Beds, type: :model do RSpec.describe Form::Lettings::Questions::Beds, type: :model do
subject(:question) { described_class.new(question_id, question_definition, page) } subject(:question) { described_class.new(nil, nil, page) }
let(:question_id) { nil } let(:page) { instance_double(Form::Page, subsection:) }
let(:question_definition) { nil } let(:subsection) { instance_double(Form::Subsection, form:) }
let(:page) { instance_double(Form::Page) }
let(:subsection) { instance_double(Form::Subsection) }
let(:form) { instance_double(Form, start_date: Time.zone.local(2023, 4, 1)) } let(:form) { instance_double(Form, start_date: Time.zone.local(2023, 4, 1)) }
describe "the hint text" do
context "when the start date is before 24/25" do
before do before do
allow(form).to receive(:start_year_after_2024?).and_return(false) 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 end
it "has correct page" do it "has the correct hint_text" do
expect(question.page).to eq(page) expect(question.hint_text).to eq("If shared accommodation, enter the number of bedrooms occupied by this household. A bedsit has 1 bedroom.")
end end
it "has the correct id" do
expect(question.id).to eq("beds")
end end
it "has the correct header" do context "when the start date is 24/25 or after" do
expect(question.header).to eq("How many bedrooms does the property have?") before do
allow(form).to receive(:start_year_after_2024?).and_return true
end end
it "has the correct check_answer_label" do it "has the correct hint_text" do
expect(question.check_answer_label).to eq("Number of bedrooms") expect(question.hint_text).to eq("If shared accommodation, enter the number of bedrooms occupied by this household.")
end end
it "has the correct type" do
expect(question.type).to eq("numeric")
end end
it "is not marked as derived" do
expect(question.derived?(nil)).to be false
end end
it "has the correct min" do describe "whether the field is derived" do
expect(question.min).to eq(1) context "when the log is a bedsit" do
end let(:log) { build(:lettings_log, unittype_gn: 2) }
it "has the correct max" do it "is not marked as derived" do
expect(question.max).to eq(12) expect(question.derived?(log)).to be true
end
context "with 2023/24 form" do
it "has the correct hint_text" do
expect(question.hint_text).to eq("If shared accommodation, enter the number of bedrooms occupied by this household. A bedsit has 1 bedroom.")
end end
end end
context "with 2024/25 form" do context "when the log is not a bedsit" do
before do let(:log) { build(:lettings_log, unittype_gn: 9) }
allow(form).to receive(:start_year_after_2024?).and_return(true)
end
it "has the correct hint_text" do it "is not marked as derived" do
expect(question.hint_text).to eq("If shared accommodation, enter the number of bedrooms occupied by this household.") expect(question.derived?(log)).to be false
end
end end
end end
end end

Loading…
Cancel
Save