406dfd6e0f
* upstream/master: Ensure we have a project with a repo in GitlabMarkdownHelper specs Revert "Make sure TraceReader uses Encoding.default_external" Make sure TraceReader uses Encoding.default_external Update CONTRIBUTING.md after merging "up-for-grabs" and "Accepting Merge Requests" [ci skip] Use `:empty_project` where possible in finder specs Use `empty_project` where possible in controller specs Use `:empty_project` where possible in helper specs Don’t count tasks that are not defined as list items correctly Use a project factory with a repository where necessary Use `:empty_project` where possible throughout spec/lib Use hashrocket for dasherized attribute Remove markdown file extension and add anchor to link Fixed builds info link on project settings page Factories with a project association use `:empty_project` by default Update enviroments.md the example for deleting an environment is missing the "s" in environments. curl --request DELETE --header "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" "https://gitlab.example.com/api/v3/projects/1/environments/1" wil 404
87 lines
2.6 KiB
Ruby
87 lines
2.6 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe Gitlab::Template::IssueTemplate do
|
|
subject { described_class }
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:project) do
|
|
create(:project,
|
|
:repository,
|
|
create_template: {
|
|
user: user,
|
|
access: Gitlab::Access::MASTER,
|
|
path: 'issue_templates' })
|
|
end
|
|
|
|
describe '.all' do
|
|
it 'strips the md suffix' do
|
|
expect(subject.all(project).first.name).not_to end_with('.issue_template')
|
|
end
|
|
|
|
it 'combines the globals and rest' do
|
|
all = subject.all(project).map(&:name)
|
|
|
|
expect(all).to include('bug')
|
|
expect(all).to include('feature_proposal')
|
|
expect(all).to include('template_test')
|
|
end
|
|
end
|
|
|
|
describe '.find' do
|
|
it 'returns nil if the file does not exist' do
|
|
expect { subject.find('mepmep-yadida', project) }.to raise_error(Gitlab::Template::Finders::RepoTemplateFinder::FileNotFoundError)
|
|
end
|
|
|
|
it 'returns the issue object of a valid file' do
|
|
ruby = subject.find('bug', project)
|
|
|
|
expect(ruby).to be_a Gitlab::Template::IssueTemplate
|
|
expect(ruby.name).to eq('bug')
|
|
end
|
|
end
|
|
|
|
describe '.by_category' do
|
|
it 'return array of templates' do
|
|
all = subject.by_category('', project).map(&:name)
|
|
expect(all).to include('bug')
|
|
expect(all).to include('feature_proposal')
|
|
expect(all).to include('template_test')
|
|
end
|
|
|
|
context 'when repo is bare or empty' do
|
|
let(:empty_project) { create(:empty_project) }
|
|
before { empty_project.add_user(user, Gitlab::Access::MASTER) }
|
|
|
|
it "returns empty array" do
|
|
templates = subject.by_category('', empty_project)
|
|
expect(templates).to be_empty
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#content' do
|
|
it 'loads the full file' do
|
|
issue_template = subject.new('.gitlab/issue_templates/bug.md', project)
|
|
|
|
expect(issue_template.name).to eq 'bug'
|
|
expect(issue_template.content).to eq('something valid')
|
|
end
|
|
|
|
it 'raises error when file is not found' do
|
|
issue_template = subject.new('.gitlab/issue_templates/bugnot.md', project)
|
|
expect { issue_template.content }.to raise_error(Gitlab::Template::Finders::RepoTemplateFinder::FileNotFoundError)
|
|
end
|
|
|
|
context "when repo is empty" do
|
|
let(:empty_project) { create(:empty_project) }
|
|
|
|
before { empty_project.add_user(user, Gitlab::Access::MASTER) }
|
|
|
|
it "raises file not found" do
|
|
issue_template = subject.new('.gitlab/issue_templates/not_existent.md', empty_project)
|
|
expect { issue_template.content }.to raise_error(Gitlab::Template::Finders::RepoTemplateFinder::FileNotFoundError)
|
|
end
|
|
end
|
|
end
|
|
end
|