Skip to content

Commit

Permalink
Add order_column into perform, update specs
Browse files Browse the repository at this point in the history
  • Loading branch information
ericaporter committed Dec 18, 2023
1 parent f113352 commit b6eb3c0
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 13 deletions.
30 changes: 20 additions & 10 deletions lib/dfe/analytics/entity_table_check_job.rb
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,16 @@ def perform
return unless supported_adapter_and_environment?

DfE::Analytics.entities_for_analytics.each do |entity|
entity_table_check_event = build_event_for(entity)
next unless id_column_exists_for_entity?(entity)

order_column = determine_order_column(entity)

entity_table_check_event = build_event_for(entity, order_column)
DfE::Analytics::SendEvents.perform_later([entity_table_check_event]) if entity_table_check_event.present?
end
end

def build_event_for(entity)
def build_event_for(entity, order_column)
unless DfE::Analytics.models_for_entity(entity).any?
Rails.logger.info("DfE::Analytics NOT Processing entity: #{entity} - No associated models")
return
Expand All @@ -27,23 +31,24 @@ def build_event_for(entity)
DfE::Analytics::Event.new
.with_type('entity_table_check')
.with_entity_table_name(entity)
.with_data(entity_table_check_data(entity))
.with_data(entity_table_check_data(entity, order_column))
.as_json
end

def adapter_name
@adapter_name ||= ActiveRecord::Base.connection.adapter_name.downcase
end

def entity_table_check_data(entity)
def entity_table_check_data(entity, order_column)
checksum_calculated_at = fetch_current_timestamp_in_time_zone

row_count, checksum = fetch_checksum_data(entity, checksum_calculated_at)
row_count, checksum = fetch_checksum_data(entity, checksum_calculated_at, order_column)
Rails.logger.info("DfE::Analytics Processing entity: #{entity}: Row count: #{row_count}")
{
row_count: row_count,
checksum: checksum,
checksum_calculated_at: checksum_calculated_at
checksum_calculated_at: checksum_calculated_at,
order_column: order_column
}
end

Expand All @@ -60,12 +65,9 @@ def fetch_current_timestamp_in_time_zone
result.first['current_timestamp'].in_time_zone(TIME_ZONE).iso8601(6)
end

def fetch_checksum_data(entity, checksum_calculated_at)
return [0, ''] unless ActiveRecord::Base.connection.column_exists?(entity, :id)

def fetch_checksum_data(entity, checksum_calculated_at, order_column)
table_name_sanitized = ActiveRecord::Base.connection.quote_table_name(entity)
checksum_calculated_at_sanitized = ActiveRecord::Base.connection.quote(checksum_calculated_at)
order_column = determine_order_column(entity)

if adapter_name == 'postgresql'
fetch_postgresql_checksum_data(table_name_sanitized, checksum_calculated_at_sanitized, order_column)
Expand All @@ -74,6 +76,14 @@ def fetch_checksum_data(entity, checksum_calculated_at)
end
end

def id_column_exists_for_entity?(entity)
return true if ActiveRecord::Base.connection.column_exists?(entity, :id)

Rails.logger.info("DfE::Analytics: Entity checksum: ID column missing in #{entity} - Skipping checks")

false
end

def determine_order_column(entity)
if ActiveRecord::Base.connection.column_exists?(entity, :updated_at)
'UPDATED_AT'
Expand Down
10 changes: 7 additions & 3 deletions spec/dfe/analytics/entity_table_check_job_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
let(:time_now) { Time.new(2023, 9, 19, 12, 0, 0) }
let(:time_zone) { 'London' }
let(:checksum_calculated_at) { ActiveRecord::Base.connection.select_all('SELECT CURRENT_TIMESTAMP AS current_timestamp').first['current_timestamp'].in_time_zone('London').iso8601(6) }
let(:order_column) { 'UPDATED_AT' }

before { Timecop.freeze(checksum_calculated_at) }
after { Timecop.return }
Expand All @@ -54,7 +55,8 @@
[
{ 'key' => 'row_count', 'value' => [table_ids.size] },
{ 'key' => 'checksum', 'value' => [checksum] },
{ 'key' => 'checksum_calculated_at', 'value' => [checksum_calculated_at] }
{ 'key' => 'checksum_calculated_at', 'value' => [checksum_calculated_at] },
{ 'key' => 'order_column', 'value' => [order_column] }
]
})])
end
Expand All @@ -74,7 +76,8 @@
'data' => [
{ 'key' => 'row_count', 'value' => [table_ids.size] },
{ 'key' => 'checksum', 'value' => [checksum] },
{ 'key' => 'checksum_calculated_at', 'value' => [checksum_calculated_at] }
{ 'key' => 'checksum_calculated_at', 'value' => [checksum_calculated_at] },
{ 'key' => 'order_column', 'value' => [order_column] }
]
})])
end
Expand All @@ -89,7 +92,8 @@
'data' => [
{ 'key' => 'row_count', 'value' => [0] },
{ 'key' => 'checksum', 'value' => [checksum] },
{ 'key' => 'checksum_calculated_at', 'value' => [checksum_calculated_at] }
{ 'key' => 'checksum_calculated_at', 'value' => [checksum_calculated_at] },
{ 'key' => 'order_column', 'value' => [order_column] }
]
})])
end
Expand Down

0 comments on commit b6eb3c0

Please sign in to comment.