Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/features/issues_spec.rb')
-rw-r--r--spec/features/issues_spec.rb320
1 files changed, 0 insertions, 320 deletions
diff --git a/spec/features/issues_spec.rb b/spec/features/issues_spec.rb
deleted file mode 100644
index e5f33d5a25a..00000000000
--- a/spec/features/issues_spec.rb
+++ /dev/null
@@ -1,320 +0,0 @@
-require 'spec_helper'
-
-describe 'Issues', feature: true do
- include SortingHelper
-
- let(:project) { create(:project) }
-
- before do
- login_as :user
- user2 = create(:user)
-
- project.team << [[@user, user2], :developer]
- end
-
- describe 'Edit issue' do
- let!(:issue) do
- create(:issue,
- author: @user,
- assignee: @user,
- project: project)
- end
-
- before do
- visit namespace_project_issues_path(project.namespace, project)
- click_link "Edit"
- end
-
- it 'should open new issue popup' do
- expect(page).to have_content("Issue ##{issue.iid}")
- end
-
- describe 'fill in' do
- before do
- fill_in 'issue_title', with: 'bug 345'
- fill_in 'issue_description', with: 'bug description'
- end
-
- it 'does not change issue count' do
- expect {
- click_button 'Save changes'
- }.to_not change { Issue.count }
- end
-
- it 'should update issue fields' do
- click_button 'Save changes'
-
- expect(page).to have_content @user.name
- expect(page).to have_content 'bug 345'
- expect(page).to have_content project.name
- end
- end
-
- end
-
- describe 'Editing issue assignee' do
- let!(:issue) do
- create(:issue,
- author: @user,
- assignee: @user,
- project: project)
- end
-
- it 'allows user to select unasigned', js: true do
- visit edit_namespace_project_issue_path(project.namespace, project, issue)
-
- expect(page).to have_content "Assign to #{@user.name}"
-
- first('#s2id_issue_assignee_id').click
- sleep 2 # wait for ajax stuff to complete
- first('.user-result').click
-
- click_button 'Save changes'
-
- expect(page).to have_content 'Assignee: none'
- expect(issue.reload.assignee).to be_nil
- end
- end
-
- describe 'Filter issue' do
- before do
- ['foobar', 'barbaz', 'gitlab'].each do |title|
- create(:issue,
- author: @user,
- assignee: @user,
- project: project,
- title: title)
- end
-
- @issue = Issue.find_by(title: 'foobar')
- @issue.milestone = create(:milestone, project: project)
- @issue.assignee = nil
- @issue.save
- end
-
- let(:issue) { @issue }
-
- it 'should allow filtering by issues with no specified milestone' do
- visit namespace_project_issues_path(project.namespace, project, milestone_id: IssuableFinder::NONE)
-
- expect(page).not_to have_content 'foobar'
- expect(page).to have_content 'barbaz'
- expect(page).to have_content 'gitlab'
- end
-
- it 'should allow filtering by a specified milestone' do
- visit namespace_project_issues_path(project.namespace, project, milestone_id: issue.milestone.id)
-
- expect(page).to have_content 'foobar'
- expect(page).not_to have_content 'barbaz'
- expect(page).not_to have_content 'gitlab'
- end
-
- it 'should allow filtering by issues with no specified assignee' do
- visit namespace_project_issues_path(project.namespace, project, assignee_id: IssuableFinder::NONE)
-
- expect(page).to have_content 'foobar'
- expect(page).not_to have_content 'barbaz'
- expect(page).not_to have_content 'gitlab'
- end
-
- it 'should allow filtering by a specified assignee' do
- visit namespace_project_issues_path(project.namespace, project, assignee_id: @user.id)
-
- expect(page).not_to have_content 'foobar'
- expect(page).to have_content 'barbaz'
- expect(page).to have_content 'gitlab'
- end
- end
-
- describe 'filter issue' do
- titles = ['foo','bar','baz']
- titles.each_with_index do |title, index|
- let!(title.to_sym) do
- create(:issue, title: title,
- project: project,
- created_at: Time.now - (index * 60))
- end
- end
- let(:newer_due_milestone) { create(:milestone, due_date: '2013-12-11') }
- let(:later_due_milestone) { create(:milestone, due_date: '2013-12-12') }
-
- it 'sorts by newest' do
- visit namespace_project_issues_path(project.namespace, project, sort: sort_value_recently_created)
-
- expect(first_issue).to include('foo')
- expect(last_issue).to include('baz')
- end
-
- it 'sorts by oldest' do
- visit namespace_project_issues_path(project.namespace, project, sort: sort_value_oldest_created)
-
- expect(first_issue).to include('baz')
- expect(last_issue).to include('foo')
- end
-
- it 'sorts by most recently updated' do
- baz.updated_at = Time.now + 100
- baz.save
- visit namespace_project_issues_path(project.namespace, project, sort: sort_value_recently_updated)
-
- expect(first_issue).to include('baz')
- end
-
- it 'sorts by least recently updated' do
- baz.updated_at = Time.now - 100
- baz.save
- visit namespace_project_issues_path(project.namespace, project, sort: sort_value_oldest_updated)
-
- expect(first_issue).to include('baz')
- end
-
- describe 'sorting by milestone' do
- before :each do
- foo.milestone = newer_due_milestone
- foo.save
- bar.milestone = later_due_milestone
- bar.save
- end
-
- it 'sorts by recently due milestone' do
- visit namespace_project_issues_path(project.namespace, project, sort: sort_value_milestone_soon)
-
- expect(first_issue).to include('foo')
- end
-
- it 'sorts by least recently due milestone' do
- visit namespace_project_issues_path(project.namespace, project, sort: sort_value_milestone_later)
-
- expect(first_issue).to include('bar')
- end
- end
-
- describe 'combine filter and sort' do
- let(:user2) { create(:user) }
-
- before :each do
- foo.assignee = user2
- foo.save
- bar.assignee = user2
- bar.save
- end
-
- it 'sorts with a filter applied' do
- visit namespace_project_issues_path(project.namespace, project,
- sort: sort_value_oldest_created,
- assignee_id: user2.id)
-
- expect(first_issue).to include('bar')
- expect(last_issue).to include('foo')
- expect(page).not_to have_content 'baz'
- end
- end
- end
-
- describe 'update assignee from issue#show' do
- let(:issue) { create(:issue, project: project, author: @user) }
-
- context 'by autorized user' do
-
- it 'with dropdown menu' do
- visit namespace_project_issue_path(project.namespace, project, issue)
-
- find('.edit-issue.inline-update #issue_assignee_id').
- set project.team.members.first.id
- click_button 'Update Issue'
-
- expect(page).to have_content 'Assignee:'
- has_select?('issue_assignee_id',
- selected: project.team.members.first.name)
- end
- end
-
- context 'by unauthorized user' do
-
- let(:guest) { create(:user) }
-
- before :each do
- project.team << [[guest], :guest]
- issue.assignee = @user
- issue.save
- end
-
- it 'shows assignee text', js: true do
- logout
- login_with guest
-
- visit namespace_project_issue_path(project.namespace, project, issue)
- expect(page).to have_content issue.assignee.name
- end
- end
- end
-
- describe 'update milestone from issue#show' do
- let!(:issue) { create(:issue, project: project, author: @user) }
- let!(:milestone) { create(:milestone, project: project) }
-
- context 'by authorized user' do
-
- it 'with dropdown menu' do
- visit namespace_project_issue_path(project.namespace, project, issue)
-
- find('.edit-issue.inline-update').
- select(milestone.title, from: 'issue_milestone_id')
- click_button 'Update Issue'
-
- expect(page).to have_content "Milestone changed to #{milestone.title}"
- expect(page).to have_content "Milestone: #{milestone.title}"
- has_select?('issue_assignee_id', selected: milestone.title)
- end
- end
-
- context 'by unauthorized user' do
- let(:guest) { create(:user) }
-
- before :each do
- project.team << [guest, :guest]
- issue.milestone = milestone
- issue.save
- end
-
- it 'shows milestone text', js: true do
- logout
- login_with guest
-
- visit namespace_project_issue_path(project.namespace, project, issue)
- expect(page).to have_content milestone.title
- end
- end
-
- describe 'removing assignee' do
- let(:user2) { create(:user) }
-
- before :each do
- issue.assignee = user2
- issue.save
- end
-
- it 'allows user to remove assignee', :js => true do
- visit namespace_project_issue_path(project.namespace, project, issue)
- expect(page).to have_content "Assignee: #{user2.name}"
-
- first('#s2id_issue_assignee_id').click
- sleep 2 # wait for ajax stuff to complete
- first('.user-result').click
-
- expect(page).to have_content 'Assignee: none'
- sleep 2 # wait for ajax stuff to complete
- expect(issue.reload.assignee).to be_nil
- end
- end
- end
-
- def first_issue
- all('ul.issues-list li').first.text
- end
-
- def last_issue
- all('ul.issues-list li').last.text
- end
-end