153 lines
5.8 KiB
Ruby
153 lines
5.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'fast_spec_helper'
|
|
require 'rspec-parameterized'
|
|
|
|
RSpec.describe Gitlab::SidekiqConfig::WorkerMatcher do
|
|
describe '#match?' do
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
let(:worker_metadatas) do
|
|
[
|
|
{
|
|
name: 'pipeline_processing:worker_a',
|
|
worker_name: 'WorkerA',
|
|
feature_category: :category_a,
|
|
has_external_dependencies: false,
|
|
urgency: :low,
|
|
resource_boundary: :cpu,
|
|
tags: [:no_disk_io, :git_access],
|
|
queue_namespace: :pipeline_processing
|
|
},
|
|
{
|
|
name: 'pipeline_processing:worker_a2',
|
|
worker_name: 'WorkerA2',
|
|
feature_category: :category_a,
|
|
has_external_dependencies: false,
|
|
urgency: :high,
|
|
resource_boundary: :none,
|
|
tags: [:git_access],
|
|
queue_namespace: :pipeline_processing
|
|
},
|
|
{
|
|
name: 'authorized_project_update:worker_b',
|
|
worker_name: 'WorkerB',
|
|
feature_category: :category_b,
|
|
has_external_dependencies: true,
|
|
urgency: :high,
|
|
resource_boundary: :memory,
|
|
tags: [:no_disk_io],
|
|
queue_namespace: :authorized_project_update
|
|
},
|
|
{
|
|
name: 'cronjob:worker_c',
|
|
worker_name: 'WorkerC',
|
|
feature_category: :category_c,
|
|
has_external_dependencies: false,
|
|
urgency: :throttled,
|
|
resource_boundary: :memory,
|
|
tags: [],
|
|
queue_namespace: :cronjob
|
|
}
|
|
]
|
|
end
|
|
|
|
context 'with valid input' do
|
|
# rubocop:disable Layout/LineLength -- Easier to read when they are on one line
|
|
where(:query, :expected_metadatas) do
|
|
# worker_name
|
|
'worker_name=WorkerA' | %w[WorkerA]
|
|
'worker_name=WorkerA2' | %w[WorkerA2]
|
|
'worker_name=WorkerB|worker_name=WorkerD' | %w[WorkerB]
|
|
'worker_name!=WorkerA' | %w[WorkerA2 WorkerB WorkerC]
|
|
|
|
# feature_category
|
|
'feature_category=category_a' | %w[WorkerA WorkerA2]
|
|
'feature_category=category_a,category_c' | %w[WorkerA WorkerA2 WorkerC]
|
|
'feature_category=category_a|feature_category=category_c' | %w[WorkerA WorkerA2 WorkerC]
|
|
'feature_category!=category_a' | %w[WorkerB WorkerC]
|
|
|
|
# has_external_dependencies
|
|
'has_external_dependencies=true' | %w[WorkerB]
|
|
'has_external_dependencies=false' | %w[WorkerA WorkerA2 WorkerC]
|
|
'has_external_dependencies=true,false' | %w[WorkerA WorkerA2 WorkerB WorkerC]
|
|
'has_external_dependencies=true|has_external_dependencies=false' | %w[WorkerA WorkerA2 WorkerB WorkerC]
|
|
'has_external_dependencies!=true' | %w[WorkerA WorkerA2 WorkerC]
|
|
|
|
# urgency
|
|
'urgency=high' | %w[WorkerA2 WorkerB]
|
|
'urgency=low' | %w[WorkerA]
|
|
'urgency=high,low,throttled' | %w[WorkerA WorkerA2 WorkerB WorkerC]
|
|
'urgency=low|urgency=throttled' | %w[WorkerA WorkerC]
|
|
'urgency!=high' | %w[WorkerA WorkerC]
|
|
|
|
# name
|
|
'name=pipeline_processing:worker_a' | %w[WorkerA]
|
|
'name=pipeline_processing:worker_a,authorized_project_update:worker_b' | %w[WorkerA WorkerB]
|
|
'name=pipeline_processing:worker_a,pipeline_processing:worker_a2|name=authorized_project_update:worker_b' | %w[WorkerA WorkerA2 WorkerB]
|
|
'name!=pipeline_processing:worker_a,pipeline_processing:worker_a2' | %w[WorkerB WorkerC]
|
|
|
|
# resource_boundary
|
|
'resource_boundary=memory' | %w[WorkerB WorkerC]
|
|
'resource_boundary=memory,cpu' | %w[WorkerA WorkerB WorkerC]
|
|
'resource_boundary=memory|resource_boundary=cpu' | %w[WorkerA WorkerB WorkerC]
|
|
'resource_boundary!=memory,cpu' | %w[WorkerA2]
|
|
|
|
# tags
|
|
'tags=no_disk_io' | %w[WorkerA WorkerB]
|
|
'tags=no_disk_io,git_access' | %w[WorkerA WorkerA2 WorkerB]
|
|
'tags=no_disk_io|tags=git_access' | %w[WorkerA WorkerA2 WorkerB]
|
|
'tags=no_disk_io&tags=git_access' | %w[WorkerA]
|
|
'tags!=no_disk_io' | %w[WorkerA2 WorkerC]
|
|
'tags!=no_disk_io,git_access' | %w[WorkerC]
|
|
'tags=unknown_tag' | []
|
|
'tags!=no_disk_io' | %w[WorkerA2 WorkerC]
|
|
'tags!=no_disk_io,git_access' | %w[WorkerC]
|
|
'tags!=unknown_tag' | %w[WorkerA WorkerA2 WorkerB WorkerC]
|
|
|
|
# queue_namespace
|
|
'queue_namespace=pipeline_processing' | %w[WorkerA WorkerA2]
|
|
'queue_namespace=pipeline_processing,authorized_project_update' | %w[WorkerA WorkerA2 WorkerB]
|
|
'queue_namespace=pipeline_processing|queue_namespace=authorized_project_update' | %w[WorkerA WorkerA2 WorkerB]
|
|
'queue_namespace=cronjob' | %w[WorkerC]
|
|
'queue_namespace!=cronjob' | %w[WorkerA WorkerA2 WorkerB]
|
|
|
|
# combinations
|
|
'feature_category=category_a&urgency=high' | %w[WorkerA2]
|
|
'feature_category=category_a&urgency=high|feature_category=category_c' | %w[WorkerA2 WorkerC]
|
|
|
|
# Match all
|
|
'*' | %w[WorkerA WorkerA2 WorkerB WorkerC]
|
|
end
|
|
# rubocop:enable Layout/LineLength
|
|
|
|
with_them do
|
|
it do
|
|
matched_metadatas = worker_metadatas.select do |metadata|
|
|
described_class.new(query).match?(metadata)
|
|
end
|
|
expect(matched_metadatas.map { |m| m[:worker_name] }).to match_array(expected_metadatas)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with invalid input' do
|
|
where(:query, :error) do
|
|
'feature_category="category_a"' | described_class::InvalidTerm
|
|
'feature_category=' | described_class::InvalidTerm
|
|
'feature_category~category_a' | described_class::InvalidTerm
|
|
'invalid_term=a' | described_class::UnknownPredicate
|
|
end
|
|
|
|
with_them do
|
|
it do
|
|
worker_metadatas.each do |metadata|
|
|
expect { described_class.new(query).match?(metadata) }
|
|
.to raise_error(error)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|