Browse Source

CLDC-3844 Add rent type response (#2900)

* Update answer options for 2025

* Correctly derive variables from new rent type option

* Update missed test

* Remove git version from dockerfile
CLDC-3852-add-some-bu-docs
kosiakkatrina 7 days ago committed by GitHub
parent
commit
5b3c57481a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 3
      app/models/derived_variables/lettings_log_variables.rb
  2. 21
      app/models/form/lettings/questions/previous_let_type.rb
  3. 13
      app/models/form/lettings/questions/rent_type.rb
  4. 9
      app/models/lettings_log.rb
  5. 1
      spec/models/form/lettings/pages/rent_type_spec.rb
  6. 21
      spec/models/form/lettings/questions/previous_let_type_spec.rb
  7. 9
      spec/models/form/lettings/questions/rent_type_spec.rb
  8. 36
      spec/models/lettings_log_derived_fields_spec.rb

3
app/models/derived_variables/lettings_log_variables.rb

@ -8,6 +8,7 @@ module DerivedVariables::LettingsLogVariables
3 => 3, # "Rent to Buy" => "Intermediate Rent"
4 => 3, # "London Living Rent" => "Intermediate Rent"
5 => 3, # "Other intermediate rent product" => "Intermediate Rent"
6 => 4, # "Specified accommodation - exempt accommodation, managed properties, refuges and local authority hostels" => "Specified accommodation"
}.freeze
UNITLETAS_MAPPING = {
@ -17,6 +18,7 @@ module DerivedVariables::LettingsLogVariables
3 => 6, # "Rent to Buy" => "Rent to Buy basis"
4 => 7, # "London Living Rent" => "London Living Rent basis"
5 => 8, # "Other intermediate rent product" => "Another Intermediate Rent basis"
6 => 9, # "Specified accommodation - exempt accommodation, managed properties, refuges and local authority hostels" => "Specified accommodation - exempt accommodation, manged properties, refuges and local authority hostels"
}.freeze
RENTTYPE_DETAIL_MAPPING = {
@ -26,6 +28,7 @@ module DerivedVariables::LettingsLogVariables
3 => 4,
4 => 5,
5 => 6,
6 => 7,
}.freeze
def set_derived_fields!

21
app/models/form/lettings/questions/previous_let_type.rb

@ -4,7 +4,7 @@ class Form::Lettings::Questions::PreviousLetType < ::Form::Question
@id = "unitletas"
@type = "radio"
@check_answers_card_number = 0
@answer_options = form.start_year_2024_or_later? ? ANSWER_OPTIONS_AFTER_2024 : ANSWER_OPTIONS
@answer_options = answer_options
@question_number = QUESTION_NUMBER_FROM_YEAR[form.start_date.year] || QUESTION_NUMBER_FROM_YEAR[QUESTION_NUMBER_FROM_YEAR.keys.max]
end
@ -30,5 +30,24 @@ class Form::Lettings::Questions::PreviousLetType < ::Form::Question
"3" => { "value" => "Don’t know" },
}.freeze
ANSWER_OPTIONS_AFTER_2025 = {
"1" => { "value" => "Social rent basis" },
"2" => { "value" => "Affordable rent basis" },
"5" => { "value" => "London Affordable Rent basis" },
"6" => { "value" => "Rent to Buy basis" },
"7" => { "value" => "London Living Rent basis" },
"8" => { "value" => "Another Intermediate Rent basis" },
"9" => { "value" => "Specified accommodation - exempt accommodation, manged properties, refuges and local authority hostels" },
"divider" => { "value" => true },
"3" => { "value" => "Don’t know" },
}.freeze
QUESTION_NUMBER_FROM_YEAR = { 2023 => 16, 2024 => 17 }.freeze
def answer_options
return ANSWER_OPTIONS_AFTER_2025 if form.start_year_2025_or_later?
return ANSWER_OPTIONS_AFTER_2024 if form.start_year_2024_or_later?
ANSWER_OPTIONS
end
end

13
app/models/form/lettings/questions/rent_type.rb

@ -5,28 +5,33 @@ class Form::Lettings::Questions::RentType < ::Form::Question
@copy_key = "lettings.setup.rent_type.rent_type"
@type = "radio"
@top_guidance_partial = "rent_type_definitions"
@answer_options = form.start_year_2024_or_later? ? ANSWER_OPTIONS_2024 : ANSWER_OPTIONS
@answer_options = answer_options
@conditional_for = { "irproduct_other" => [5] }
@question_number = QUESTION_NUMBER_FROM_YEAR[form.start_date.year] || QUESTION_NUMBER_FROM_YEAR[QUESTION_NUMBER_FROM_YEAR.keys.max] if form.start_date.present?
end
ANSWER_OPTIONS = {
"0" => { "value" => "Social Rent" },
"1" => { "value" => "Affordable Rent" },
"2" => { "value" => "London Affordable Rent" },
"4" => { "value" => "London Living Rent" },
"3" => { "value" => "Rent to Buy" },
"0" => { "value" => "Social Rent" },
"4" => { "value" => "London Living Rent" },
"5" => { "value" => "Other intermediate rent product" },
}.freeze
ANSWER_OPTIONS_2024 = {
ANSWER_OPTIONS_2025 = {
"0" => { "value" => "Social Rent" },
"1" => { "value" => "Affordable Rent" },
"2" => { "value" => "London Affordable Rent" },
"3" => { "value" => "Rent to Buy" },
"4" => { "value" => "London Living Rent" },
"5" => { "value" => "Other intermediate rent product" },
"6" => { "value" => "Specified accommodation - exempt accommodation, managed properties, refuges and local authority hostels" },
}.freeze
QUESTION_NUMBER_FROM_YEAR = { 2023 => 6, 2024 => 8 }.freeze
def answer_options
form.start_year_2025_or_later? ? ANSWER_OPTIONS_2025 : ANSWER_OPTIONS
end
end

9
app/models/lettings_log.rb

@ -146,7 +146,7 @@ class LettingsLog < Log
AUTOGENERATED_FIELDS = %w[id status created_at updated_at discarded_at].freeze
OPTIONAL_FIELDS = %w[tenancycode propcode chcharge].freeze
RENT_TYPE_MAPPING_LABELS = { 1 => "Social Rent", 2 => "Affordable Rent", 3 => "Intermediate Rent" }.freeze
RENT_TYPE_MAPPING_LABELS = { 1 => "Social Rent", 2 => "Affordable Rent", 3 => "Intermediate Rent", 4 => "Specified accommodation" }.freeze
HAS_BENEFITS_OPTIONS = [1, 6, 8, 7].freeze
NUM_OF_WEEKS_FROM_PERIOD = { 2 => 26, 3 => 13, 4 => 12, 5 => 50, 6 => 49, 7 => 48, 8 => 47, 9 => 46, 1 => 52, 10 => 53 }.freeze
SUFFIX_FROM_PERIOD = { 2 => "every 2 weeks", 3 => "every 4 weeks", 4 => "every month" }.freeze
@ -158,6 +158,7 @@ class LettingsLog < Log
rent_to_buy: 3,
london_living_rent: 4,
other_intermediate_rent_product: 5,
specified_accommodation: 6,
}.freeze
def form
@ -830,6 +831,12 @@ private
elsif is_general_needs?
owning_organisation[:provider_type] == "PRP" ? 9 : 11
end
when "Specified accommodation"
if is_supported_housing?
owning_organisation[:provider_type] == "PRP" ? 14 : 16
elsif is_general_needs?
owning_organisation[:provider_type] == "PRP" ? 13 : 15
end
end
end

1
spec/models/form/lettings/pages/rent_type_spec.rb

@ -11,6 +11,7 @@ RSpec.describe Form::Lettings::Pages::RentType, type: :model do
before do
allow(subsection).to receive(:form).and_return(form)
allow(form).to receive(:start_year_2024_or_later?).and_return(true)
allow(form).to receive(:start_year_2025_or_later?).and_return(false)
end
it "has correct subsection" do

21
spec/models/form/lettings/questions/previous_let_type_spec.rb

@ -9,6 +9,7 @@ RSpec.describe Form::Lettings::Questions::PreviousLetType, type: :model do
before do
allow(form).to receive(:start_year_2024_or_later?).and_return(false)
allow(form).to receive(:start_year_2025_or_later?).and_return(false)
allow(page).to receive(:subsection).and_return(subsection)
allow(subsection).to receive(:form).and_return(form)
end
@ -60,4 +61,24 @@ RSpec.describe Form::Lettings::Questions::PreviousLetType, type: :model do
})
end
end
context "with collection year on or after 2025" do
before do
allow(form).to receive(:start_year_2025_or_later?).and_return(true)
end
it "has the correct answer options" do
expect(question.answer_options).to eq({
"1" => { "value" => "Social rent basis" },
"2" => { "value" => "Affordable rent basis" },
"5" => { "value" => "London Affordable Rent basis" },
"6" => { "value" => "Rent to Buy basis" },
"7" => { "value" => "London Living Rent basis" },
"8" => { "value" => "Another Intermediate Rent basis" },
"9" => { "value" => "Specified accommodation - exempt accommodation, manged properties, refuges and local authority hostels" },
"divider" => { "value" => true },
"3" => { "value" => "Don’t know" },
})
end
end
end

9
spec/models/form/lettings/questions/rent_type_spec.rb

@ -12,7 +12,7 @@ RSpec.describe Form::Lettings::Questions::RentType, type: :model do
before do
allow(page).to receive(:subsection).and_return(subsection)
allow(subsection).to receive(:form).and_return(form)
allow(form).to receive(:start_year_2024_or_later?).and_return(false)
allow(form).to receive(:start_year_2025_or_later?).and_return(false)
end
it "has correct page" do
@ -35,9 +35,9 @@ RSpec.describe Form::Lettings::Questions::RentType, type: :model do
expect(question.derived?(nil)).to be false
end
context "when 2023" do
context "when 2025" do
before do
allow(form).to receive(:start_year_2024_or_later?).and_return(false)
allow(form).to receive(:start_year_2025_or_later?).and_return(true)
end
it "has the correct answer_options" do
@ -48,6 +48,7 @@ RSpec.describe Form::Lettings::Questions::RentType, type: :model do
"3" => { "value" => "Rent to Buy" },
"0" => { "value" => "Social Rent" },
"5" => { "value" => "Other intermediate rent product" },
"6" => { "value" => "Specified accommodation - exempt accommodation, managed properties, refuges and local authority hostels" },
})
end
@ -58,7 +59,7 @@ RSpec.describe Form::Lettings::Questions::RentType, type: :model do
context "when 2024" do
before do
allow(form).to receive(:start_year_2024_or_later?).and_return(true)
allow(form).to receive(:start_year_2025_or_later?).and_return(false)
end
it "has the correct answer_options" do

36
spec/models/lettings_log_derived_fields_spec.rb

@ -187,6 +187,18 @@ RSpec.describe LettingsLog, type: :model do
needstype: 1,
expected_lettype: 1,
},
{
context: "when the rent type is Specified accommodation and supported housing",
rent_type: 6,
needstype: 2,
expected_lettype: 14,
},
{
context: "when the rent type is Specified accommodation and general needs housing",
rent_type: 6,
needstype: 1,
expected_lettype: 13,
},
].each do |test_case|
context test_case[:context] do
it "correctly derives lettype" do
@ -953,6 +965,11 @@ RSpec.describe LettingsLog, type: :model do
log.rent_type = 5
expect { log.set_derived_fields! }.to change(log, :renttype).to 3
end
it "when rent_type is Specified accommodation derives renttype as Specified accommodation" do
log.rent_type = 6
expect { log.set_derived_fields! }.to change(log, :renttype).to 4
end
end
describe "variables dependent on whether a letting is a renewal" do
@ -1168,6 +1185,25 @@ RSpec.describe LettingsLog, type: :model do
expect { persisted_renewal_lettings_log.update!(renewal: 0) }.to change(persisted_renewal_lettings_log, :unitletas).from(expected_unitletas).to nil
end
end
context "when rent_type is Specified accommodation " do
let(:rent_type) { 6 }
let(:expected_unitletas) { 9 }
before do
Timecop.freeze(Time.zone.local(2025, 5, 5))
end
it "derives the most recent let type as London Living Rent basis if it is a renewal" do
log.assign_attributes(renewal: 1, rent_type:)
expect { log.set_derived_fields! }.to change(log, :unitletas).to expected_unitletas
end
it "clears the most recent let type if it is not a renewal" do
expect { persisted_renewal_lettings_log.update!(renewal: 0) }.to change(persisted_renewal_lettings_log, :unitletas).from(expected_unitletas).to nil
end
end
end
end
end

Loading…
Cancel
Save