class Spinach::Features::ProjectIssues < Spinach::FeatureSteps include SharedAuthentication include SharedIssuable include SharedProject include SharedNote include SharedPaths include SharedMarkdown include SharedUser step 'I should see "Release 0.4" in issues' do expect(page).to have_content "Release 0.4" end step 'I should not see "Release 0.3" in issues' do expect(page).not_to have_content "Release 0.3" end step 'I should not see "Tweet control" in issues' do expect(page).not_to have_content "Tweet control" end step 'I should see that I am subscribed' do expect(find('.issuable-subscribe-button span')).to have_content 'Unsubscribe' end step 'I should see that I am unsubscribed' do expect(find('.issuable-subscribe-button span')).to have_content 'Subscribe' end step 'I click link "Closed"' do find('.issues-state-filters a', text: "Closed").click end step 'I click button "Unsubscribe"' do click_on "Unsubscribe" end step 'I should see "Release 0.3" in issues' do expect(page).to have_content "Release 0.3" end step 'I should not see "Release 0.4" in issues' do expect(page).not_to have_content "Release 0.4" end step 'I click link "All"' do click_link "All" # Waits for load expect(find('.issues-state-filters > .active')).to have_content 'All' end step 'I click link "Release 0.4"' do click_link "Release 0.4" end step 'I should see issue "Release 0.4"' do expect(page).to have_content "Release 0.4" end step 'I should see issue "Tweet control"' do expect(page).to have_content "Tweet control" end step 'I click link "New Issue"' do click_link "New Issue" end step 'I click "author" dropdown' do page.find('.js-author-search').click sleep 1 end step 'I see current user as the first user' do expect(page).to have_selector('.dropdown-content', visible: true) users = page.all('.dropdown-menu-author .dropdown-content li a') expect(users[0].text).to eq 'Any Author' expect(users[1].text).to eq "#{current_user.name} #{current_user.to_reference}" end step 'I submit new issue "500 error on profile"' do fill_in "issue_title", with: "500 error on profile" click_button "Submit issue" end step 'I submit new issue "500 error on profile" with label \'bug\'' do fill_in "issue_title", with: "500 error on profile" select 'bug', from: "Labels" click_button "Submit issue" end step 'I click link "500 error on profile"' do click_link "500 error on profile" end step 'I should see label \'bug\' with issue' do page.within '.issuable-show-labels' do expect(page).to have_content 'bug' end end step 'I should see issue "500 error on profile"' do issue = Issue.find_by(title: "500 error on profile") expect(page).to have_content issue.title expect(page).to have_content issue.author_name expect(page).to have_content issue.project.name end step 'I fill in issue search with "Re"' do filter_issue "Re" end step 'I fill in issue search with "Bu"' do filter_issue "Bu" end step 'I fill in issue search with ".3"' do filter_issue ".3" end step 'I fill in issue search with "Something"' do filter_issue "Something" end step 'I fill in issue search with ""' do filter_issue "" end step 'project "Shop" has milestone "v2.2"' do milestone = create(:milestone, title: "v2.2", project: project) 3.times { create(:issue, project: project, milestone: milestone) } end step 'project "Shop" has milestone "v3.0"' do milestone = create(:milestone, title: "v3.0", project: project) 3.times { create(:issue, project: project, milestone: milestone) } end When 'I select milestone "v3.0"' do select "v3.0", from: "milestone_id" end step 'I should see selected milestone with title "v3.0"' do issues_milestone_selector = "#issue_milestone_id_chzn > a" expect(find(issues_milestone_selector)).to have_content("v3.0") end When 'I select first assignee from "Shop" project' do first_assignee = project.users.first select first_assignee.name, from: "assignee_id" end step 'I should see first assignee from "Shop" as selected assignee' do issues_assignee_selector = "#issue_assignee_id_chzn > a" assignee_name = project.users.first.name expect(find(issues_assignee_selector)).to have_content(assignee_name) end step 'project "Shop" have "Release 0.4" open issue' do create(:issue, title: "Release 0.4", project: project, author: project.users.first, description: "# Description header" ) end step 'project "Shop" have "Tweet control" open issue' do create(:issue, title: "Tweet control", project: project, author: project.users.first) end step 'project "Shop" have "Bugfix" open issue' do create(:issue, title: "Bugfix", project: project, author: project.users.first) end step 'project "Shop" have "Release 0.3" closed issue' do create(:closed_issue, title: "Release 0.3", project: project, author: project.users.first) end step 'issue "Release 0.4" have 2 upvotes and 1 downvote' do awardable = Issue.find_by(title: 'Release 0.4') create_list(:award_emoji, 2, awardable: awardable) create(:award_emoji, :downvote, awardable: awardable) end step 'issue "Tweet control" have 1 upvote and 2 downvotes' do awardable = Issue.find_by(title: 'Tweet control') create(:award_emoji, :upvote, awardable: awardable) create_list(:award_emoji, 2, awardable: awardable, name: 'thumbsdown') end step 'The list should be sorted by "Least popular"' do page.within '.issues-list' do page.within 'li.issue:nth-child(1)' do expect(page).to have_content 'Tweet control' expect(page).to have_content '1 2' end page.within 'li.issue:nth-child(2)' do expect(page).to have_content 'Release 0.4' expect(page).to have_content '2 1' end page.within 'li.issue:nth-child(3)' do expect(page).to have_content 'Bugfix' expect(page).not_to have_content '0 0' end end end step 'The list should be sorted by "Most popular"' do page.within '.issues-list' do page.within 'li.issue:nth-child(1)' do expect(page).to have_content 'Release 0.4' expect(page).to have_content '2 1' end page.within 'li.issue:nth-child(2)' do expect(page).to have_content 'Tweet control' expect(page).to have_content '1 2' end page.within 'li.issue:nth-child(3)' do expect(page).to have_content 'Bugfix' expect(page).not_to have_content '0 0' end end end step 'empty project "Empty Project"' do create :project_empty_repo, name: 'Empty Project', namespace: @user.namespace end When 'I visit empty project page' do project = Project.find_by(name: 'Empty Project') visit namespace_project_path(project.namespace, project) end step 'I see empty project details with ssh clone info' do project = Project.find_by(name: 'Empty Project') page.all(:css, '.git-empty .clone').each do |element| expect(element.text).to include(project.url_to_repo) end end When "I visit project \"Community\" issues page" do project = Project.find_by(name: 'Community') visit namespace_project_issues_path(project.namespace, project) end When "I visit empty project's issues page" do project = Project.find_by(name: 'Empty Project') visit namespace_project_issues_path(project.namespace, project) end step 'I leave a comment with code block' do page.within(".js-main-target-form") do fill_in "note[note]", with: "```\nCommand [1]: /usr/local/bin/git , see [text](doc/text)\n```" click_button "Comment" sleep 0.05 end end step 'I should see an error alert section within the comment form' do page.within(".js-main-target-form") do find(".error-alert") end end step 'The code block should be unchanged' do expect(page).to have_content("```\nCommand [1]: /usr/local/bin/git , see [text](doc/text)\n```") end step 'project \'Shop\' has issue \'Bugfix1\' with description: \'Description for issue1\'' do create(:issue, title: 'Bugfix1', description: 'Description for issue1', project: project) end step 'project \'Shop\' has issue \'Feature1\' with description: \'Feature submitted for issue1\'' do create(:issue, title: 'Feature1', description: 'Feature submitted for issue1', project: project) end step 'I fill in issue search with \'Description for issue1\'' do filter_issue 'Description for issue' end step 'I fill in issue search with \'issue1\'' do filter_issue 'issue1' end step 'I fill in issue search with \'Rock and roll\'' do filter_issue 'Rock and roll' end step 'I should see \'Bugfix1\' in issues' do expect(page).to have_content 'Bugfix1' end step 'I should see \'Feature1\' in issues' do expect(page).to have_content 'Feature1' end step 'I should not see \'Bugfix1\' in issues' do expect(page).not_to have_content 'Bugfix1' end step 'issue \'Release 0.4\' has label \'bug\'' do label = project.labels.create!(name: 'bug', color: '#990000') issue = Issue.find_by!(title: 'Release 0.4') issue.labels << label end step 'I click label \'bug\'' do page.within ".issues-list" do click_link 'bug' end end step 'I should not see labels field' do page.within '.issue-form' do expect(page).not_to have_content("Labels") end end step 'I should not see milestone field' do page.within '.issue-form' do expect(page).not_to have_content("Milestone") end end step 'I should not see assignee field' do page.within '.issue-form' do expect(page).not_to have_content("Assign to") end end step 'another user adds a comment with text "Yay!" to issue "Release 0.4"' do issue = Issue.find_by!(title: 'Release 0.4') create(:note_on_issue, noteable: issue, project: project, note: 'Yay!') end step 'I should see a new comment with text "Yay!"' do page.within '#notes' do expect(page).to have_content('Yay!') end end def filter_issue(text) fill_in 'issuable_search', with: text end end