Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2022-10-11 18:10:03 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2022-10-11 18:10:03 +0300
commit14ae125e1c59ca3e9b535938707831c986dbbc43 (patch)
tree6cb2244b7aafe63586d5e1c538ab8e1385db4163 /spec/rubocop
parentfd31bd1fc7954f69025d8e6bbe7f772ea9fb4bb0 (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/rubocop')
-rw-r--r--spec/rubocop/cop/sidekiq_api_usage_spec.rb60
1 files changed, 60 insertions, 0 deletions
diff --git a/spec/rubocop/cop/sidekiq_api_usage_spec.rb b/spec/rubocop/cop/sidekiq_api_usage_spec.rb
new file mode 100644
index 00000000000..79a0774e625
--- /dev/null
+++ b/spec/rubocop/cop/sidekiq_api_usage_spec.rb
@@ -0,0 +1,60 @@
+# frozen_string_literal: true
+
+require 'rubocop_spec_helper'
+
+require_relative '../../../rubocop/cop/sidekiq_api_usage'
+
+RSpec.describe RuboCop::Cop::SidekiqApiUsage do
+ let(:msg) { described_class::MSG }
+
+ context 'when calling Sidekiq::Worker' do
+ it 'registers no offences for calling skipping_transaction_check' do
+ expect_no_offenses(<<~PATTERN)
+ Sidekiq::Worker.skipping_transaction_check do
+ end
+ PATTERN
+ end
+
+ it 'registers no offences for calling raise_inside_transaction_exception' do
+ expect_no_offenses(<<~PATTERN)
+ Sidekiq::Worker.raise_inside_transaction_exception(cause: "testing")
+ PATTERN
+ end
+
+ it 'registers no offences for calling raise_exception_for_being_inside_a_transaction?' do
+ expect_no_offenses(<<~PATTERN)
+ return if Sidekiq::Worker.raise_exception_for_being_inside_a_transaction?
+ PATTERN
+ end
+
+ it 'registers offence for calling other Sidekiq::Worker methods' do
+ expect_offense(<<~PATTERN)
+ Sidekiq::Worker.drain_all
+ ^^^^^^^^^^^^^^^^^^^^^^^^^ #{msg}
+ PATTERN
+ end
+ end
+
+ it 'does not registers offence when calling Sidekiq::Testing' do
+ expect_no_offenses(<<~PATTERN)
+ Sidekiq::Testing.inline! do
+ create_real_projects!
+ create_large_projects!
+ end
+ PATTERN
+ end
+
+ it 'registers offence when calling Sidekiq API' do
+ expect_offense(<<~PATTERN)
+ Sidekiq::Queue.new('testing').all
+ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ #{msg}
+ PATTERN
+ end
+
+ it 'registers offence when assigning Sidekiq API classes' do
+ expect_offense(<<~PATTERN)
+ retry_set = Sidekiq::RetrySet.new
+ ^^^^^^^^^^^^^^^^^^^^^ #{msg}
+ PATTERN
+ end
+end