Commit 59d6fb79 authored by nmilojevic1's avatar nmilojevic1

Address reviewer feedback

- extract method utilizes_load_balancing_capabilities?
- Fix application_worker specs
parent 5b5c8c9d
...@@ -55,7 +55,7 @@ module ApplicationWorker ...@@ -55,7 +55,7 @@ module ApplicationWorker
def perform_async(*args) def perform_async(*args)
# Worker execution for workers with data_consistency set to :delayed or :sticky # Worker execution for workers with data_consistency set to :delayed or :sticky
# will be delayed to give replication enough time to complete # will be delayed to give replication enough time to complete
if delayed_execution? && data_consistency_delayed_execution_feature_flag_enabled? if utilizes_load_balancing_capabilities? && data_consistency_delayed_execution_feature_flag_enabled?
perform_in(delay_interval, *args) perform_in(delay_interval, *args)
else else
super super
...@@ -132,11 +132,5 @@ module ApplicationWorker ...@@ -132,11 +132,5 @@ module ApplicationWorker
def delay_interval def delay_interval
DEFAULT_DELAY_INTERVAL.seconds DEFAULT_DELAY_INTERVAL.seconds
end end
private
def delayed_execution?
get_data_consistency != :always
end
end end
end end
...@@ -99,11 +99,16 @@ module WorkerAttributes ...@@ -99,11 +99,16 @@ module WorkerAttributes
# Since the deduplication should always take into account the latest binary replication pointer into account, # Since the deduplication should always take into account the latest binary replication pointer into account,
# not the first one, the deduplication will not work with sticky or delayed. # not the first one, the deduplication will not work with sticky or delayed.
# Follow up issue to improve this: https://gitlab.com/gitlab-org/gitlab/-/issues/325291 # Follow up issue to improve this: https://gitlab.com/gitlab-org/gitlab/-/issues/325291
if idempotent? && get_data_consistency != :always if idempotent? && utilizes_load_balancing_capabilities?
raise ArgumentError, "Class can't be marked as idempotent if data_consistency is not set to :always" raise ArgumentError, "Class can't be marked as idempotent if data_consistency is not set to :always"
end end
end end
# If data_consistency is not set to :always, worker will try to utilize load balancing capabilities and use the replica
def utilizes_load_balancing_capabilities?
get_data_consistency != :always
end
def get_data_consistency def get_data_consistency
class_attributes[:data_consistency] || :always class_attributes[:data_consistency] || :always
end end
......
...@@ -24,7 +24,7 @@ module Gitlab ...@@ -24,7 +24,7 @@ module Gitlab
job['worker_data_consistency'] = worker_class.get_data_consistency job['worker_data_consistency'] = worker_class.get_data_consistency
return if worker_class.get_data_consistency == :always return unless worker_class.utilizes_load_balancing_capabilities?
if Session.current.performed_write? if Session.current.performed_write?
job['database_write_location'] = load_balancer.primary_write_location job['database_write_location'] = load_balancer.primary_write_location
......
...@@ -25,7 +25,7 @@ module Gitlab ...@@ -25,7 +25,7 @@ module Gitlab
def requires_primary?(worker_class, job) def requires_primary?(worker_class, job)
return true unless worker_class.include?(::ApplicationWorker) return true unless worker_class.include?(::ApplicationWorker)
return true if worker_class.get_data_consistency == :always return true unless worker_class.utilizes_load_balancing_capabilities?
return true unless worker_class.get_data_consistency_feature_flag_enabled? return true unless worker_class.get_data_consistency_feature_flag_enabled?
location = job['database_write_location'] || job['database_replica_location'] location = job['database_write_location'] || job['database_replica_location']
......
...@@ -177,9 +177,9 @@ RSpec.describe ApplicationWorker do ...@@ -177,9 +177,9 @@ RSpec.describe ApplicationWorker do
end end
describe '.perform_async' do describe '.perform_async' do
context 'when workers data consistency is not :always' do shared_examples_for 'worker utilizes load balancing capabilities' do |data_consistency|
before do before do
worker.data_consistency(:sticky) worker.data_consistency(data_consistency)
end end
context 'when data_consistency_delayed_execution feature flag is disabled' do context 'when data_consistency_delayed_execution feature flag is disabled' do
...@@ -200,12 +200,6 @@ RSpec.describe ApplicationWorker do ...@@ -200,12 +200,6 @@ RSpec.describe ApplicationWorker do
end end
end end
it 'delayed_execution? return true' do
expect(worker).to receive(:delayed_execution?).and_return(true)
worker.perform_async
end
it 'call perform_in' do it 'call perform_in' do
expect(worker).to receive(:perform_in).with(described_class::DEFAULT_DELAY_INTERVAL.seconds, 123) expect(worker).to receive(:perform_in).with(described_class::DEFAULT_DELAY_INTERVAL.seconds, 123)
...@@ -213,6 +207,14 @@ RSpec.describe ApplicationWorker do ...@@ -213,6 +207,14 @@ RSpec.describe ApplicationWorker do
end end
end end
context 'when workers data consistency is :sticky' do
it_behaves_like 'worker utilizes load balancing capabilities', :sticky
end
context 'when workers data consistency is :delayed' do
it_behaves_like 'worker utilizes load balancing capabilities', :delayed
end
context 'when workers data consistency is :always' do context 'when workers data consistency is :always' do
before do before do
worker.data_consistency(:always) worker.data_consistency(:always)
...@@ -223,12 +225,6 @@ RSpec.describe ApplicationWorker do ...@@ -223,12 +225,6 @@ RSpec.describe ApplicationWorker do
worker.perform_async worker.perform_async
end end
it 'delayed_execution? return false' do
expect(worker).to receive(:delayed_execution?).and_return(false)
worker.perform_async
end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment