Browse Source

Update existing created_by values

pull/2373/head
Kat 2 years ago
parent
commit
5501a23ab0
  1. 16
      lib/tasks/update_created_by_values.rake
  2. 1
      spec/factories/lettings_log.rb
  3. 1
      spec/factories/sales_log.rb
  4. 113
      spec/lib/tasks/update_created_by_values_spec.rb

16
lib/tasks/update_created_by_values.rake

@ -0,0 +1,16 @@
desc "Updates created_by values for lettings and sales logs"
task update_created_by_values: :environment do
LettingsLog.filter_by_years(%w[2023 2024]).where.not(bulk_upload_id: nil).update_all("created_by_id = (SELECT user_id FROM bulk_uploads WHERE bulk_uploads.id = lettings_logs.bulk_upload_id)")
LettingsLog.filter_by_years(%w[2023 2024]).where(bulk_upload_id: nil).each do |lettings_log|
user = PaperTrail::Version.find_by(item_id: lettings_log.id, event: "create")&.actor
lettings_log.created_by = user.presence || lettings_log.assigned_to
lettings_log.save!(touch: false, validate: false)
end
SalesLog.filter_by_years(%w[2023 2024]).where.not(bulk_upload_id: nil).update_all("created_by_id = (SELECT user_id FROM bulk_uploads WHERE bulk_uploads.id = sales_logs.bulk_upload_id)")
SalesLog.filter_by_years(%w[2023 2024]).where(bulk_upload_id: nil).each do |sales_log|
user = PaperTrail::Version.find_by(item_id: sales_log.id, event: "create")&.actor
sales_log.created_by = user.presence || sales_log.assigned_to
sales_log.save!(touch: false, validate: false)
end
end

1
spec/factories/lettings_log.rb

@ -1,6 +1,7 @@
FactoryBot.define do FactoryBot.define do
factory :lettings_log do factory :lettings_log do
assigned_to { FactoryBot.create(:user) } assigned_to { FactoryBot.create(:user) }
created_by { assigned_to }
owning_organisation { assigned_to.organisation } owning_organisation { assigned_to.organisation }
managing_organisation { assigned_to.organisation } managing_organisation { assigned_to.organisation }
created_at { Time.zone.today } created_at { Time.zone.today }

1
spec/factories/sales_log.rb

@ -1,6 +1,7 @@
FactoryBot.define do FactoryBot.define do
factory :sales_log do factory :sales_log do
assigned_to { FactoryBot.create(:user) } assigned_to { FactoryBot.create(:user) }
created_by { assigned_to }
owning_organisation { assigned_to.organisation } owning_organisation { assigned_to.organisation }
managing_organisation { owning_organisation } managing_organisation { owning_organisation }
created_at { Time.zone.now } created_at { Time.zone.now }

113
spec/lib/tasks/update_created_by_values_spec.rb

@ -0,0 +1,113 @@
require "rails_helper"
require "rake"
RSpec.describe "update_created_by_values" do
describe ":update_created_by_values", type: :task do
subject(:task) { Rake::Task["update_created_by_values"] }
before do
Rake.application.rake_require("tasks/update_created_by_values")
Rake::Task.define_task(:environment)
task.reenable
end
context "when the rake task is run" do
let(:user) { create(:user) }
context "with bulk upload id" do
let(:bulk_upload) { create(:bulk_upload) }
let(:lettings_log) { create(:lettings_log, :completed, assigned_to: user, bulk_upload_id: bulk_upload.id, updated_at: Time.zone.yesterday) }
let(:sales_log) { create(:sales_log, :completed, assigned_to: user, bulk_upload_id: bulk_upload.id, updated_at: Time.zone.yesterday) }
it "updates created_by to bulk upload user id for lettings log" do
initial_updated_at = lettings_log.updated_at
expect(lettings_log.created_by_id).to eq(user.id)
expect(lettings_log.assigned_to_id).to eq(user.id)
task.invoke
lettings_log.reload
expect(lettings_log.created_by_id).to eq(bulk_upload.user_id)
expect(lettings_log.assigned_to_id).to eq(user.id)
expect(lettings_log.updated_at).to eq(initial_updated_at)
end
it "updates created_by to bulk upload user id for sales log" do
initial_updated_at = sales_log.updated_at
expect(sales_log.created_by_id).to eq(user.id)
expect(sales_log.assigned_to_id).to eq(user.id)
task.invoke
sales_log.reload
expect(sales_log.created_by_id).to eq(bulk_upload.user_id)
expect(sales_log.assigned_to_id).to eq(user.id)
expect(sales_log.updated_at).to eq(initial_updated_at)
end
end
context "without bulk upload id" do
context "and version whodunnit exists for create" do
let(:lettings_log) { create(:lettings_log, :completed, assigned_to: user, created_by_id: nil, updated_at: Time.zone.yesterday) }
let(:sales_log) { create(:sales_log, :completed, assigned_to: user, created_by_id: nil, updated_at: Time.zone.yesterday) }
let(:other_user) { create(:user, organisation: user.organisation) }
before do
PaperTrail::Version.find_by(item_id: lettings_log.id, event: "create").update!(whodunnit: other_user.to_global_id.uri.to_s)
PaperTrail::Version.find_by(item_id: sales_log.id, event: "create").update!(whodunnit: other_user.to_global_id.uri.to_s)
end
it "updates created_by to create whodunnit for lettings" do
initial_updated_at = lettings_log.updated_at
expect(lettings_log.created_by_id).to eq(nil)
expect(lettings_log.assigned_to_id).to eq(user.id)
task.invoke
lettings_log.reload
expect(lettings_log.created_by_id).to eq(other_user.id)
expect(lettings_log.assigned_to_id).to eq(user.id)
expect(lettings_log.updated_at).to eq(initial_updated_at)
end
it "updates created_by to create whodunnit for sales" do
initial_updated_at = sales_log.updated_at
expect(sales_log.created_by_id).to eq(nil)
expect(sales_log.assigned_to_id).to eq(user.id)
task.invoke
sales_log.reload
expect(sales_log.created_by_id).to eq(other_user.id)
expect(sales_log.assigned_to_id).to eq(user.id)
expect(sales_log.updated_at).to eq(initial_updated_at)
end
end
context "and version whodunnit does not exist for create" do
let(:lettings_log) { create(:lettings_log, :completed, assigned_to: user, created_by_id: nil, updated_at: Time.zone.yesterday) }
let(:sales_log) { create(:sales_log, :completed, assigned_to: user, created_by_id: nil, updated_at: Time.zone.yesterday) }
before do
PaperTrail::Version.find_by(item_id: lettings_log.id, event: "create").update!(whodunnit: nil)
PaperTrail::Version.find_by(item_id: sales_log.id, event: "create").update!(whodunnit: nil)
end
it "sets created_by to assigned_to for lettings" do
initial_updated_at = lettings_log.updated_at
expect(lettings_log.created_by_id).to eq(nil)
expect(lettings_log.assigned_to_id).to eq(user.id)
task.invoke
lettings_log.reload
expect(lettings_log.created_by_id).to eq(user.id)
expect(lettings_log.assigned_to_id).to eq(user.id)
expect(lettings_log.updated_at).to eq(initial_updated_at)
end
it "sets created_by to assigned_to for sales" do
initial_updated_at = sales_log.updated_at
expect(sales_log.created_by_id).to eq(nil)
expect(sales_log.assigned_to_id).to eq(user.id)
task.invoke
sales_log.reload
expect(sales_log.created_by_id).to eq(user.id)
expect(sales_log.assigned_to_id).to eq(user.id)
expect(sales_log.updated_at).to eq(initial_updated_at)
end
end
end
end
end
end
Loading…
Cancel
Save