Move dashboard issues spinach test to Rspec
https://gitlab.com/gitlab-org/gitlab-ce/issues/23036
This commit is contained in:
parent
57d5a5499c
commit
6ed73dc7c2
3 changed files with 48 additions and 112 deletions
|
@ -1,21 +0,0 @@
|
|||
@dashboard
|
||||
Feature: Dashboard Issues
|
||||
Background:
|
||||
Given I sign in as a user
|
||||
And I have authored issues
|
||||
And I have assigned issues
|
||||
And I have other issues
|
||||
And I visit dashboard issues page
|
||||
|
||||
Scenario: I should see assigned issues
|
||||
Then I should see issues assigned to me
|
||||
|
||||
@javascript
|
||||
Scenario: I should see authored issues
|
||||
When I click "Authored by me" link
|
||||
Then I should see issues authored by me
|
||||
|
||||
@javascript
|
||||
Scenario: I should see all issues
|
||||
When I click "All" link
|
||||
Then I should see all issues
|
|
@ -1,91 +0,0 @@
|
|||
class Spinach::Features::DashboardIssues < Spinach::FeatureSteps
|
||||
include SharedAuthentication
|
||||
include SharedPaths
|
||||
include Select2Helper
|
||||
|
||||
step 'I should see issues assigned to me' do
|
||||
should_see(assigned_issue)
|
||||
should_not_see(authored_issue)
|
||||
should_not_see(other_issue)
|
||||
end
|
||||
|
||||
step 'I should see issues authored by me' do
|
||||
should_see(authored_issue)
|
||||
should_see(authored_issue_on_public_project)
|
||||
should_not_see(assigned_issue)
|
||||
should_not_see(other_issue)
|
||||
end
|
||||
|
||||
step 'I should see all issues' do
|
||||
should_see(authored_issue)
|
||||
should_see(assigned_issue)
|
||||
should_see(other_issue)
|
||||
end
|
||||
|
||||
step 'I have authored issues' do
|
||||
authored_issue
|
||||
authored_issue_on_public_project
|
||||
end
|
||||
|
||||
step 'I have assigned issues' do
|
||||
assigned_issue
|
||||
end
|
||||
|
||||
step 'I have other issues' do
|
||||
other_issue
|
||||
end
|
||||
|
||||
step 'I click "Authored by me" link' do
|
||||
find("#assignee_id").set("")
|
||||
find(".js-author-search", match: :first).click
|
||||
find(".dropdown-menu-author li a", match: :first, text: current_user.to_reference).click
|
||||
end
|
||||
|
||||
step 'I click "All" link' do
|
||||
find(".js-author-search").click
|
||||
expect(page).to have_selector(".dropdown-menu-author li a")
|
||||
find(".dropdown-menu-author li a", match: :first).click
|
||||
expect(page).not_to have_selector(".dropdown-menu-author li a")
|
||||
|
||||
find(".js-assignee-search").click
|
||||
expect(page).to have_selector(".dropdown-menu-assignee li a")
|
||||
find(".dropdown-menu-assignee li a", match: :first).click
|
||||
expect(page).not_to have_selector(".dropdown-menu-assignee li a")
|
||||
end
|
||||
|
||||
def should_see(issue)
|
||||
expect(page).to have_content(issue.title[0..10])
|
||||
end
|
||||
|
||||
def should_not_see(issue)
|
||||
expect(page).not_to have_content(issue.title[0..10])
|
||||
end
|
||||
|
||||
def assigned_issue
|
||||
@assigned_issue ||= create :issue, assignee: current_user, project: project
|
||||
end
|
||||
|
||||
def authored_issue
|
||||
@authored_issue ||= create :issue, author: current_user, project: project
|
||||
end
|
||||
|
||||
def other_issue
|
||||
@other_issue ||= create :issue, project: project
|
||||
end
|
||||
|
||||
def authored_issue_on_public_project
|
||||
@authored_issue_on_public_project ||= create :issue, author: current_user, project: public_project
|
||||
end
|
||||
|
||||
def project
|
||||
@project ||= begin
|
||||
project = create(:empty_project)
|
||||
project.team << [current_user, :master]
|
||||
project
|
||||
end
|
||||
end
|
||||
|
||||
def public_project
|
||||
@public_project ||= create(:empty_project, :public)
|
||||
end
|
||||
end
|
48
spec/features/dashboard/issues_spec.rb
Normal file
48
spec/features/dashboard/issues_spec.rb
Normal file
|
@ -0,0 +1,48 @@
|
|||
require 'spec_helper'
|
||||
|
||||
RSpec.describe 'Dashboard Issues', feature: true do
|
||||
let(:current_user) { create :user }
|
||||
let(:public_project) { create(:empty_project, :public) }
|
||||
let(:project) do
|
||||
create(:empty_project) do |project|
|
||||
project.team << [current_user, :master]
|
||||
end
|
||||
end
|
||||
|
||||
let!(:authored_issue) { create :issue, author: current_user, project: project }
|
||||
let!(:authored_issue_on_public_project) { create :issue, author: current_user, project: public_project }
|
||||
let!(:assigned_issue) { create :issue, assignee: current_user, project: project }
|
||||
let!(:other_issue) { create :issue, project: project }
|
||||
|
||||
before do
|
||||
login_as(current_user)
|
||||
|
||||
visit issues_dashboard_path(assignee_id: current_user.id)
|
||||
end
|
||||
|
||||
it 'shows issues assigned to current user' do
|
||||
expect(page).to have_content(assigned_issue.title)
|
||||
expect(page).not_to have_content(authored_issue.title)
|
||||
expect(page).not_to have_content(other_issue.title)
|
||||
end
|
||||
|
||||
it 'shows issues when current user is author', js: true do
|
||||
find('#assignee_id', visible: false).set('')
|
||||
find('.js-author-search', match: :first).click
|
||||
find('.dropdown-menu-author li a', match: :first, text: current_user.to_reference).click
|
||||
|
||||
expect(page).to have_content(authored_issue.title)
|
||||
expect(page).to have_content(authored_issue_on_public_project.title)
|
||||
expect(page).not_to have_content(assigned_issue.title)
|
||||
expect(page).not_to have_content(other_issue.title)
|
||||
end
|
||||
|
||||
it 'shows all issues' do
|
||||
click_link('Reset filters')
|
||||
|
||||
expect(page).to have_content(authored_issue.title)
|
||||
expect(page).to have_content(authored_issue_on_public_project.title)
|
||||
expect(page).to have_content(assigned_issue.title)
|
||||
expect(page).to have_content(other_issue.title)
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue