From 25135c0e4169dec26afa55cfd40965e6ff4ea586 Mon Sep 17 00:00:00 2001 From: Zeke Gabrielse Date: Wed, 1 May 2024 08:15:16 -0500 Subject: [PATCH] denormalize event type for request and event logs --- app/models/event_log.rb | 4 ++ ...4919_add_event_type_event_to_event_logs.rb | 5 ++ ...26_add_event_type_event_to_request_logs.rb | 5 ++ db/schema.rb | 4 +- spec/models/event_log_spec.rb | 62 +++++++++++++++++++ 5 files changed, 79 insertions(+), 1 deletion(-) create mode 100644 db/migrate/20240501124919_add_event_type_event_to_event_logs.rb create mode 100644 db/migrate/20240501124926_add_event_type_event_to_request_logs.rb diff --git a/app/models/event_log.rb b/app/models/event_log.rb index f0f17739ef..625adde460 100644 --- a/app/models/event_log.rb +++ b/app/models/event_log.rb @@ -2,6 +2,7 @@ class EventLog < ApplicationRecord include Keygen::EE::ProtectedClass[entitlements: %i[event_logs]] + include Denormalizable include Environmental include Accountable include DateRangeable @@ -22,6 +23,9 @@ class EventLog < ApplicationRecord has_environment has_account + denormalizes :event, from: :event_type, prefix: :event_type + denormalizes :event_type_event, to: :request_log + # NOTE(ezekg) Would love to add a default instead of this, but alas, # the table is too big and it would break everything. before_create -> { self.created_date ||= (created_at || Date.current) } diff --git a/db/migrate/20240501124919_add_event_type_event_to_event_logs.rb b/db/migrate/20240501124919_add_event_type_event_to_event_logs.rb new file mode 100644 index 0000000000..480c3ed912 --- /dev/null +++ b/db/migrate/20240501124919_add_event_type_event_to_event_logs.rb @@ -0,0 +1,5 @@ +class AddEventTypeEventToEventLogs < ActiveRecord::Migration[7.1] + def change + add_column :event_logs, :event_type_event, :string, null: true + end +end diff --git a/db/migrate/20240501124926_add_event_type_event_to_request_logs.rb b/db/migrate/20240501124926_add_event_type_event_to_request_logs.rb new file mode 100644 index 0000000000..7e5be1c7dc --- /dev/null +++ b/db/migrate/20240501124926_add_event_type_event_to_request_logs.rb @@ -0,0 +1,5 @@ +class AddEventTypeEventToRequestLogs < ActiveRecord::Migration[7.1] + def change + add_column :request_logs, :event_type_event, :string, null: true + end +end diff --git a/db/schema.rb b/db/schema.rb index 46bd49f813..123e3d70ef 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema[7.1].define(version: 2024_04_24_041244) do +ActiveRecord::Schema[7.1].define(version: 2024_05_01_124926) do # These are extensions that must be enabled in order to support this database enable_extension "btree_gin" enable_extension "pg_stat_statements" @@ -110,6 +110,7 @@ t.datetime "updated_at", null: false t.uuid "environment_id" t.date "created_date" + t.string "event_type_event" t.index ["account_id", "created_at"], name: "index_event_logs_on_account_id_and_created_at", order: { created_at: :desc } t.index ["account_id", "created_date"], name: "index_event_logs_on_account_id_and_created_date", order: { created_date: :desc } t.index ["environment_id"], name: "index_event_logs_on_environment_id" @@ -695,6 +696,7 @@ t.jsonb "response_headers" t.float "run_time" t.float "queue_time" + t.string "event_type_event" t.index ["account_id", "created_at"], name: "index_request_logs_on_account_id_and_created_at" t.index ["account_id", "created_date"], name: "index_request_logs_on_account_id_and_created_date", order: { created_date: :desc } t.index ["environment_id"], name: "index_request_logs_on_environment_id" diff --git a/spec/models/event_log_spec.rb b/spec/models/event_log_spec.rb index 222bc13499..68fcc3fa38 100644 --- a/spec/models/event_log_spec.rb +++ b/spec/models/event_log_spec.rb @@ -4,6 +4,68 @@ require 'spec_helper' describe EventLog, type: :model do + let(:account) { create(:account) } + it_behaves_like :environmental it_behaves_like :accountable + + describe '#event_type=' do + let(:event_type) { EventType.all.to_a.sample } + + context 'on build' do + it 'should denormalize event from event type' do + event_log = build(:event_log, event_type:, account:) + + expect(event_log.event_type_event).to eq event_type.event + expect(event_log.event_type_id).to eq be_nil + end + + it 'should denormalize event type to request log' do + request_log = build(:request_log, account:) + event_log = build(:event_log, request_log:, event_type:, account:) + + expect(request_log.event_type_event).to eq event_type.event + expect(request_log.event_type_id).to be_nil + end + end + + context 'on create' do + it 'should denormalize event from event type' do + event_log = create(:event_log, event_type:, account:) + + expect(event_log.event_type_event).to eq event_type.event + expect(event_log.event_type_id).to eq event_type.id + end + + it 'should denormalize event type to request log' do + request_log = create(:request_log, account:) + event_log = create(:event_log, request_log:, event_type:, account:) + + expect(request_log.event_type_event).to eq event_type.event + expect(request_log.event_type_id).to eq event_type.id + end + end + + context 'on update' do + it 'should denormalize event from event type' do + event_log = create(:event_log, account:) + + event_log.update!(event_type:) + + expect(event_log.event_type_event).to eq event_type.event + expect(event_log.event_type_id).to eq event_type.id + end + + it 'should denormalize event type to request log' do + request_log = create(:request_log, account:) + event_log = create(:event_log, request_log:, account:) + + event_log.update!(event_type:) + request_log.reload + + expect(request_log.event_type_event).to eq event_type.event + expect(request_log.event_type_id).to eq event_type.id + end + end + end end