Skip to content

Commit

Permalink
Add tests to Dashboard#merge_requests filter
Browse files Browse the repository at this point in the history
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
  • Loading branch information
dzaporozhets committed Dec 24, 2013
1 parent 5953582 commit 4c61c46
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 21 deletions.
4 changes: 2 additions & 2 deletions app/views/shared/_filter.html.haml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
= form_tag filter_path(entity), method: 'get' do
%fieldset
%fieldset.scope-filter
%ul.nav.nav-pills.nav-stacked
%li{class: ("active" if params[:scope].blank?)}
= link_to filter_path(entity, scope: nil) do
Expand All @@ -11,7 +11,7 @@
= link_to filter_path(entity, scope: 'all') do
All

%fieldset
%fieldset.status-filter
%ul.nav.nav-pills.nav-stacked
%li{class: ("active" if params[:status].blank?)}
= link_to filter_path(entity, status: nil) do
Expand Down
14 changes: 12 additions & 2 deletions features/dashboard/merge_requests.feature
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,17 @@ Feature: Dashboard Merge Requests
Background:
Given I sign in as a user
And I have authored merge requests
And I have assigned merge requests
And I have other merge requests
And I visit dashboard merge requests page

Scenario: I should see projects list
Then I should see my merge requests
Scenario: I should see assigned merge_requests
Then I should see merge requests assigned to me

Scenario: I should see authored merge_requests
When I click "Authored by me" link
Then I should see merge requests authored by me

Scenario: I should see all merge_requests
When I click "All" link
Then I should see all merge requests
79 changes: 62 additions & 17 deletions features/steps/dashboard/dashboard_merge_requests.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,28 +2,73 @@ class DashboardMergeRequests < Spinach::FeatureSteps
include SharedAuthentication
include SharedPaths

Then 'I should see my merge requests' do
merge_requests = @user.merge_requests
merge_requests.each do |mr|
page.should have_content(mr.title[0..10])
page.should have_content(mr.target_project.name)
page.should have_content(mr.source_project.name)
step 'I should see merge requests assigned to me' do
should_see(assigned_merge_request)
should_not_see(authored_merge_request)
should_not_see(other_merge_request)
end

step 'I should see merge requests authored by me' do
should_see(authored_merge_request)
should_not_see(assigned_merge_request)
should_not_see(other_merge_request)
end

step 'I should see all merge requests' do
should_see(authored_merge_request)
should_see(assigned_merge_request)
should_see(other_merge_request)
end

step 'I have authored merge requests' do
authored_merge_request
end

step 'I have assigned merge requests' do
assigned_merge_request
end

step 'I have other merge requests' do
other_merge_request
end

step 'I click "Authored by me" link' do
within ".scope-filter" do
click_link 'Authored by me'
end
end

step 'I click "All" link' do
within ".scope-filter" do
click_link 'All'
end
end

And 'I have authored merge requests' do
project1_source = create :project
project1_target= create :project
project2_source = create :project
project2_target = create :project
def should_see(merge_request)
page.should have_content(merge_request.title[0..10])
end

def should_not_see(merge_request)
page.should_not have_content(merge_request.title[0..10])
end

project1_source.team << [@user, :master]
project1_target.team << [@user, :master]
project2_source.team << [@user, :master]
project2_target.team << [@user, :master]
def assigned_merge_request
@assigned_merge_request ||= create :merge_request, assignee: current_user, target_project: project
end

def authored_merge_request
@authored_merge_request ||= create :merge_request, author: current_user, target_project: project
end

def other_merge_request
@other_merge_request ||= create :merge_request, target_project: project
end

merge_request1 = create :merge_request, author: @user, source_project: project1_source, target_project: project1_target
merge_request2 = create :merge_request, author: @user, source_project: project2_source, target_project: project2_target
def project
@project ||= begin
project =create :project_with_code
project.team << [current_user, :master]
project
end
end
end

0 comments on commit 4c61c46

Please sign in to comment.