Browse Source

Cldc 3492 oustide rent range soft validation not clearing for bedsit (#2473)

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

* delete spec file not testing anything worthwhile
pull/2475/head
Arthur Campbell 6 months ago committed by GitHub
parent
commit
d95e08cca2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 4
      app/models/form/lettings/questions/beds.rb
  2. 33
      spec/models/form/lettings/pages/property_number_of_bedrooms_spec.rb
  3. 78
      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

33
spec/models/form/lettings/pages/property_number_of_bedrooms_spec.rb

@ -1,33 +0,0 @@
require "rails_helper"
RSpec.describe Form::Lettings::Pages::PropertyNumberOfBedrooms, 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, form: instance_double(Form, start_date: Time.zone.local(2024, 4, 1))) }
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[beds])
end
it "has the correct id" do
expect(page.id).to eq("property_number_of_bedrooms")
end
it "has the correct header" do
expect(page.header).to be_nil
end
it "has the correct description" do
expect(page.description).to be_nil
end
it "has the correct depends_on" do
expect(page.depends_on).to eq([{ "is_general_needs?" => true, "is_beds_inferred?" => false }])
end
end

78
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)) }
before do describe "the hint text" do
allow(form).to receive(:start_year_after_2024?).and_return(false) context "when the start date is before 24/25" do
allow(page).to receive(:subsection).and_return(subsection) before do
allow(subsection).to receive(:form).and_return(form) allow(form).to receive(:start_year_after_2024?).and_return false
end end
it "has correct page" do
expect(question.page).to eq(page)
end
it "has the correct id" do
expect(question.id).to eq("beds")
end
it "has the correct header" do
expect(question.header).to eq("How many bedrooms does the property have?")
end
it "has the correct check_answer_label" do
expect(question.check_answer_label).to eq("Number of bedrooms")
end
it "has the correct type" do it "has the correct hint_text" do
expect(question.type).to eq("numeric") 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
it "is not marked as derived" do context "when the start date is 24/25 or after" do
expect(question.derived?(nil)).to be false before do
end allow(form).to receive(:start_year_after_2024?).and_return true
end
it "has the correct min" do it "has the correct hint_text" do
expect(question.min).to eq(1) expect(question.hint_text).to eq("If shared accommodation, enter the number of bedrooms occupied by this household.")
end
end
end end
it "has the correct max" do describe "whether the field is derived" do
expect(question.max).to eq(12) context "when the log is a bedsit" do
end let(:log) { build(:lettings_log, unittype_gn: 2) }
context "with 2023/24 form" do it "is not marked as derived" do
it "has the correct hint_text" do expect(question.derived?(log)).to be true
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