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
49 lines
1.6 KiB
Ruby
49 lines
1.6 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe Projects::TemplatesController do
|
|
let(:project) { create(:project, :repository) }
|
|
let(:user) { create(:user) }
|
|
let(:user2) { create(:user) }
|
|
let(:file_path_1) { '.gitlab/issue_templates/bug.md' }
|
|
let(:body) { JSON.parse(response.body) }
|
|
|
|
before do
|
|
project.team << [user, :developer]
|
|
sign_in(user)
|
|
end
|
|
|
|
before do
|
|
project.add_user(user, Gitlab::Access::MASTER)
|
|
project.repository.commit_file(user, file_path_1, 'something valid',
|
|
message: 'test 3', branch_name: 'master', update: false)
|
|
end
|
|
|
|
describe '#show' do
|
|
it 'renders template name and content as json' do
|
|
get(:show, namespace_id: project.namespace.to_param, template_type: "issue", key: "bug", project_id: project.path, format: :json)
|
|
|
|
expect(response.status).to eq(200)
|
|
expect(body["name"]).to eq("bug")
|
|
expect(body["content"]).to eq("something valid")
|
|
end
|
|
|
|
it 'renders 404 when unauthorized' do
|
|
sign_in(user2)
|
|
get(:show, namespace_id: project.namespace.to_param, template_type: "issue", key: "bug", project_id: project.path, format: :json)
|
|
|
|
expect(response.status).to eq(404)
|
|
end
|
|
|
|
it 'renders 404 when template type is not found' do
|
|
sign_in(user)
|
|
get(:show, namespace_id: project.namespace.to_param, template_type: "dont_exist", key: "bug", project_id: project.path, format: :json)
|
|
|
|
expect(response.status).to eq(404)
|
|
end
|
|
|
|
it 'renders 404 without errors' do
|
|
sign_in(user)
|
|
expect { get(:show, namespace_id: project.namespace.to_param, template_type: "dont_exist", key: "bug", project_id: project.path, format: :json) }.not_to raise_error
|
|
end
|
|
end
|
|
end
|