f82377b89f
Use wait_for_requests for checking Vue resource and $.ajax requests [CE] Closes #31946 and #31555 See merge request !11451
191 lines
7 KiB
Ruby
191 lines
7 KiB
Ruby
class Spinach::Features::DashboardTodos < Spinach::FeatureSteps
|
|
include SharedAuthentication
|
|
include SharedPaths
|
|
include SharedProject
|
|
include SharedUser
|
|
include WaitForRequests
|
|
|
|
step '"John Doe" is a developer of project "Shop"' do
|
|
project.team << [john_doe, :developer]
|
|
end
|
|
|
|
step 'I am a developer of project "Enterprise"' do
|
|
enterprise.team << [current_user, :developer]
|
|
end
|
|
|
|
step '"Mary Jane" is a developer of project "Shop"' do
|
|
project.team << [john_doe, :developer]
|
|
end
|
|
|
|
step 'I have todos' do
|
|
create(:todo, user: current_user, project: project, author: mary_jane, target: issue, action: Todo::MENTIONED)
|
|
create(:todo, user: current_user, project: project, author: john_doe, target: issue, action: Todo::ASSIGNED)
|
|
note = create(:note, author: john_doe, noteable: issue, note: "#{current_user.to_reference} Wdyt?", project: project)
|
|
create(:todo, user: current_user, project: project, author: john_doe, target: issue, action: Todo::MENTIONED, note: note)
|
|
create(:todo, user: current_user, project: project, author: john_doe, target: merge_request, action: Todo::ASSIGNED)
|
|
end
|
|
|
|
step 'I should see todos assigned to me' do
|
|
merge_request_reference = merge_request.to_reference(full: true)
|
|
issue_reference = issue.to_reference(full: true)
|
|
|
|
page.within('.todos-count') { expect(page).to have_content '4' }
|
|
expect(page).to have_content 'To do 4'
|
|
expect(page).to have_content 'Done 0'
|
|
|
|
expect(page).to have_link project.name_with_namespace
|
|
should_see_todo(1, "John Doe assigned you merge request #{merge_request_reference}", merge_request.title)
|
|
should_see_todo(2, "John Doe mentioned you on issue #{issue_reference}", "#{current_user.to_reference} Wdyt?")
|
|
should_see_todo(3, "John Doe assigned you issue #{issue_reference}", issue.title)
|
|
should_see_todo(4, "Mary Jane mentioned you on issue #{issue_reference}", issue.title)
|
|
end
|
|
|
|
step 'I mark the todo as done' do
|
|
page.within('.todo:nth-child(1)') do
|
|
click_link 'Done'
|
|
end
|
|
|
|
page.within('.todos-count') { expect(page).to have_content '3' }
|
|
expect(page).to have_content 'To do 3'
|
|
expect(page).to have_content 'Done 1'
|
|
should_see_todo(1, "John Doe assigned you merge request #{merge_request.to_reference(full: true)}", merge_request.title, state: :done_reversible)
|
|
end
|
|
|
|
step 'I mark all todos as done' do
|
|
merge_request_reference = merge_request.to_reference(full: true)
|
|
issue_reference = issue.to_reference(full: true)
|
|
|
|
find('.js-todos-mark-all').trigger('click')
|
|
|
|
page.within('.todos-count') { expect(page).to have_content '0' }
|
|
expect(page).to have_content 'To do 0'
|
|
expect(page).to have_content 'Done 4'
|
|
expect(page).to have_content "You're all done!"
|
|
expect('.prepend-top-default').not_to have_link project.name_with_namespace
|
|
should_not_see_todo "John Doe assigned you merge request #{merge_request_reference}"
|
|
should_not_see_todo "John Doe mentioned you on issue #{issue_reference}"
|
|
should_not_see_todo "John Doe assigned you issue #{issue_reference}"
|
|
should_not_see_todo "Mary Jane mentioned you on issue #{issue_reference}"
|
|
end
|
|
|
|
step 'I should see the todo marked as done' do
|
|
find('.todos-done a').trigger('click')
|
|
|
|
expect(page).to have_link project.name_with_namespace
|
|
should_see_todo(1, "John Doe assigned you merge request #{merge_request.to_reference(full: true)}", merge_request.title, state: :done_irreversible)
|
|
end
|
|
|
|
step 'I should see all todos marked as done' do
|
|
merge_request_reference = merge_request.to_reference(full: true)
|
|
issue_reference = issue.to_reference(full: true)
|
|
|
|
find('.todos-done a').trigger('click')
|
|
|
|
expect(page).to have_link project.name_with_namespace
|
|
should_see_todo(1, "John Doe assigned you merge request #{merge_request_reference}", merge_request.title, state: :done_irreversible)
|
|
should_see_todo(2, "John Doe mentioned you on issue #{issue_reference}", "#{current_user.to_reference} Wdyt?", state: :done_irreversible)
|
|
should_see_todo(3, "John Doe assigned you issue #{issue_reference}", issue.title, state: :done_irreversible)
|
|
should_see_todo(4, "Mary Jane mentioned you on issue #{issue_reference}", issue.title, state: :done_irreversible)
|
|
end
|
|
|
|
step 'I filter by "Enterprise"' do
|
|
click_button 'Project'
|
|
page.within '.dropdown-menu-project' do
|
|
click_link enterprise.name_with_namespace
|
|
end
|
|
end
|
|
|
|
step 'I filter by "John Doe"' do
|
|
click_button 'Author'
|
|
page.within '.dropdown-menu-author' do
|
|
click_link john_doe.username
|
|
end
|
|
end
|
|
|
|
step 'I filter by "Issue"' do
|
|
click_button 'Type'
|
|
page.within '.dropdown-menu-type' do
|
|
click_link 'Issue'
|
|
end
|
|
end
|
|
|
|
step 'I filter by "Mentioned"' do
|
|
click_button 'Action'
|
|
page.within '.dropdown-menu-action' do
|
|
click_link 'Mentioned'
|
|
end
|
|
end
|
|
|
|
step 'I should not see todos' do
|
|
expect(page).to have_content "You're all done!"
|
|
end
|
|
|
|
step 'I should not see todos related to "Mary Jane" in the list' do
|
|
should_not_see_todo "Mary Jane mentioned you on issue #{issue.to_reference(full: true)}"
|
|
end
|
|
|
|
step 'I should not see todos related to "Merge Requests" in the list' do
|
|
should_not_see_todo "John Doe assigned you merge request #{merge_request.to_reference(full: true)}"
|
|
end
|
|
|
|
step 'I should not see todos related to "Assignments" in the list' do
|
|
should_not_see_todo "John Doe assigned you merge request #{merge_request.to_reference(full: true)}"
|
|
should_not_see_todo "John Doe assigned you issue #{issue.to_reference(full: true)}"
|
|
end
|
|
|
|
step 'I click on the todo' do
|
|
find('.todo:nth-child(1)').click
|
|
end
|
|
|
|
step 'I should be directed to the corresponding page' do
|
|
page.should have_css('.identifier', text: 'Merge request !1')
|
|
# Merge request page loads and issues a number of Ajax requests
|
|
wait_for_requests
|
|
end
|
|
|
|
def should_see_todo(position, title, body, state: :pending)
|
|
page.within(".todo:nth-child(#{position})") do
|
|
expect(page).to have_content title
|
|
expect(page).to have_content body
|
|
|
|
if state == :pending
|
|
expect(page).to have_link 'Done'
|
|
elsif state == :done_reversible
|
|
expect(page).to have_link 'Undo'
|
|
elsif state == :done_irreversible
|
|
expect(page).not_to have_link 'Undo'
|
|
expect(page).not_to have_link 'Done'
|
|
else
|
|
raise 'Invalid state given, valid states: :pending, :done_reversible, :done_irreversible'
|
|
end
|
|
end
|
|
end
|
|
|
|
def should_not_see_todo(title)
|
|
expect(page).not_to have_visible_content title
|
|
end
|
|
|
|
def have_visible_content(text)
|
|
have_css('*', text: text, visible: true)
|
|
end
|
|
|
|
def john_doe
|
|
@john_doe ||= user_exists("John Doe", { username: "john_doe" })
|
|
end
|
|
|
|
def mary_jane
|
|
@mary_jane ||= user_exists("Mary Jane", { username: "mary_jane" })
|
|
end
|
|
|
|
def enterprise
|
|
@enterprise ||= Project.find_by(name: 'Enterprise')
|
|
end
|
|
|
|
def issue
|
|
@issue ||= create(:issue, assignees: [current_user], project: project)
|
|
end
|
|
|
|
def merge_request
|
|
@merge_request ||= create(:merge_request, assignee: current_user, source_project: project)
|
|
end
|
|
end
|