Move ProjectHooks from spec/requests to spinach
This commit is contained in:
parent
9cabe04368
commit
db69836319
5 changed files with 65 additions and 43 deletions
21
features/project/hooks.feature
Normal file
21
features/project/hooks.feature
Normal file
|
@ -0,0 +1,21 @@
|
|||
Feature: Project Hooks
|
||||
Background:
|
||||
Given I sign in as a user
|
||||
And I own project "Shop"
|
||||
|
||||
Scenario: I should see hook list
|
||||
Given project has hook
|
||||
When I visit project hooks page
|
||||
Then I should see project hook
|
||||
|
||||
Scenario: I add new hook
|
||||
Given I visit project hooks page
|
||||
When I submit new hook
|
||||
Then I should see newly created hook
|
||||
|
||||
Scenario: I test hook
|
||||
Given project has hook
|
||||
And I visit project hooks page
|
||||
When I click test hook button
|
||||
Then hook should be triggered
|
||||
|
36
features/steps/project/project_hooks.rb
Normal file
36
features/steps/project/project_hooks.rb
Normal file
|
@ -0,0 +1,36 @@
|
|||
class ProjectHooks < Spinach::FeatureSteps
|
||||
include SharedAuthentication
|
||||
include SharedProject
|
||||
include SharedPaths
|
||||
include RSpec::Matchers
|
||||
include RSpec::Mocks::ExampleMethods
|
||||
|
||||
Given 'project has hook' do
|
||||
@hook = Factory :project_hook, project: current_project
|
||||
end
|
||||
|
||||
Then 'I should see project hook' do
|
||||
page.should have_content @hook.url
|
||||
end
|
||||
|
||||
When '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
|
||||
page.current_path.should == project_hooks_path(current_project)
|
||||
page.should have_content(@url)
|
||||
end
|
||||
|
||||
When 'I click test hook button' do
|
||||
test_hook_context = double(execute: true)
|
||||
TestHookContext.should_receive(:new).and_return(test_hook_context)
|
||||
click_link 'Test Hook'
|
||||
end
|
||||
|
||||
Then 'hook should be triggered' do
|
||||
page.current_path.should == project_hooks_path(current_project)
|
||||
end
|
||||
end
|
|
@ -125,6 +125,10 @@ module SharedPaths
|
|||
visit project_wiki_path(@project, :index)
|
||||
end
|
||||
|
||||
When 'I visit project hooks page' do
|
||||
visit project_hooks_path(@project)
|
||||
end
|
||||
|
||||
# ----------------------------------------
|
||||
# "Shop" Project
|
||||
# ----------------------------------------
|
||||
|
|
|
@ -12,4 +12,8 @@ module SharedProject
|
|||
@project = Factory :project, :name => "Shop"
|
||||
@project.add_access(@user, :admin)
|
||||
end
|
||||
|
||||
def current_project
|
||||
@project ||= Project.first
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,43 +0,0 @@
|
|||
require 'spec_helper'
|
||||
|
||||
describe "Hooks" do
|
||||
before do
|
||||
login_as :user
|
||||
@project = Factory :project
|
||||
@project.add_access(@user, :read, :admin)
|
||||
end
|
||||
|
||||
describe "GET index" do
|
||||
it "should be available" do
|
||||
@hook = Factory :project_hook, project: @project
|
||||
visit project_hooks_path(@project)
|
||||
page.should have_content "Hooks"
|
||||
page.should have_content @hook.url
|
||||
end
|
||||
end
|
||||
|
||||
describe "New Hook" do
|
||||
before do
|
||||
@url = Faker::Internet.uri("http")
|
||||
visit project_hooks_path(@project)
|
||||
fill_in "hook_url", with: @url
|
||||
expect { click_button "Add Web Hook" }.to change(ProjectHook, :count).by(1)
|
||||
end
|
||||
|
||||
it "should open new team member popup" do
|
||||
page.current_path.should == project_hooks_path(@project)
|
||||
page.should have_content(@url)
|
||||
end
|
||||
end
|
||||
|
||||
describe "Test" do
|
||||
before do
|
||||
@hook = Factory :project_hook, project: @project
|
||||
stub_request(:post, @hook.url)
|
||||
visit project_hooks_path(@project)
|
||||
click_link "Test Hook"
|
||||
end
|
||||
|
||||
it { page.current_path.should == project_hooks_path(@project) }
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue