Do not execute hooks on empty projects, fixes #6108

This commit is contained in:
Robert Schilling 2014-07-27 22:26:23 +02:00
parent cb0d63b9e3
commit 062ff17b1c
3 changed files with 31 additions and 7 deletions

View file

@ -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

View file

@ -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

View file

@ -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