debian-mirror-gitlab/spec/features/issues_spec.rb

722 lines
21 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
require 'spec_helper'
2015-04-26 12:48:37 +05:30
describe 'Issues', feature: true do
2017-08-17 22:00:37 +05:30
include DropzoneHelper
2016-09-13 17:45:13 +05:30
include IssueHelpers
2015-04-26 12:48:37 +05:30
include SortingHelper
2017-08-17 22:00:37 +05:30
let(:project) { create(:empty_project, :public) }
2014-09-02 18:07:02 +05:30
before do
login_as :user
user2 = create(:user)
project.team << [[@user, user2], :developer]
end
2015-04-26 12:48:37 +05:30
describe 'Edit issue' do
2014-09-02 18:07:02 +05:30
let!(:issue) do
create(:issue,
author: @user,
2017-08-17 22:00:37 +05:30
assignees: [@user],
2014-09-02 18:07:02 +05:30
project: project)
end
before do
2015-09-11 14:41:01 +05:30
visit edit_namespace_project_issue_path(project.namespace, project, issue)
2016-08-24 12:49:21 +05:30
find('.js-zen-enter').click
2014-09-02 18:07:02 +05:30
end
2016-09-13 17:45:13 +05:30
it 'opens new issue popup' do
2015-04-26 12:48:37 +05:30
expect(page).to have_content("Issue ##{issue.iid}")
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
describe 'fill in' do
2014-09-02 18:07:02 +05:30
before do
2015-04-26 12:48:37 +05:30
fill_in 'issue_title', with: 'bug 345'
fill_in 'issue_description', with: 'bug description'
2014-09-02 18:07:02 +05:30
end
end
end
2015-04-26 12:48:37 +05:30
describe 'Editing issue assignee' do
2014-09-02 18:07:02 +05:30
let!(:issue) do
create(:issue,
author: @user,
2017-08-17 22:00:37 +05:30
assignees: [@user],
2014-09-02 18:07:02 +05:30
project: project)
end
2016-06-02 11:05:42 +05:30
it 'allows user to select unassigned', js: true do
2015-04-26 12:48:37 +05:30
visit edit_namespace_project_issue_path(project.namespace, project, issue)
2014-09-02 18:07:02 +05:30
2015-12-23 02:04:40 +05:30
expect(page).to have_content "Assignee #{@user.name}"
2014-09-02 18:07:02 +05:30
2016-11-03 12:29:30 +05:30
first('.js-user-search').click
click_link 'Unassigned'
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
click_button 'Save changes'
2014-09-02 18:07:02 +05:30
2015-12-23 02:04:40 +05:30
page.within('.assignee') do
2016-06-02 11:05:42 +05:30
expect(page).to have_content 'No assignee - assign yourself'
2015-12-23 02:04:40 +05:30
end
2017-08-17 22:00:37 +05:30
expect(issue.reload.assignees).to be_empty
2014-09-02 18:07:02 +05:30
end
end
describe 'due date', js: true do
context 'on new form' do
before do
visit new_namespace_project_issue_path(project.namespace, project)
end
2016-09-13 17:45:13 +05:30
it 'saves with due date' do
date = Date.today.at_beginning_of_month
fill_in 'issue_title', with: 'bug 345'
fill_in 'issue_description', with: 'bug description'
find('#issuable-due-date').click
2017-08-17 22:00:37 +05:30
page.within '.pika-single' do
click_button date.day
end
expect(find('#issuable-due-date').value).to eq date.to_s
click_button 'Submit issue'
page.within '.issuable-sidebar' do
expect(page).to have_content date.to_s(:medium)
end
end
end
context 'on edit form' do
2016-08-24 12:49:21 +05:30
let(:issue) { create(:issue, author: @user, project: project, due_date: Date.today.at_beginning_of_month.to_s) }
before do
visit edit_namespace_project_issue_path(project.namespace, project, issue)
end
2016-09-13 17:45:13 +05:30
it 'saves with due date' do
date = Date.today.at_beginning_of_month
expect(find('#issuable-due-date').value).to eq date.to_s
date = date.tomorrow
fill_in 'issue_title', with: 'bug 345'
fill_in 'issue_description', with: 'bug description'
find('#issuable-due-date').click
2017-08-17 22:00:37 +05:30
page.within '.pika-single' do
click_button date.day
end
expect(find('#issuable-due-date').value).to eq date.to_s
click_button 'Save changes'
page.within '.issuable-sidebar' do
expect(page).to have_content date.to_s(:medium)
end
end
2016-09-29 09:46:39 +05:30
it 'warns about version conflict' do
issue.update(title: "New title")
fill_in 'issue_title', with: 'bug 345'
fill_in 'issue_description', with: 'bug description'
click_button 'Save changes'
expect(page).to have_content 'Someone edited the issue the same time you did'
end
end
end
2016-06-02 11:05:42 +05:30
describe 'Issue info' do
it 'excludes award_emoji from comment count' do
2017-08-17 22:00:37 +05:30
issue = create(:issue, author: @user, assignees: [@user], project: project, title: 'foobar')
create(:award_emoji, awardable: issue)
2016-06-02 11:05:42 +05:30
visit namespace_project_issues_path(project.namespace, project, assignee_id: @user.id)
expect(page).to have_content 'foobar'
2016-09-29 09:46:39 +05:30
expect(page.all('.no-comments').first.text).to eq "0"
2016-06-02 11:05:42 +05:30
end
end
2015-04-26 12:48:37 +05:30
describe 'Filter issue' do
2014-09-02 18:07:02 +05:30
before do
2017-08-17 22:00:37 +05:30
%w(foobar barbaz gitlab).each do |title|
2014-09-02 18:07:02 +05:30
create(:issue,
author: @user,
2017-08-17 22:00:37 +05:30
assignees: [@user],
2014-09-02 18:07:02 +05:30
project: project,
title: title)
end
2015-04-26 12:48:37 +05:30
@issue = Issue.find_by(title: 'foobar')
2014-09-02 18:07:02 +05:30
@issue.milestone = create(:milestone, project: project)
2017-08-17 22:00:37 +05:30
@issue.assignees = []
2014-09-02 18:07:02 +05:30
@issue.save
end
let(:issue) { @issue }
2016-09-13 17:45:13 +05:30
it 'allows filtering by issues with no specified assignee' do
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, assignee_id: IssuableFinder::NONE)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
expect(page).to have_content 'foobar'
expect(page).not_to have_content 'barbaz'
expect(page).not_to have_content 'gitlab'
2014-09-02 18:07:02 +05:30
end
2016-09-13 17:45:13 +05:30
it 'allows filtering by a specified assignee' do
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, assignee_id: @user.id)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
expect(page).not_to have_content 'foobar'
expect(page).to have_content 'barbaz'
expect(page).to have_content 'gitlab'
2014-09-02 18:07:02 +05:30
end
end
describe 'filter issue' do
2016-06-02 11:05:42 +05:30
titles = %w[foo bar baz]
2014-09-02 18:07:02 +05:30
titles.each_with_index do |title, index|
2015-04-26 12:48:37 +05:30
let!(title.to_sym) do
create(:issue, title: title,
project: project,
created_at: Time.now - (index * 60))
end
2014-09-02 18:07:02 +05:30
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
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_recently_created)
2014-09-02 18:07:02 +05:30
2016-09-13 17:45:13 +05:30
expect(first_issue).to include('foo')
expect(last_issue).to include('baz')
2014-09-02 18:07:02 +05:30
end
it 'sorts by oldest' do
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_oldest_created)
2014-09-02 18:07:02 +05:30
2016-09-13 17:45:13 +05:30
expect(first_issue).to include('baz')
expect(last_issue).to include('foo')
2014-09-02 18:07:02 +05:30
end
it 'sorts by most recently updated' do
baz.updated_at = Time.now + 100
baz.save
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_recently_updated)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
expect(first_issue).to include('baz')
2014-09-02 18:07:02 +05:30
end
it 'sorts by least recently updated' do
baz.updated_at = Time.now - 100
baz.save
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_oldest_updated)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
expect(first_issue).to include('baz')
2014-09-02 18:07:02 +05:30
end
2016-06-02 11:05:42 +05:30
describe 'sorting by due date' do
before do
foo.update(due_date: 1.day.from_now)
bar.update(due_date: 6.days.from_now)
end
it 'sorts by recently due date' do
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_due_date_soon)
expect(first_issue).to include('foo')
end
it 'sorts by least recently due date' do
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_due_date_later)
expect(first_issue).to include('bar')
end
it 'sorts by least recently due date by excluding nil due dates' do
bar.update(due_date: nil)
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_due_date_later)
expect(first_issue).to include('foo')
end
context 'with a filter on labels' do
let(:label) { create(:label, project: project) }
before { create(:label_link, label: label, target: foo) }
it 'sorts by least recently due date by excluding nil due dates' do
bar.update(due_date: nil)
visit namespace_project_issues_path(project.namespace, project, label_names: [label.name], sort: sort_value_due_date_later)
expect(first_issue).to include('foo')
end
end
end
describe 'filtering by due date' do
before do
foo.update(due_date: 1.day.from_now)
bar.update(due_date: 6.days.from_now)
end
it 'filters by none' do
visit namespace_project_issues_path(project.namespace, project, due_date: Issue::NoDueDate.name)
expect(page).not_to have_content('foo')
expect(page).not_to have_content('bar')
expect(page).to have_content('baz')
end
it 'filters by any' do
visit namespace_project_issues_path(project.namespace, project, due_date: Issue::AnyDueDate.name)
expect(page).to have_content('foo')
expect(page).to have_content('bar')
expect(page).to have_content('baz')
end
it 'filters by due this week' do
foo.update(due_date: Date.today.beginning_of_week + 2.days)
bar.update(due_date: Date.today.end_of_week)
baz.update(due_date: Date.today - 8.days)
visit namespace_project_issues_path(project.namespace, project, due_date: Issue::DueThisWeek.name)
expect(page).to have_content('foo')
expect(page).to have_content('bar')
expect(page).not_to have_content('baz')
end
it 'filters by due this month' do
foo.update(due_date: Date.today.beginning_of_month + 2.days)
bar.update(due_date: Date.today.end_of_month)
baz.update(due_date: Date.today - 50.days)
visit namespace_project_issues_path(project.namespace, project, due_date: Issue::DueThisMonth.name)
expect(page).to have_content('foo')
expect(page).to have_content('bar')
expect(page).not_to have_content('baz')
end
it 'filters by overdue' do
foo.update(due_date: Date.today + 2.days)
bar.update(due_date: Date.today + 20.days)
baz.update(due_date: Date.yesterday)
visit namespace_project_issues_path(project.namespace, project, due_date: Issue::Overdue.name)
expect(page).not_to have_content('foo')
expect(page).not_to have_content('bar')
expect(page).to have_content('baz')
end
end
2014-09-02 18:07:02 +05:30
describe 'sorting by milestone' do
2016-06-02 11:05:42 +05:30
before do
2014-09-02 18:07:02 +05:30
foo.milestone = newer_due_milestone
foo.save
bar.milestone = later_due_milestone
bar.save
end
it 'sorts by recently due milestone' do
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_milestone_soon)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
expect(first_issue).to include('foo')
2016-06-02 11:05:42 +05:30
expect(last_issue).to include('baz')
2014-09-02 18:07:02 +05:30
end
it 'sorts by least recently due milestone' do
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project, sort: sort_value_milestone_later)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
expect(first_issue).to include('bar')
2016-06-02 11:05:42 +05:30
expect(last_issue).to include('baz')
2014-09-02 18:07:02 +05:30
end
end
describe 'combine filter and sort' do
let(:user2) { create(:user) }
2016-06-02 11:05:42 +05:30
before do
2017-08-17 22:00:37 +05:30
foo.assignees << user2
2014-09-02 18:07:02 +05:30
foo.save
2017-08-17 22:00:37 +05:30
bar.assignees << user2
2014-09-02 18:07:02 +05:30
bar.save
end
it 'sorts with a filter applied' do
2015-04-26 12:48:37 +05:30
visit namespace_project_issues_path(project.namespace, project,
sort: sort_value_oldest_created,
assignee_id: user2.id)
2014-09-02 18:07:02 +05:30
2016-09-13 17:45:13 +05:30
expect(first_issue).to include('bar')
expect(last_issue).to include('foo')
2015-04-26 12:48:37 +05:30
expect(page).not_to have_content 'baz'
2014-09-02 18:07:02 +05:30
end
end
end
2017-08-17 22:00:37 +05:30
describe 'when I want to reset my incoming email token' do
let(:project1) { create(:empty_project, namespace: @user.namespace) }
let!(:issue) { create(:issue, project: project1) }
before do
stub_incoming_email_setting(enabled: true, address: "p+%{key}@gl.ab")
project1.team << [@user, :master]
visit namespace_project_issues_path(@user.namespace, project1)
end
it 'changes incoming email address token', js: true do
find('.issue-email-modal-btn').click
previous_token = find('input#issue_email').value
find('.incoming-email-token-reset').trigger('click')
wait_for_ajax
expect(page).to have_no_field('issue_email', with: previous_token)
new_token = project1.new_issue_address(@user.reload)
expect(page).to have_field(
'issue_email',
with: new_token
)
end
end
2016-10-01 15:18:49 +05:30
describe 'update labels from issue#show', js: true do
2017-08-17 22:00:37 +05:30
let(:issue) { create(:issue, project: project, author: @user, assignees: [@user]) }
2016-10-01 15:18:49 +05:30
let!(:label) { create(:label, project: project) }
before do
visit namespace_project_issue_path(project.namespace, project, issue)
end
it 'will not send ajax request when no data is changed' do
page.within '.labels' do
click_link 'Edit'
2017-08-17 22:00:37 +05:30
find('.dropdown-menu-close', match: :first).click
2016-10-01 15:18:49 +05:30
expect(page).not_to have_selector('.block-loading')
end
end
end
2014-09-02 18:07:02 +05:30
describe 'update assignee from issue#show' do
2017-08-17 22:00:37 +05:30
let(:issue) { create(:issue, project: project, author: @user, assignees: [@user]) }
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
context 'by authorized user' do
it 'allows user to select unassigned', js: true do
2015-04-26 12:48:37 +05:30
visit namespace_project_issue_path(project.namespace, project, issue)
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
page.within('.assignee') do
expect(page).to have_content "#{@user.name}"
click_link 'Edit'
click_link 'Unassigned'
2017-08-17 22:00:37 +05:30
first('.title').click
2016-06-02 11:05:42 +05:30
expect(page).to have_content 'No assignee'
end
2017-08-17 22:00:37 +05:30
# wait_for_ajax does not work with vue-resource at the moment
sleep 1
expect(issue.reload.assignees).to be_empty
2016-06-02 11:05:42 +05:30
end
it 'allows user to select an assignee', js: true do
issue2 = create(:issue, project: project, author: @user)
visit namespace_project_issue_path(project.namespace, project, issue2)
page.within('.assignee') do
expect(page).to have_content "No assignee"
end
page.within '.assignee' do
click_link 'Edit'
end
2016-06-02 11:05:42 +05:30
page.within '.dropdown-menu-user' do
click_link @user.name
end
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
page.within('.assignee') do
expect(page).to have_content @user.name
end
2014-09-02 18:07:02 +05:30
end
it 'allows user to unselect themselves', js: true do
issue2 = create(:issue, project: project, author: @user)
visit namespace_project_issue_path(project.namespace, project, issue2)
page.within '.assignee' do
click_link 'Edit'
click_link @user.name
2017-08-17 22:00:37 +05:30
page.within '.value .author' do
expect(page).to have_content @user.name
end
click_link 'Edit'
click_link @user.name
2017-08-17 22:00:37 +05:30
page.within '.value .assign-yourself' do
expect(page).to have_content "No assignee"
end
end
end
2014-09-02 18:07:02 +05:30
end
context 'by unauthorized user' do
let(:guest) { create(:user) }
2016-06-02 11:05:42 +05:30
before do
2014-09-02 18:07:02 +05:30
project.team << [[guest], :guest]
end
2015-04-26 12:48:37 +05:30
it 'shows assignee text', js: true do
2014-09-02 18:07:02 +05:30
logout
login_with guest
2015-04-26 12:48:37 +05:30
visit namespace_project_issue_path(project.namespace, project, issue)
2017-08-17 22:00:37 +05:30
expect(page).to have_content issue.assignees.first.name
2014-09-02 18:07:02 +05:30
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
2016-06-02 11:05:42 +05:30
it 'allows user to select unassigned', js: true do
visit namespace_project_issue_path(project.namespace, project, issue)
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
page.within('.milestone') do
expect(page).to have_content "None"
end
2015-12-23 02:04:40 +05:30
2016-06-02 11:05:42 +05:30
find('.block.milestone .edit-link').click
sleep 2 # wait for ajax stuff to complete
first('.dropdown-content li').click
sleep 2
2015-12-23 02:04:40 +05:30
page.within('.milestone') do
2016-06-02 11:05:42 +05:30
expect(page).to have_content 'None'
2015-12-23 02:04:40 +05:30
end
2016-06-02 11:05:42 +05:30
expect(issue.reload.milestone).to be_nil
2014-09-02 18:07:02 +05:30
end
it 'allows user to de-select milestone', js: true do
visit namespace_project_issue_path(project.namespace, project, issue)
page.within('.milestone') do
click_link 'Edit'
click_link milestone.title
page.within '.value' do
expect(page).to have_content milestone.title
end
click_link 'Edit'
click_link milestone.title
page.within '.value' do
expect(page).to have_content 'None'
end
end
end
2014-09-02 18:07:02 +05:30
end
context 'by unauthorized user' do
let(:guest) { create(:user) }
2016-06-02 11:05:42 +05:30
before do
2014-09-02 18:07:02 +05:30
project.team << [guest, :guest]
issue.milestone = milestone
issue.save
end
2015-04-26 12:48:37 +05:30
it 'shows milestone text', js: true do
2014-09-02 18:07:02 +05:30
logout
login_with guest
2015-04-26 12:48:37 +05:30
visit namespace_project_issue_path(project.namespace, project, issue)
expect(page).to have_content milestone.title
2014-09-02 18:07:02 +05:30
end
end
describe 'removing assignee' do
let(:user2) { create(:user) }
2016-06-02 11:05:42 +05:30
before do
2017-08-17 22:00:37 +05:30
issue.assignees << user2
2014-09-02 18:07:02 +05:30
issue.save
end
2016-06-02 11:05:42 +05:30
end
end
describe 'new issue' do
2017-08-17 22:00:37 +05:30
context 'by unauthenticated user' do
before do
logout
end
it 'redirects to signin then back to new issue after signin' do
visit namespace_project_issues_path(project.namespace, project)
click_link 'New issue'
expect(current_path).to eq new_user_session_path
login_as :user
expect(current_path).to eq new_namespace_project_issue_path(project.namespace, project)
end
end
2016-06-02 11:05:42 +05:30
context 'dropzone upload file', js: true do
before do
visit new_namespace_project_issue_path(project.namespace, project)
end
2016-09-13 17:45:13 +05:30
it 'uploads file when dragging into textarea' do
2017-08-17 22:00:37 +05:30
dropzone_file Rails.root.join('spec', 'fixtures', 'banana_sample.gif')
2016-06-02 11:05:42 +05:30
expect(page.find_field("issue_description").value).to have_content 'banana_sample'
end
2017-08-17 22:00:37 +05:30
it "doesn't add double newline to end of a single attachment markdown" do
dropzone_file Rails.root.join('spec', 'fixtures', 'banana_sample.gif')
expect(page.find_field("issue_description").value).not_to match /\n\n$/
end
end
context 'form filled by URL parameters' do
let(:project) { create(:project, :public, :repository) }
before do
project.repository.create_file(
@user,
'.gitlab/issue_templates/bug.md',
'this is a test "bug" template',
message: 'added issue template',
branch_name: 'master')
visit new_namespace_project_issue_path(project.namespace, project, issuable_template: 'bug')
end
it 'fills in template' do
expect(find('.js-issuable-selector .dropdown-toggle-text')).to have_content('bug')
end
2016-06-02 11:05:42 +05:30
end
end
2017-08-17 22:00:37 +05:30
describe 'new issue by email' do
2016-09-13 17:45:13 +05:30
shared_examples 'show the email in the modal' do
2017-08-17 22:00:37 +05:30
let(:issue) { create(:issue, project: project) }
2016-09-13 17:45:13 +05:30
before do
2017-08-17 22:00:37 +05:30
project.issues << issue
2016-09-13 17:45:13 +05:30
stub_incoming_email_setting(enabled: true, address: "p+%{key}@gl.ab")
visit namespace_project_issues_path(project.namespace, project)
click_button('Email a new issue')
end
it 'click the button to show modal for the new email' do
page.within '#issue-email-modal' do
email = project.new_issue_address(@user)
expect(page).to have_selector("input[value='#{email}']")
end
end
end
context 'with existing issues' do
let!(:issue) { create(:issue, project: project, author: @user) }
it_behaves_like 'show the email in the modal'
end
context 'without existing issues' do
it_behaves_like 'show the email in the modal'
end
end
2016-06-02 11:05:42 +05:30
describe 'due date' do
context 'update due on issue#show', js: true do
2017-08-17 22:00:37 +05:30
let(:issue) { create(:issue, project: project, author: @user, assignees: [@user]) }
2016-06-02 11:05:42 +05:30
before do
2015-04-26 12:48:37 +05:30
visit namespace_project_issue_path(project.namespace, project, issue)
2016-06-02 11:05:42 +05:30
end
2014-09-02 18:07:02 +05:30
2016-09-13 17:45:13 +05:30
it 'adds due date to issue' do
2017-08-17 22:00:37 +05:30
date = Date.today.at_beginning_of_month + 2.days
2016-06-02 11:05:42 +05:30
page.within '.due_date' do
click_link 'Edit'
2017-08-17 22:00:37 +05:30
page.within '.pika-single' do
click_button date.day
2016-06-02 11:05:42 +05:30
end
2017-08-17 22:00:37 +05:30
wait_for_ajax
expect(find('.value').text).to have_content date.strftime('%b %-d, %Y')
2015-12-23 02:04:40 +05:30
end
2016-06-02 11:05:42 +05:30
end
2015-12-23 02:04:40 +05:30
2016-09-13 17:45:13 +05:30
it 'removes due date from issue' do
2017-08-17 22:00:37 +05:30
date = Date.today.at_beginning_of_month + 2.days
2016-06-02 11:05:42 +05:30
page.within '.due_date' do
click_link 'Edit'
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
page.within '.pika-single' do
click_button date.day
2016-06-02 11:05:42 +05:30
end
2017-08-17 22:00:37 +05:30
wait_for_ajax
2016-06-22 15:30:34 +05:30
expect(page).to have_no_content 'No due date'
2016-06-02 11:05:42 +05:30
click_link 'remove due date'
2016-06-22 15:30:34 +05:30
expect(page).to have_content 'No due date'
2015-12-23 02:04:40 +05:30
end
2014-09-02 18:07:02 +05:30
end
end
end
2017-08-17 22:00:37 +05:30
describe 'title issue#show', js: true do
include WaitForVueResource
2016-06-02 11:05:42 +05:30
2017-08-17 22:00:37 +05:30
it 'updates the title', js: true do
issue = create(:issue, author: @user, assignees: [@user], project: project, title: 'new title')
visit namespace_project_issue_path(project.namespace, project, issue)
expect(page).to have_text("new title")
issue.update(title: "updated title")
wait_for_vue_resource
expect(page).to have_text("updated title")
end
2016-06-02 11:05:42 +05:30
end
2014-09-02 18:07:02 +05:30
end