From 3e3cdcff6b02404a7b1d5e4b32296b63ad5b67f0 Mon Sep 17 00:00:00 2001 From: Henry Date: Wed, 17 Aug 2022 15:46:53 -0400 Subject: [PATCH] PLAN-724 various fixes to diff logic --- .../publication_dates_controller.rb | 20 +++++---- .../reports/schedule_reports_controller.rb | 43 +++++++++---------- app/services/change_service.rb | 9 +++- 3 files changed, 38 insertions(+), 34 deletions(-) diff --git a/app/controllers/publication_dates_controller.rb b/app/controllers/publication_dates_controller.rb index 971d4b442..3048de63e 100644 --- a/app/controllers/publication_dates_controller.rb +++ b/app/controllers/publication_dates_controller.rb @@ -7,18 +7,20 @@ class PublicationDatesController < ResourceController def reset # Make sure that people can not publish etc while we clean up - PublicationStatus.last.update(status: 'inprogress') + if PublicationStatus.last + PublicationStatus.last.update(status: 'inprogress') - # Get rid of published data first - PublishedSession.destroy_all + # Get rid of published data first + PublishedSession.destroy_all - # Then get rid of the audit - Audit::PublishedSessionVersion.delete_all + # Then get rid of the audit + Audit::PublishedSessionVersion.delete_all - # Then remove caches, dates, and status - PublishSnapshot.delete_all - PublicationDate.delete_all - PublicationStatus.delete_all + # Then remove caches, dates, and status + PublishSnapshot.delete_all + PublicationDate.delete_all + PublicationStatus.delete_all + end render status: :ok, json: { message: 'publication reset' }.to_json, diff --git a/app/controllers/reports/schedule_reports_controller.rb b/app/controllers/reports/schedule_reports_controller.rb index 576d5e479..0316e525e 100644 --- a/app/controllers/reports/schedule_reports_controller.rb +++ b/app/controllers/reports/schedule_reports_controller.rb @@ -55,8 +55,13 @@ def check_sessions_changed(changes:, live:) changes.values.sort{|a,b| (a[:object] ? a[:object].title : '') <=> (b[:object] ? b[:object].title : '')}.each do |change| next unless change[:object] + if change[:object] && session_status_change_to_publishable?(change: change) || session_status_change_to_drop?(change: change) + state_change_sessions << change[:object].id + end + if (change[:changes]['room_id'] || change[:changes]['start_time']) #&& !change[:changes]['status'] - next if change[:changes]['status'] && ignore_session_status_change?(change: change) + next if ignore_session_status_change?(change: change) + next if !change[:changes]['status'] && ['draft', 'dropped'].include?(change[:object].status) # Rails.logger.debug "******** SESSION ADD/REMOVE #{change[:changes]} " if room_added?(change) || start_time_added?(change) @@ -81,12 +86,7 @@ def check_sessions_changed(changes:, live:) end if change[:object].start_time && change[:object].room_id - session_id = check_status_change(change: change, live: live) - - if session_id - state_change_sessions << session_id - next - end + check_status_change(change: change, live: live) if change[:changes]['title'] session_title_change_row(@session_title_changed, change) @@ -98,7 +98,6 @@ def check_sessions_changed(changes:, live:) end # Rails.logger.debug "*********** ST #{state_change_sessions}" - return state_change_sessions end @@ -194,43 +193,41 @@ def check_assignments_changed(changes:, state_change_sessions:) end def check_status_change(change:, live: false) - # Rails.logger.debug "********* STATUS CHANGE" return unless change[:changes]['status'] return if ignore_session_status_change?(change: change) - # Rails.logger.debug "********* STATUS CHANGE ..... #{change[:changes]['status']}" - if ['draft', 'dropped'].include?(change[:changes]['status'][1]) + if session_status_change_to_drop?(change: change) if live return unless change[:object].published_session - session_removed_row(@session_removed, change) live_drop(session: change[:object], sheet: @participants_add_drop) - - return change[:object].id - else - session_removed_row(@session_removed, change) end + session_removed_row(@session_removed, change) + return end - if ['draft', 'dropped'].include?(change[:changes]['status'][0]) + if session_status_change_to_publishable?(change: change) # Rails.logger.debug "********* STATUS CHANGE ..... ADDD #{live}" session_added_row(@session_added, change) - if live - live_add(session: change[:object], sheet: @participants_add_drop) - - return change[:object].id - end + live_add(session: change[:object], sheet: @participants_add_drop) if live return end end def ignore_session_status_change?(change:) - ['draft', 'dropped'].include?(change[:changes]['status'][0]) && ['draft', 'dropped'].include?(change[:changes]['status'][1]) + change[:changes]['status'] && ['draft', 'dropped'].include?(change[:changes]['status'][0]) && ['draft', 'dropped'].include?(change[:changes]['status'][1]) end + def session_status_change_to_publishable?(change:) + change[:changes]['status'] && ['draft', 'dropped'].include?(change[:changes]['status'][0]) && ['reviewed', 'revised'].include?(change[:changes]['status'][1]) + end + + def session_status_change_to_drop?(change:) + change[:changes]['status'] && ['draft', 'dropped'].include?(change[:changes]['status'][1]) && ['reviewed', 'revised'].include?(change[:changes]['status'][0]) + end def init_sheets(workbook:) @session_time_changed = workbook.add_worksheet("Session Time Changed") diff --git a/app/services/change_service.rb b/app/services/change_service.rb index bb7f47724..e485aad8b 100644 --- a/app/services/change_service.rb +++ b/app/services/change_service.rb @@ -57,8 +57,13 @@ def self.get_changes(clazz:, type:, from:, to:, publishable_session_ids: nil) if changes[key] changes[key][:changes] = self.merge_change_set(to: changes[key][:changes], from: audit.object_changes) else - obj = type.find(audit.item_id) if audit.event != 'destroy' && type.exists?(audit.item_id) - obj ||= audit.reify + # Get the old version of the object + obj = if audit.event == 'create' + type.find(audit.item_id) if type.exists?(audit.item_id) + else + audit.reify + end + # obj = audit.reify if publishable_session_ids next unless publishable_session_ids.include?(obj.session_id) end