Commit be835f93 authored by Alejandro Rodríguez's avatar Alejandro Rodríguez

Use gl_repository if present when enqueing Sidekiq PostReceive jobs

parent db96f724
v5.0.5
- Use gl_repository if present when enqueing Sidekiq PostReceive jobs
v5.0.4 v5.0.4
- Handle GL_REPOSITORY env variable and use it in API calls and Sidekiq enqueuing - Handle GL_REPOSITORY env variable and use it in API calls and Sidekiq enqueuing
......
...@@ -107,9 +107,9 @@ class GitlabPostReceive ...@@ -107,9 +107,9 @@ class GitlabPostReceive
def update_redis def update_redis
# Encode changes as base64 so we don't run into trouble with non-UTF-8 input. # Encode changes as base64 so we don't run into trouble with non-UTF-8 input.
changes = Base64.encode64(@changes) changes = Base64.encode64(@changes)
# TODO: Change to `@gl_repository || @repo_path` in next release. # TODO: Change to `@gl_repository` in next release.
# See https://gitlab.com/gitlab-org/gitlab-shell/merge_requests/130#note_28747613 # See https://gitlab.com/gitlab-org/gitlab-shell/merge_requests/130#note_28747613
project_identifier = @repo_path project_identifier = @gl_repository || @repo_path
queue = "#{config.redis_namespace}:queue:post_receive" queue = "#{config.redis_namespace}:queue:post_receive"
msg = JSON.dump({ msg = JSON.dump({
......
...@@ -137,13 +137,28 @@ describe GitlabPostReceive do ...@@ -137,13 +137,28 @@ describe GitlabPostReceive do
end end
end end
it "pushes a Sidekiq job onto the queue" do context 'Sidekiq jobs' do
expect(redis_client).to receive(:rpush).with( it "pushes a Sidekiq job onto the queue" do
'resque:gitlab:queue:post_receive', expect(redis_client).to receive(:rpush).with(
%Q/{"class":"PostReceive","args":["#{repo_path}","#{actor}",#{base64_changes.inspect}],"jid":"#{gitlab_post_receive.jid}","enqueued_at":#{enqueued_at.to_f}}/ 'resque:gitlab:queue:post_receive',
).and_return(true) %Q/{"class":"PostReceive","args":["#{gl_repository}","#{actor}",#{base64_changes.inspect}],"jid":"#{gitlab_post_receive.jid}","enqueued_at":#{enqueued_at.to_f}}/
).and_return(true)
gitlab_post_receive.exec gitlab_post_receive.exec
end
context 'when gl_repository is nil' do
let(:gl_repository) { nil }
it "pushes a Sidekiq job with the repository path" do
expect(redis_client).to receive(:rpush).with(
'resque:gitlab:queue:post_receive',
%Q/{"class":"PostReceive","args":["#{repo_path}","#{actor}",#{base64_changes.inspect}],"jid":"#{gitlab_post_receive.jid}","enqueued_at":#{enqueued_at.to_f}}/
).and_return(true)
gitlab_post_receive.exec
end
end
end end
context 'reference counter' do context 'reference counter' do
......
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