164 lines
4.5 KiB
Ruby
164 lines
4.5 KiB
Ruby
require 'rails_helper'
|
|
|
|
feature 'Issues > User uses slash commands', feature: true, js: true do
|
|
include SlashCommandsHelpers
|
|
|
|
it_behaves_like 'issuable record that supports slash commands in its description and notes', :issue do
|
|
let(:issuable) { create(:issue, project: project) }
|
|
end
|
|
|
|
describe 'issue-only commands' do
|
|
let(:user) { create(:user) }
|
|
let(:project) { create(:project, :public) }
|
|
|
|
before do
|
|
project.team << [user, :master]
|
|
login_with(user)
|
|
visit namespace_project_issue_path(project.namespace, project, issue)
|
|
end
|
|
|
|
after do
|
|
wait_for_ajax
|
|
end
|
|
|
|
describe 'adding a due date from note' do
|
|
let(:issue) { create(:issue, project: project) }
|
|
|
|
context 'when the current user can update the due date' do
|
|
it 'does not create a note, and sets the due date accordingly' do
|
|
write_note("/due 2016-08-28")
|
|
|
|
expect(page).not_to have_content '/due 2016-08-28'
|
|
expect(page).to have_content 'Commands applied'
|
|
|
|
issue.reload
|
|
|
|
expect(issue.due_date).to eq Date.new(2016, 8, 28)
|
|
end
|
|
end
|
|
|
|
context 'when the current user cannot update the due date' do
|
|
let(:guest) { create(:user) }
|
|
before do
|
|
project.team << [guest, :guest]
|
|
logout
|
|
login_with(guest)
|
|
visit namespace_project_issue_path(project.namespace, project, issue)
|
|
end
|
|
|
|
it 'does not create a note, and sets the due date accordingly' do
|
|
write_note("/due 2016-08-28")
|
|
|
|
expect(page).to have_content '/due 2016-08-28'
|
|
expect(page).not_to have_content 'Commands applied'
|
|
|
|
issue.reload
|
|
|
|
expect(issue.due_date).to be_nil
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'removing a due date from note' do
|
|
let(:issue) { create(:issue, project: project, due_date: Date.new(2016, 8, 28)) }
|
|
|
|
context 'when the current user can update the due date' do
|
|
it 'does not create a note, and removes the due date accordingly' do
|
|
expect(issue.due_date).to eq Date.new(2016, 8, 28)
|
|
|
|
write_note("/remove_due_date")
|
|
|
|
expect(page).not_to have_content '/remove_due_date'
|
|
expect(page).to have_content 'Commands applied'
|
|
|
|
issue.reload
|
|
|
|
expect(issue.due_date).to be_nil
|
|
end
|
|
end
|
|
|
|
context 'when the current user cannot update the due date' do
|
|
let(:guest) { create(:user) }
|
|
before do
|
|
project.team << [guest, :guest]
|
|
logout
|
|
login_with(guest)
|
|
visit namespace_project_issue_path(project.namespace, project, issue)
|
|
end
|
|
|
|
it 'does not create a note, and sets the due date accordingly' do
|
|
write_note("/remove_due_date")
|
|
|
|
expect(page).to have_content '/remove_due_date'
|
|
expect(page).not_to have_content 'Commands applied'
|
|
|
|
issue.reload
|
|
|
|
expect(issue.due_date).to eq Date.new(2016, 8, 28)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'Issuable time tracking' do
|
|
let(:issue) { create(:issue, project: project) }
|
|
|
|
before do
|
|
project.team << [user, :developer]
|
|
end
|
|
|
|
context 'Issue' do
|
|
before do
|
|
visit namespace_project_issue_path(project.namespace, project, issue)
|
|
end
|
|
|
|
it_behaves_like 'issuable time tracker'
|
|
end
|
|
|
|
context 'Merge Request' do
|
|
let(:merge_request) { create(:merge_request, source_project: project) }
|
|
|
|
before do
|
|
visit namespace_project_merge_request_path(project.namespace, project, merge_request)
|
|
end
|
|
|
|
it_behaves_like 'issuable time tracker'
|
|
end
|
|
end
|
|
|
|
describe 'Issuable time tracking' do
|
|
let(:issue) { create(:issue, project: project) }
|
|
|
|
before do
|
|
project.team << [user, :developer]
|
|
end
|
|
|
|
context 'Issue' do
|
|
before do
|
|
visit namespace_project_issue_path(project.namespace, project, issue)
|
|
end
|
|
|
|
it_behaves_like 'issuable time tracker'
|
|
end
|
|
|
|
context 'Merge Request' do
|
|
let(:merge_request) { create(:merge_request, source_project: project) }
|
|
|
|
before do
|
|
visit namespace_project_merge_request_path(project.namespace, project, merge_request)
|
|
end
|
|
|
|
it_behaves_like 'issuable time tracker'
|
|
end
|
|
end
|
|
|
|
describe 'toggling the WIP prefix from the title from note' do
|
|
let(:issue) { create(:issue, project: project) }
|
|
|
|
it 'does not recognize the command nor create a note' do
|
|
write_note("/wip")
|
|
|
|
expect(page).not_to have_content '/wip'
|
|
end
|
|
end
|
|
end
|
|
end
|