2 changed files with 72 additions and 0 deletions
@ -0,0 +1,12 @@ |
|||||||
|
desc "Bulk update logs with invalid rp_dontknow values" |
||||||
|
task recalculate_invalid_rpdontknow: :environment do |
||||||
|
validation_trigger_condition = "rp_dontknow = 1 AND (rp_homeless = 1 OR rp_insan_unsat = 1 OR rp_medwel = 1 OR rp_hardship = 1)" |
||||||
|
|
||||||
|
LettingsLog.filter_by_year(2024).where(validation_trigger_condition).find_each do |log| |
||||||
|
log.rp_dontknow = 0 |
||||||
|
|
||||||
|
unless log.save |
||||||
|
Rails.logger.info "Could not save changes to lettings log #{log.id}" |
||||||
|
end |
||||||
|
end |
||||||
|
end |
@ -0,0 +1,60 @@ |
|||||||
|
require "rails_helper" |
||||||
|
require "rake" |
||||||
|
|
||||||
|
RSpec.describe "recalculate_invalid_reasonpref_dontknow" do |
||||||
|
subject(:task) { Rake::Task["recalculate_invalid_rpdontknow"] } |
||||||
|
|
||||||
|
before do |
||||||
|
Rake.application.rake_require("tasks/recalculate_invalid_reasonpref_dontknow") |
||||||
|
Rake::Task.define_task(:environment) |
||||||
|
task.reenable |
||||||
|
end |
||||||
|
|
||||||
|
let(:invalid_logs) { create_list(:lettings_log, 5, :completed, reasonpref: 1, rp_dontknow: 1, rp_homeless: 1, rp_insan_unsat: rand(2), rp_medwel: rand(2), rp_hardship: rand(2)) } |
||||||
|
let(:pre_2024_invalid_logs) do |
||||||
|
create_list(:lettings_log, 5, :completed, reasonpref: 1, rp_dontknow: 1, rp_homeless: 1, rp_insan_unsat: rand(2), rp_medwel: rand(2), rp_hardship: rand(2)).each do |log| |
||||||
|
log.startdate = Time.zone.local(rand(2021..2023), 4, 1) |
||||||
|
log.save!(validate: false) |
||||||
|
end |
||||||
|
end |
||||||
|
let(:valid_logs) { create_list(:lettings_log, 3, :completed, reasonpref: 1, rp_dontknow: 0, rp_homeless: 1, rp_insan_unsat: 1, rp_medwel: rand(2), rp_hardship: rand(2)) } |
||||||
|
|
||||||
|
it "updates the right logs from 2024/25 with invalid rp_dontknow values" do |
||||||
|
invalid_logs.each do |log| |
||||||
|
expect(log.reasonpref).to eq(1) |
||||||
|
expect(log.rp_dontknow).to eq(1) |
||||||
|
expect(log.rp_homeless).to eq(1) |
||||||
|
end |
||||||
|
pre_2024_invalid_logs.each do |log| |
||||||
|
expect(log.reasonpref).to eq(1) |
||||||
|
expect(log.rp_dontknow).to eq(1) |
||||||
|
expect(log.rp_homeless).to eq(1) |
||||||
|
end |
||||||
|
valid_logs.each do |log| |
||||||
|
expect(log.reasonpref).to eq(1) |
||||||
|
expect(log.rp_dontknow).to eq(0) |
||||||
|
expect(log.rp_homeless).to eq(1) |
||||||
|
expect(log.rp_insan_unsat).to eq(1) |
||||||
|
end |
||||||
|
task.invoke |
||||||
|
invalid_logs.each do |log| |
||||||
|
log.reload |
||||||
|
expect(log.reasonpref).to eq(1) |
||||||
|
expect(log.rp_dontknow).to eq(0) |
||||||
|
expect(log.rp_homeless).to eq(1) |
||||||
|
end |
||||||
|
pre_2024_invalid_logs.each do |log| |
||||||
|
log.reload |
||||||
|
expect(log.reasonpref).to eq(1) |
||||||
|
expect(log.rp_dontknow).to eq(1) |
||||||
|
expect(log.rp_homeless).to eq(1) |
||||||
|
end |
||||||
|
valid_logs.each do |log| |
||||||
|
log.reload |
||||||
|
expect(log.reasonpref).to eq(1) |
||||||
|
expect(log.rp_dontknow).to eq(0) |
||||||
|
expect(log.rp_homeless).to eq(1) |
||||||
|
expect(log.rp_insan_unsat).to eq(1) |
||||||
|
end |
||||||
|
end |
||||||
|
end |
Loading…
Reference in new issue