Skip to content
Snippets Groups Projects
Commit 062ff17b authored by Robert Schilling's avatar Robert Schilling
Browse files

Do not execute hooks on empty projects, fixes #6108

parent cb0d63b9
No related branches found
No related tags found
1 merge request!7383Do not execute hooks on empty projects, fixes #6108
Loading
Loading
@@ -24,7 +24,12 @@ class Projects::HooksController < Projects::ApplicationController
end
 
def test
TestHookService.new.execute(hook, current_user)
if !@project.empty_repo?
TestHookService.new.execute(hook, current_user)
flash[:notice] = 'Hook successfully executed.'
else
flash[:alert] = 'Hook execution failed. Ensure the project has commits.'
end
 
redirect_to :back
end
Loading
Loading
Loading
Loading
@@ -19,3 +19,8 @@ Feature: Project Hooks
When I click test hook button
Then hook should be triggered
 
Scenario: I test a hook on empty project
Given I own empty project with hook
And I visit project hooks page
When I click test hook button
Then I should see hook error message
Loading
Loading
@@ -8,31 +8,45 @@ class ProjectHooks < Spinach::FeatureSteps
include RSpec::Mocks::ExampleMethods
include WebMock::API
 
Given 'project has hook' do
step 'project has hook' do
@hook = create(:project_hook, project: current_project)
end
 
Then 'I should see project hook' do
step 'I own empty project with hook' do
@project = create(:empty_project,
name: 'Empty Project', namespace: @user.namespace)
@hook = create(:project_hook, project: current_project)
end
step 'I should see project hook' do
page.should have_content @hook.url
end
 
When 'I submit new hook' do
step 'I submit new hook' do
@url = Faker::Internet.uri("http")
fill_in "hook_url", with: @url
expect { click_button "Add Web Hook" }.to change(ProjectHook, :count).by(1)
end
 
Then 'I should see newly created hook' do
step 'I should see newly created hook' do
page.current_path.should == project_hooks_path(current_project)
page.should have_content(@url)
end
 
When 'I click test hook button' do
step 'I click test hook button' do
stub_request(:post, @hook.url).to_return(status: 200)
click_link 'Test Hook'
end
 
Then 'hook should be triggered' do
step 'hook should be triggered' do
page.current_path.should == project_hooks_path(current_project)
page.should have_selector '.flash-notice',
text: 'Hook successfully executed.'
end
step 'I should see hook error message' do
page.should have_selector '.flash-alert',
text: 'Hook execution failed. '\
'Ensure the project has commits.'
end
end
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment