Browse Source

CLDC-1224: Tenancy type and tenancy length (#578)

* Fix value mapping for tenancy type 22/23

* Update secure helper

* Null safe

* Spec update

* Update mandatory

* Use helper
pull/619/head
baarkerlounger 3 years ago committed by baarkerlounger
parent
commit
9f738b53e5
  1. 29
      app/models/case_log.rb
  2. 9
      config/forms/2022_2023.json
  3. 148
      spec/models/validations/tenancy_validations_spec.rb
  4. 3
      spec/requests/case_logs_controller_spec.rb

29
app/models/case_log.rb

@ -191,9 +191,20 @@ class CaseLog < ApplicationRecord
tshortfall_known == 1 tshortfall_known == 1
end end
def is_fixed_term_tenancy?
[4, 6].include?(tenancy)
end
def is_secure_tenancy? def is_secure_tenancy?
return unless collection_start_year
# 1: Secure (including flexible) # 1: Secure (including flexible)
tenancy == 1 if collection_start_year < 2022
tenancy == 1
else
# 6: Secure - fixed term, 7: Secure - lifetime
[6, 7].include?(tenancy)
end
end end
def is_assured_shorthold_tenancy? def is_assured_shorthold_tenancy?
@ -461,9 +472,19 @@ private
end end
def dynamically_not_required def dynamically_not_required
previous_la_known_field = postcode_known? ? %w[previous_la_known] : [] not_required = []
tshortfall_field = tshortfall_unknown? ? %w[tshortfall] : [] not_required << "previous_la_known" if postcode_known?
previous_la_known_field + tshortfall_field not_required << "tshortfall" if tshortfall_unknown?
not_required << "tenancylength" if tenancylength_optional?
not_required
end
def tenancylength_optional?
return false unless collection_start_year
return true if collection_start_year < 2022
collection_start_year >= 2022 && !is_fixed_term_tenancy?
end end
def set_derived_fields! def set_derived_fields!

9
config/forms/2022_2023.json

@ -994,7 +994,7 @@
"hint_text": "", "hint_text": "",
"type": "radio", "type": "radio",
"answer_options": { "answer_options": {
"1": { "4": {
"value": "Assured Shorthold Tenancy (AST) - Fixed term" "value": "Assured Shorthold Tenancy (AST) - Fixed term"
}, },
"6": { "6": {
@ -1041,7 +1041,7 @@
"hint_text": "This is also known as an ‘introductory period’.", "hint_text": "This is also known as an ‘introductory period’.",
"type": "radio", "type": "radio",
"answer_options": { "answer_options": {
"1": { "4": {
"value": "Assured Shorthold Tenancy (AST) - Fixed term" "value": "Assured Shorthold Tenancy (AST) - Fixed term"
}, },
"6": { "6": {
@ -1095,10 +1095,13 @@
}, },
"depends_on": [ "depends_on": [
{ {
"tenancy": 1 "tenancy": 4
}, },
{ {
"tenancy": 6 "tenancy": 6
},
{
"tenancy": 3
} }
] ]
}, },

148
spec/models/validations/tenancy_validations_spec.rb

@ -4,7 +4,7 @@ RSpec.describe Validations::TenancyValidations do
subject(:tenancy_validator) { validator_class.new } subject(:tenancy_validator) { validator_class.new }
let(:validator_class) { Class.new { include Validations::TenancyValidations } } let(:validator_class) { Class.new { include Validations::TenancyValidations } }
let(:record) { FactoryBot.create(:case_log) } let(:record) { FactoryBot.create(:case_log, startdate: Time.zone.local(2021, 5, 1)) }
describe "fixed term tenancy validations" do describe "fixed term tenancy validations" do
context "when fixed term tenancy" do context "when fixed term tenancy" do
@ -62,44 +62,134 @@ RSpec.describe Validations::TenancyValidations do
end end
end end
context "when type of tenancy is secure" do context "when the collection start year is before 2022" do
let(:expected_error) { I18n.t("validations.tenancy.length.secure") } context "when type of tenancy is secure" do
let(:expected_error) { I18n.t("validations.tenancy.length.secure") }
before { record.tenancy = 1 } before { record.tenancy = 1 }
context "when tenancy length is greater than 1" do context "when tenancy length is greater than 1" do
it "adds an error" do it "adds an error" do
record.tenancylength = 1 record.tenancylength = 1
tenancy_validator.validate_fixed_term_tenancy(record) tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to include(match(expected_error)) expect(record.errors["tenancylength"]).to include(match(expected_error))
expect(record.errors["tenancy"]).to include(match(expected_error)) expect(record.errors["tenancy"]).to include(match(expected_error))
end
end end
end
context "when tenancy length is less than 100" do context "when tenancy length is less than 100" do
it "adds an error" do it "adds an error" do
record.tenancylength = 100 record.tenancylength = 100
tenancy_validator.validate_fixed_term_tenancy(record) tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to include(match(expected_error)) expect(record.errors["tenancylength"]).to include(match(expected_error))
expect(record.errors["tenancy"]).to include(match(expected_error)) expect(record.errors["tenancy"]).to include(match(expected_error))
end
end
context "when tenancy length is between 2-99" do
it "does not add an error" do
record.tenancylength = 3
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to be_empty
expect(record.errors["tenancy"]).to be_empty
end
end
context "when tenancy length has not been answered" do
it "does not add an error" do
record.tenancylength = nil
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to be_empty
expect(record.errors["tenancy"]).to be_empty
end
end end
end end
end
context "when tenancy length is between 2-99" do context "when the collection start year is 2022 or later" do
it "does not add an error" do let(:record) { FactoryBot.create(:case_log, startdate: Time.zone.local(2022, 5, 1)) }
record.tenancylength = 3
tenancy_validator.validate_fixed_term_tenancy(record) context "when type of tenancy is Secure - fixed term" do
expect(record.errors["tenancylength"]).to be_empty let(:expected_error) { I18n.t("validations.tenancy.length.secure") }
expect(record.errors["tenancy"]).to be_empty
before { record.tenancy = 6 }
context "when tenancy length is greater than 1" do
it "adds an error" do
record.tenancylength = 1
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to include(match(expected_error))
expect(record.errors["tenancy"]).to include(match(expected_error))
end
end
context "when tenancy length is less than 100" do
it "adds an error" do
record.tenancylength = 100
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to include(match(expected_error))
expect(record.errors["tenancy"]).to include(match(expected_error))
end
end
context "when tenancy length is between 2-99" do
it "does not add an error" do
record.tenancylength = 3
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to be_empty
expect(record.errors["tenancy"]).to be_empty
end
end
context "when tenancy length has not been answered" do
it "does not add an error" do
record.tenancylength = nil
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to be_empty
expect(record.errors["tenancy"]).to be_empty
end
end end
end end
context "when tenancy length has not been answered" do context "when type of tenancy is Secure - lifetime" do
it "does not add an error" do let(:expected_error) { I18n.t("validations.tenancy.length.secure") }
record.tenancylength = nil
tenancy_validator.validate_fixed_term_tenancy(record) before { record.tenancy = 7 }
expect(record.errors["tenancylength"]).to be_empty
expect(record.errors["tenancy"]).to be_empty context "when tenancy length is greater than 1" do
it "adds an error" do
record.tenancylength = 1
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to include(match(expected_error))
expect(record.errors["tenancy"]).to include(match(expected_error))
end
end
context "when tenancy length is less than 100" do
it "adds an error" do
record.tenancylength = 100
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to include(match(expected_error))
expect(record.errors["tenancy"]).to include(match(expected_error))
end
end
context "when tenancy length is between 2-99" do
it "does not add an error" do
record.tenancylength = 3
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to be_empty
expect(record.errors["tenancy"]).to be_empty
end
end
context "when tenancy length has not been answered" do
it "does not add an error" do
record.tenancylength = nil
tenancy_validator.validate_fixed_term_tenancy(record)
expect(record.errors["tenancylength"]).to be_empty
expect(record.errors["tenancy"]).to be_empty
end
end end
end end
end end

3
spec/requests/case_logs_controller_spec.rb

@ -239,6 +239,7 @@ RSpec.describe CaseLogsController, type: :request do
owning_organisation: organisation, owning_organisation: organisation,
mrcdate: Time.zone.local(2022, 2, 1), mrcdate: Time.zone.local(2022, 2, 1),
startdate: Time.zone.local(2022, 12, 1), startdate: Time.zone.local(2022, 12, 1),
tenancy: 6,
managing_organisation: organisation) managing_organisation: organisation)
end end
@ -267,6 +268,7 @@ RSpec.describe CaseLogsController, type: :request do
owning_organisation: organisation, owning_organisation: organisation,
mrcdate: Time.zone.local(2022, 2, 1), mrcdate: Time.zone.local(2022, 2, 1),
startdate: Time.zone.local(2022, 12, 1), startdate: Time.zone.local(2022, 12, 1),
tenancy: 6,
managing_organisation: organisation) managing_organisation: organisation)
end end
let!(:case_log_2022_in_progress) do let!(:case_log_2022_in_progress) do
@ -274,6 +276,7 @@ RSpec.describe CaseLogsController, type: :request do
owning_organisation: organisation, owning_organisation: organisation,
mrcdate: Time.zone.local(2022, 2, 1), mrcdate: Time.zone.local(2022, 2, 1),
startdate: Time.zone.local(2022, 12, 1), startdate: Time.zone.local(2022, 12, 1),
tenancy: 6,
managing_organisation: organisation) managing_organisation: organisation)
end end

Loading…
Cancel
Save