summaryrefslogtreecommitdiff
path: root/spec/controllers/projects/settings/integration_hook_logs_controller_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/controllers/projects/settings/integration_hook_logs_controller_spec.rb')
-rw-r--r--spec/controllers/projects/settings/integration_hook_logs_controller_spec.rb60
1 files changed, 60 insertions, 0 deletions
diff --git a/spec/controllers/projects/settings/integration_hook_logs_controller_spec.rb b/spec/controllers/projects/settings/integration_hook_logs_controller_spec.rb
new file mode 100644
index 00000000000..8261461e8aa
--- /dev/null
+++ b/spec/controllers/projects/settings/integration_hook_logs_controller_spec.rb
@@ -0,0 +1,60 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+RSpec.describe Projects::Settings::IntegrationHookLogsController do
+ let(:project) { create(:project, :repository) }
+ let(:user) { create(:user) }
+ let(:integration) { create(:drone_ci_integration, project: project) }
+ let(:log) { create(:web_hook_log, web_hook: integration.service_hook) }
+ let(:log_params) do
+ {
+ namespace_id: project.namespace,
+ project_id: project,
+ integration_id: integration.to_param,
+ id: log.id
+ }
+ end
+
+ before do
+ sign_in(user)
+ project.add_maintainer(user)
+ end
+
+ describe 'GET #show' do
+ subject { get :show, params: log_params }
+
+ specify do
+ expect(response).to be_successful
+ end
+
+ it 'renders a 404 if the hook does not exist' do
+ log_params
+ integration.service_hook.destroy!
+
+ subject
+
+ expect(response).to have_gitlab_http_status(:not_found)
+ end
+ end
+
+ describe 'POST #retry' do
+ subject { post :retry, params: log_params }
+
+ it 'executes the hook and redirects to the service form' do
+ expect_any_instance_of(ServiceHook).to receive(:execute)
+ expect_any_instance_of(described_class).to receive(:set_hook_execution_notice)
+
+ expect(subject).to redirect_to(edit_project_settings_integration_path(project, integration))
+ end
+
+ it 'renders a 404 if the hook does not exist' do
+ log_params
+ integration.service_hook.destroy!
+
+ subject
+
+ expect(response).to have_gitlab_http_status(:not_found)
+ end
+ end
+end