debian-mirror-gitlab/spec/features/projects/issuable_templates_spec.rb

153 lines
5.5 KiB
Ruby
Raw Normal View History

2016-09-13 17:45:13 +05:30
require 'spec_helper'
feature 'issuable templates', feature: true, js: true do
include WaitForAjax
let(:user) { create(:user) }
let(:project) { create(:project, :public) }
before do
project.team << [user, :master]
login_as user
end
context 'user creates an issue using templates' do
let(:template_content) { 'this is a test "bug" template' }
2016-09-29 09:46:39 +05:30
let(:longtemplate_content) { %Q(this\n\n\n\n\nis\n\n\n\n\na\n\n\n\n\nbug\n\n\n\n\ntemplate) }
2016-09-13 17:45:13 +05:30
let(:issue) { create(:issue, author: user, assignee: user, project: project) }
2016-11-03 12:29:30 +05:30
let(:description_addition) { ' appending to description' }
2016-09-13 17:45:13 +05:30
background do
project.repository.commit_file(user, '.gitlab/issue_templates/bug.md', template_content, 'added issue template', 'master', false)
2016-09-29 09:46:39 +05:30
project.repository.commit_file(user, '.gitlab/issue_templates/test.md', longtemplate_content, 'added issue template', 'master', false)
2016-09-13 17:45:13 +05:30
visit edit_namespace_project_issue_path project.namespace, project, issue
fill_in :'issue[title]', with: 'test issue title'
end
scenario 'user selects "bug" template' do
select_template 'bug'
wait_for_ajax
preview_template
save_changes
end
2016-09-29 09:46:39 +05:30
2016-11-03 12:29:30 +05:30
scenario 'user selects "bug" template and then "no template"' do
select_template 'bug'
wait_for_ajax
select_option 'No template'
wait_for_ajax
preview_template('')
save_changes('')
end
scenario 'user selects "bug" template, edits description and then selects "reset template"' do
select_template 'bug'
wait_for_ajax
find_field('issue_description').send_keys(description_addition)
preview_template(template_content + description_addition)
select_option 'Reset template'
preview_template
save_changes
end
2016-09-29 09:46:39 +05:30
it 'updates height of markdown textarea' do
start_height = page.evaluate_script('$(".markdown-area").outerHeight()')
select_template 'test'
wait_for_ajax
end_height = page.evaluate_script('$(".markdown-area").outerHeight()')
2016-11-03 12:29:30 +05:30
2016-09-29 09:46:39 +05:30
expect(end_height).not_to eq(start_height)
end
2016-09-13 17:45:13 +05:30
end
2016-11-03 12:29:30 +05:30
context 'user creates an issue using templates, with a prior description' do
let(:prior_description) { 'test issue description' }
let(:template_content) { 'this is a test "bug" template' }
let(:issue) { create(:issue, author: user, assignee: user, project: project) }
background do
project.repository.commit_file(user, '.gitlab/issue_templates/bug.md', template_content, 'added issue template', 'master', false)
visit edit_namespace_project_issue_path project.namespace, project, issue
fill_in :'issue[title]', with: 'test issue title'
fill_in :'issue[description]', with: prior_description
end
scenario 'user selects "bug" template' do
select_template 'bug'
wait_for_ajax
preview_template("#{template_content}")
save_changes
end
end
2016-09-13 17:45:13 +05:30
context 'user creates a merge request using templates' do
let(:template_content) { 'this is a test "feature-proposal" template' }
let(:merge_request) { create(:merge_request, :with_diffs, source_project: project) }
background do
project.repository.commit_file(user, '.gitlab/merge_request_templates/feature-proposal.md', template_content, 'added merge request template', 'master', false)
visit edit_namespace_project_merge_request_path project.namespace, project, merge_request
fill_in :'merge_request[title]', with: 'test merge request title'
end
scenario 'user selects "feature-proposal" template' do
select_template 'feature-proposal'
wait_for_ajax
preview_template
save_changes
end
end
context 'user creates a merge request from a forked project using templates' do
let(:template_content) { 'this is a test "feature-proposal" template' }
let(:fork_user) { create(:user) }
let(:fork_project) { create(:project, :public) }
2016-09-29 09:46:39 +05:30
let(:merge_request) { create(:merge_request, :with_diffs, source_project: fork_project, target_project: project) }
2016-09-13 17:45:13 +05:30
background do
logout
project.team << [fork_user, :developer]
fork_project.team << [fork_user, :master]
create(:forked_project_link, forked_to_project: fork_project, forked_from_project: project)
login_as fork_user
2016-09-29 09:46:39 +05:30
project.repository.commit_file(fork_user, '.gitlab/merge_request_templates/feature-proposal.md', template_content, 'added merge request template', 'master', false)
visit edit_namespace_project_merge_request_path project.namespace, project, merge_request
2016-09-13 17:45:13 +05:30
fill_in :'merge_request[title]', with: 'test merge request title'
end
2016-09-29 09:46:39 +05:30
context 'feature proposal template' do
context 'template exists in target project' do
scenario 'user selects template' do
select_template 'feature-proposal'
wait_for_ajax
preview_template
save_changes
end
end
2016-09-13 17:45:13 +05:30
end
end
2016-11-03 12:29:30 +05:30
def preview_template(expected_content = template_content)
2016-09-13 17:45:13 +05:30
click_link 'Preview'
2016-11-03 12:29:30 +05:30
expect(page).to have_content expected_content
click_link 'Write'
2016-09-13 17:45:13 +05:30
end
2016-11-03 12:29:30 +05:30
def save_changes(expected_content = template_content)
2016-09-13 17:45:13 +05:30
click_button "Save changes"
2016-11-03 12:29:30 +05:30
expect(page).to have_content expected_content
2016-09-13 17:45:13 +05:30
end
def select_template(name)
first('.js-issuable-selector').click
first('.js-issuable-selector-wrap .dropdown-content a', text: name).click
end
2016-11-03 12:29:30 +05:30
def select_option(name)
first('.js-issuable-selector').click
first('.js-issuable-selector-wrap .dropdown-footer-list a', text: name).click
end
2016-09-13 17:45:13 +05:30
end