|
|
|
require "rails_helper"
|
|
|
|
|
|
|
|
RSpec.describe Validations::SoftValidations do
|
|
|
|
let(:organisation) { FactoryBot.create(:organisation, provider_type: "PRP") }
|
|
|
|
let(:record) { FactoryBot.create(:lettings_log, owning_organisation: organisation) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
Timecop.freeze(Time.zone.local(2021, 10, 10))
|
|
|
|
Singleton.__init__(FormHandler)
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
Timecop.return
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "rent min max validations" do
|
|
|
|
before do
|
|
|
|
LaRentRange.create!(
|
|
|
|
ranges_rent_id: "1",
|
|
|
|
la: "E07000223",
|
|
|
|
beds: 1,
|
|
|
|
lettype: 1,
|
|
|
|
soft_min: 12.41,
|
|
|
|
soft_max: 89.54,
|
|
|
|
hard_min: 9.87,
|
|
|
|
hard_max: 100.99,
|
|
|
|
start_year: 2021,
|
|
|
|
)
|
|
|
|
|
|
|
|
record.la = "E07000223"
|
|
|
|
record.needstype = 1
|
|
|
|
record.rent_type = 0
|
|
|
|
record.beds = 1
|
|
|
|
record.period = 1
|
|
|
|
record.startdate = Time.zone.today
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when validating soft min" do
|
|
|
|
before do
|
|
|
|
record.brent = 11
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns out of soft min range if no startdate is given" do
|
|
|
|
record.startdate = nil
|
|
|
|
expect(record)
|
|
|
|
.not_to be_rent_in_soft_min_range
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns out of soft min range if no brent is given" do
|
|
|
|
record.brent = nil
|
|
|
|
expect(record)
|
|
|
|
.not_to be_rent_in_soft_min_range
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns true if weekly rent is in soft min range" do
|
|
|
|
expect(record)
|
|
|
|
.to be_rent_in_soft_min_range
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when validating soft max" do
|
|
|
|
before do
|
|
|
|
record.brent = 90
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns out of soft max range if no startdate is given" do
|
|
|
|
record.startdate = nil
|
|
|
|
expect(record)
|
|
|
|
.not_to be_rent_in_soft_max_range
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns out of soft max range if no brent is given" do
|
|
|
|
record.brent = nil
|
|
|
|
expect(record)
|
|
|
|
.not_to be_rent_in_soft_max_range
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns true if weekly rent is in soft max range" do
|
|
|
|
expect(record)
|
|
|
|
.to be_rent_in_soft_max_range
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "retirement soft validations" do
|
|
|
|
context "when the tenant is retired but under the expected retirement age" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(age1: 43, ecstat1: 5)
|
|
|
|
expect(record.person_1_retired_under_soft_min_age?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the tenant is not retired but over the expected retirement age" do
|
|
|
|
context "when the tenant is female" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(age1: 85, sex1: "F", ecstat1: 3)
|
|
|
|
expect(record.person_1_not_retired_over_soft_max_age?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the tenant is male" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(age1: 85, sex1: "M", ecstat1: 3)
|
|
|
|
expect(record.person_1_not_retired_over_soft_max_age?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the tenant is non-binary" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(age1: 85, sex1: "X", ecstat1: 3)
|
|
|
|
expect(record.person_1_not_retired_over_soft_max_age?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the tenant prefers not to say what their economic status is but is under the expected retirement age" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(age1: 43, ecstat1: 10)
|
|
|
|
expect(record.person_1_retired_under_soft_min_age?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the tenant prefers not to say what their economic status is but is over the expected retirement age" do
|
|
|
|
context "when the tenant is female" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(age1: 85, sex1: "F", ecstat1: 10)
|
|
|
|
expect(record.person_1_not_retired_over_soft_max_age?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the tenant is male" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(age1: 85, sex1: "M", ecstat1: 10)
|
|
|
|
expect(record.person_1_not_retired_over_soft_max_age?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the tenant is non-binary" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(age1: 85, sex1: "X", ecstat1: 10)
|
|
|
|
expect(record.person_1_not_retired_over_soft_max_age?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "pregnancy soft validations" do
|
|
|
|
context "when there are no female tenants" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(age1: 43, sex1: "M", preg_occ: 1, hhmemb: 1, age1_known: 0)
|
|
|
|
expect(record.no_females_in_a_pregnant_household?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when there are no female tenants and age of other tenants is unknown" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(sex1: "M", preg_occ: 1, hhmemb: 1, age1_known: 1)
|
|
|
|
expect(record.no_females_in_a_pregnant_household?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when female tenants are under 16" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(age2: 14, sex2: "F", preg_occ: 1, hhmemb: 2, details_known_2: 0, age2_known: 0, age1: 18, sex1: "M", age1_known: 0)
|
|
|
|
expect(record.female_in_pregnant_household_in_soft_validation_range?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when female tenants are over 50" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(age1: 54, sex1: "F", preg_occ: 1, hhmemb: 1, age1_known: 0)
|
|
|
|
expect(record.female_in_pregnant_household_in_soft_validation_range?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when female tenants are outside of soft validation ranges" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(age1: 44, sex1: "F", preg_occ: 1, hhmemb: 1)
|
|
|
|
expect(record.no_females_in_a_pregnant_household?).to be false
|
|
|
|
expect(record.female_in_pregnant_household_in_soft_validation_range?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the information about the tenants is not given" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(preg_occ: 1, hhmemb: 2)
|
|
|
|
expect(record.no_females_in_a_pregnant_household?).to be false
|
|
|
|
expect(record.female_in_pregnant_household_in_soft_validation_range?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "major repairs date soft validations" do
|
|
|
|
before do
|
|
|
|
Timecop.freeze(Time.zone.local(2022, 2, 1))
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
Timecop.unfreeze
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the major repairs date is within 10 years of the tenancy start date" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(startdate: Time.zone.local(2022, 2, 1), mrcdate: Time.zone.local(2013, 2, 1))
|
|
|
|
expect(record.major_repairs_date_in_soft_range?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the major repairs date is less than 2 years before the tenancy start date" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(startdate: Time.zone.local(2022, 2, 1), mrcdate: Time.zone.local(2021, 2, 1))
|
|
|
|
expect(record.major_repairs_date_in_soft_range?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "void date soft validations" do
|
|
|
|
before do
|
|
|
|
Timecop.freeze(Time.zone.local(2022, 2, 1))
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
Timecop.unfreeze
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the void date is within 10 years of the tenancy start date" do
|
|
|
|
it "shows the interruption screen" do
|
|
|
|
record.update!(startdate: Time.zone.local(2022, 2, 1), voiddate: Time.zone.local(2013, 2, 1))
|
|
|
|
expect(record.voiddate_in_soft_range?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the void date is less than 2 years before the tenancy start date" do
|
|
|
|
it "does not show the interruption screen" do
|
|
|
|
record.update!(startdate: Time.zone.local(2022, 2, 1), voiddate: Time.zone.local(2021, 2, 1))
|
|
|
|
expect(record.voiddate_in_soft_range?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "old persons shared ownership soft validations" do
|
|
|
|
context "when it is a joint purchase and both buyers are over 64" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 1, age1: 65, age2: 66, type: 24) }
|
|
|
|
|
|
|
|
it "returns false" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is a joint purchase and first buyer is over 64" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 1, age1: 65, age2: 40, type: 24) }
|
|
|
|
|
|
|
|
it "returns false" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is a joint purchase and second buyer is over 64" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 1, age1: 43, age2: 64, type: 24) }
|
|
|
|
|
|
|
|
it "returns false" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is a joint purchase and neither of the buyers are over 64" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 1, age1: 43, age2: 33, type: 24) }
|
|
|
|
|
|
|
|
it "returns true" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is a joint purchase and first buyer is under 64 and the second buyers' age is unknown" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 1, age1: 43, age2_known: 1, type: 24) }
|
|
|
|
|
|
|
|
it "returns true" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is a joint purchase and neither of the buyers ages are known" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 1, age1_known: 1, age2_known: 1, type: 24) }
|
|
|
|
|
|
|
|
it "returns true" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is not a joint purchase and the buyer is over 64" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 2, age1: 70, type: 24) }
|
|
|
|
|
|
|
|
it "returns false" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is not a joint purchase and the buyer is under 64" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 2, age1: 20, type: 24) }
|
|
|
|
|
|
|
|
it "returns true" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when it is not a joint purchase and the buyers age is not known" do
|
|
|
|
let(:record) { FactoryBot.build(:sales_log, jointpur: 2, age1_known: 1, type: 24) }
|
|
|
|
|
|
|
|
it "returns true" do
|
|
|
|
expect(record.buyers_age_for_old_persons_shared_ownership_invalid?).to be true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#care_home_charge_expected_not_provided?" do
|
|
|
|
it "returns false if is_carehome is 'No'" do
|
|
|
|
record.period = 3
|
|
|
|
record.is_carehome = 0
|
|
|
|
record.chcharge = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_care_home_charge_expected_not_provided
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if is_carehome is not given" do
|
|
|
|
record.period = 3
|
|
|
|
record.is_carehome = nil
|
|
|
|
record.chcharge = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_care_home_charge_expected_not_provided
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if chcharge is given" do
|
|
|
|
record.period = 3
|
|
|
|
record.is_carehome = 1
|
|
|
|
record.chcharge = 40
|
|
|
|
|
|
|
|
expect(record).not_to be_care_home_charge_expected_not_provided
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns true if is_carehome is 'Yes' and chcharge is not given" do
|
|
|
|
record.period = 3
|
|
|
|
record.is_carehome = 1
|
|
|
|
record.chcharge = nil
|
|
|
|
|
|
|
|
expect(record).to be_care_home_charge_expected_not_provided
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#la_referral_for_general_needs?" do
|
|
|
|
it "returns false if needstype is 'Supported Housing'" do
|
|
|
|
record.needstype = 2
|
|
|
|
record.referral = 4
|
|
|
|
|
|
|
|
expect(record).not_to be_la_referral_for_general_needs
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if needstype is not given" do
|
|
|
|
record.needstype = nil
|
|
|
|
record.referral = 4
|
|
|
|
|
|
|
|
expect(record).not_to be_la_referral_for_general_needs
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if referral is not given" do
|
|
|
|
record.needstype = 1
|
|
|
|
record.referral = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_la_referral_for_general_needs
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns true if needstype is 'General needs' and referral is 4" do
|
|
|
|
record.needstype = 1
|
|
|
|
record.referral = 4
|
|
|
|
|
|
|
|
expect(record).to be_la_referral_for_general_needs
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "scharge_over_soft_max?" do
|
|
|
|
context "and organisation is PRP" do
|
|
|
|
before do
|
|
|
|
record.owning_organisation.update(provider_type: "PRP")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if scharge is not given" do
|
|
|
|
record.scharge = nil
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = 1
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if period is not given" do
|
|
|
|
record.scharge = 201
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 34,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 100,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 69,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if scharge is under soft max for general needs #{test_case[:period][:label]}(35)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 199,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 400,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 399,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if scharge is under soft max for supported housing #{test_case[:period][:label]} (200)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 36,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 180,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 71,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if scharge is over soft max for general needs #{test_case[:period][:label]} (35)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 201,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 1000,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 401,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if scharge is over soft max for supported housing #{test_case[:period][:label]} (200)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "and organisation is LA" do
|
|
|
|
before do
|
|
|
|
record.owning_organisation.update(provider_type: "LA")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if scharge is not given" do
|
|
|
|
record.scharge = nil
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = 1
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if period is not given" do
|
|
|
|
record.scharge = 201
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 24,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 88,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 49,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if scharge is under soft max for general needs #{test_case[:period][:label]}(25)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 99,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 400,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 199,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if scharge is under soft max for supported housing #{test_case[:period][:label]} (100)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 26,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 120,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 51,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if scharge is over soft max for general needs #{test_case[:period][:label]} (25)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
scharge: 101,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
scharge: 450,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
scharge: 201,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if scharge is over soft max for supported housing #{test_case[:period][:label]} (100)" do
|
|
|
|
record.scharge = test_case[:scharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_scharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "pscharge_over_soft_max?" do
|
|
|
|
context "and organisation is PRP" do
|
|
|
|
before do
|
|
|
|
record.owning_organisation.update(provider_type: "PRP")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if pscharge is not given" do
|
|
|
|
record.pscharge = nil
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = 1
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if period is not given" do
|
|
|
|
record.pscharge = 201
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 34,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 100,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 69,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if pscharge is under soft max for general needs #{test_case[:period][:label]}(35)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 99,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 400,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 199,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if pscharge is under soft max for supported housing #{test_case[:period][:label]} (100)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 36,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 180,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 71,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if pscharge is over soft max for general needs #{test_case[:period][:label]} (35)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 101,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 450,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 201,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if pscharge is over soft max for supported housing #{test_case[:period][:label]} (100)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "and organisation is LA" do
|
|
|
|
before do
|
|
|
|
record.owning_organisation.update(provider_type: "LA")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if pscharge is not given" do
|
|
|
|
record.pscharge = nil
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = 1
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if period is not given" do
|
|
|
|
record.pscharge = 201
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 24,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 88,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 49,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if pscharge is under soft max for general needs #{test_case[:period][:label]}(25)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 74,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 250,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 149,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if pscharge is under soft max for supported housing #{test_case[:period][:label]} (75)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 26,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 120,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 51,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if pscharge is over soft max for general needs #{test_case[:period][:label]} (25)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
pscharge: 76,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
pscharge: 350,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
pscharge: 151,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if pscharge is over soft max for supported housing #{test_case[:period][:label]} (75)" do
|
|
|
|
record.pscharge = test_case[:pscharge]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_pscharge_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "supcharg_over_soft_max?" do
|
|
|
|
context "and organisation is PRP" do
|
|
|
|
before do
|
|
|
|
record.owning_organisation.update(provider_type: "PRP")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if supcharg is not given" do
|
|
|
|
record.supcharg = nil
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = 1
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if period is not given" do
|
|
|
|
record.supcharg = 201
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 34,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 100,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 69,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if supcharg is under soft max for general needs #{test_case[:period][:label]}(35)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 84,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 320,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 169,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if supcharg is under soft max for supported housing #{test_case[:period][:label]} (85)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 36,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 180,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 71,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if supcharg is over soft max for general needs #{test_case[:period][:label]} (35)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 86,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 400,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 171,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if supcharg is over soft max for supported housing #{test_case[:period][:label]} (85)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "and organisation is LA" do
|
|
|
|
before do
|
|
|
|
record.owning_organisation.update(provider_type: "LA")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if supcharg is not given" do
|
|
|
|
record.supcharg = nil
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = 1
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if period is not given" do
|
|
|
|
record.supcharg = 201
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = nil
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 24,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 88,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 49,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if supcharg is under soft max for general needs #{test_case[:period][:label]}(25)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 74,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 250,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 149,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns false if supcharg is under soft max for supported housing #{test_case[:period][:label]} (75)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).not_to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 26,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 120,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 51,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if supcharg is over soft max for general needs #{test_case[:period][:label]} (25)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 1
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[{
|
|
|
|
period: { label: "weekly", value: 1 },
|
|
|
|
supcharg: 76,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "monthly", value: 4 },
|
|
|
|
supcharg: 350,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
period: { label: "every 2 weeks", value: 2 },
|
|
|
|
supcharg: 151,
|
|
|
|
}].each do |test_case|
|
|
|
|
it "returns true if supcharg is over soft max for supported housing #{test_case[:period][:label]} (75)" do
|
|
|
|
record.supcharg = test_case[:supcharg]
|
|
|
|
record.needstype = 2
|
|
|
|
record.period = test_case[:period][:value]
|
|
|
|
|
|
|
|
expect(record).to be_supcharg_over_soft_max
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "reasonother_might_be_existing_category?" do
|
|
|
|
it "returns true if reasonother is exactly in the 'likely existing category' list" do
|
|
|
|
record.reasonother = "Domestic Abuse"
|
|
|
|
|
|
|
|
expect(record).to be_reasonother_might_be_existing_category
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns true if any word of reasonother is exactly in the 'likely existing category' list" do
|
|
|
|
record.reasonother = "Was decanted from somewhere"
|
|
|
|
|
|
|
|
expect(record).to be_reasonother_might_be_existing_category
|
|
|
|
end
|
|
|
|
|
|
|
|
it "is not case sensitive when matching" do
|
|
|
|
record.reasonother = "domestic abuse"
|
|
|
|
|
|
|
|
expect(record).to be_reasonother_might_be_existing_category
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if no part of reasonother is in the 'likely existing category' list" do
|
|
|
|
record.reasonother = "other"
|
|
|
|
|
|
|
|
expect(record).not_to be_reasonother_might_be_existing_category
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if match to the 'likely existing category' list is only part of a word" do
|
|
|
|
record.reasonother = "wasdecanted"
|
|
|
|
|
|
|
|
expect(record).not_to be_reasonother_might_be_existing_category
|
|
|
|
end
|
|
|
|
|
|
|
|
it "ignores neighbouring non-alphabet for matching" do
|
|
|
|
record.reasonother = "1Domestic abuse."
|
|
|
|
|
|
|
|
expect(record).to be_reasonother_might_be_existing_category
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|