Commit d34ff2e2 authored by Thong Kuah's avatar Thong Kuah

Merge branch 'fix-sidekiq-cluster-dryrun-newlines' into 'master'

Error on newlines in sidekiq-cluster arguments

See merge request gitlab-org/gitlab!69237
parents 36848426 91e7b17c
...@@ -57,6 +57,11 @@ module Gitlab ...@@ -57,6 +57,11 @@ module Gitlab
worker_queues = SidekiqConfig::CliMethods.worker_queues(@rails_path) worker_queues = SidekiqConfig::CliMethods.worker_queues(@rails_path)
queue_groups = argv.map do |queues_or_query_string| queue_groups = argv.map do |queues_or_query_string|
if queues_or_query_string =~ /[\r\n]/
raise CommandError,
'The queue arguments cannot contain newlines'
end
next worker_queues if queues_or_query_string == SidekiqConfig::WorkerMatcher::WILDCARD_MATCH next worker_queues if queues_or_query_string == SidekiqConfig::WorkerMatcher::WILDCARD_MATCH
# When using the queue query syntax, we treat each queue group # When using the queue query syntax, we treat each queue group
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' require 'fast_spec_helper'
require 'shellwords' require 'shellwords'
require 'rspec-parameterized'
RSpec.describe 'bin/sidekiq-cluster' do RSpec.describe 'bin/sidekiq-cluster', :aggregate_failures do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
let(:root) { File.expand_path('../..', __dir__) }
context 'when selecting some queues and excluding others' do context 'when selecting some queues and excluding others' do
where(:args, :included, :excluded) do where(:args, :included, :excluded) do
%w[--negate cronjob] | '-qdefault,1' | '-qcronjob,1' %w[--negate cronjob] | '-qdefault,1' | '-qcronjob,1'
...@@ -13,10 +16,10 @@ RSpec.describe 'bin/sidekiq-cluster' do ...@@ -13,10 +16,10 @@ RSpec.describe 'bin/sidekiq-cluster' do
end end
with_them do with_them do
it 'runs successfully', :aggregate_failures do it 'runs successfully' do
cmd = %w[bin/sidekiq-cluster --dryrun] + args cmd = %w[bin/sidekiq-cluster --dryrun] + args
output, status = Gitlab::Popen.popen(cmd, Rails.root.to_s) output, status = Gitlab::Popen.popen(cmd, root)
expect(status).to be(0) expect(status).to be(0)
expect(output).to include('bundle exec sidekiq') expect(output).to include('bundle exec sidekiq')
...@@ -31,10 +34,10 @@ RSpec.describe 'bin/sidekiq-cluster' do ...@@ -31,10 +34,10 @@ RSpec.describe 'bin/sidekiq-cluster' do
%w[*], %w[*],
%w[--queue-selector *] %w[--queue-selector *]
].each do |args| ].each do |args|
it "runs successfully with `#{args}`", :aggregate_failures do it "runs successfully with `#{args}`" do
cmd = %w[bin/sidekiq-cluster --dryrun] + args cmd = %w[bin/sidekiq-cluster --dryrun] + args
output, status = Gitlab::Popen.popen(cmd, Rails.root.to_s) output, status = Gitlab::Popen.popen(cmd, root)
expect(status).to be(0) expect(status).to be(0)
expect(output).to include('bundle exec sidekiq') expect(output).to include('bundle exec sidekiq')
...@@ -43,4 +46,20 @@ RSpec.describe 'bin/sidekiq-cluster' do ...@@ -43,4 +46,20 @@ RSpec.describe 'bin/sidekiq-cluster' do
end end
end end
end end
context 'when arguments contain newlines' do
it 'raises an error' do
[
["default\n"],
["defaul\nt"]
].each do |args|
cmd = %w[bin/sidekiq-cluster --dryrun] + args
output, status = Gitlab::Popen.popen(cmd, root)
expect(status).to be(1)
expect(output).to include('cannot contain newlines')
end
end
end
end end
...@@ -48,6 +48,18 @@ RSpec.describe Gitlab::SidekiqCluster::CLI do ...@@ -48,6 +48,18 @@ RSpec.describe Gitlab::SidekiqCluster::CLI do
cli.run(%w(*)) cli.run(%w(*))
end end
it 'raises an error when the arguments contain newlines' do
invalid_arguments = [
["foo\n"],
["foo\r"],
%W[foo b\nar]
]
invalid_arguments.each do |arguments|
expect { cli.run(arguments) }.to raise_error(described_class::CommandError)
end
end
context 'with --negate flag' do context 'with --negate flag' do
it 'starts Sidekiq workers for all queues in all_queues.yml except the ones in argv' do it 'starts Sidekiq workers for all queues in all_queues.yml except the ones in argv' do
expect(Gitlab::SidekiqConfig::CliMethods).to receive(:worker_queues).and_return(['baz']) expect(Gitlab::SidekiqConfig::CliMethods).to receive(:worker_queues).and_return(['baz'])
......
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