debian-mirror-gitlab/spec/javascripts/fixtures/issues.rb

126 lines
3.7 KiB
Ruby
Raw Normal View History

2017-08-17 22:00:37 +05:30
require 'spec_helper'
describe Projects::IssuesController, '(JavaScript fixtures)', type: :controller do
include JavaScriptFixturesHelpers
2019-05-18 00:54:41 +05:30
let(:admin) { create(:admin, feed_token: 'feedtoken:coldfeed') }
2017-08-17 22:00:37 +05:30
let(:namespace) { create(:namespace, name: 'frontend-fixtures' )}
let(:project) { create(:project_empty_repo, namespace: namespace, path: 'issues-project') }
render_views
before(:all) do
clean_frontend_fixtures('issues/')
end
2018-03-17 18:26:18 +05:30
before do
2017-08-17 22:00:37 +05:30
sign_in(admin)
end
2018-03-17 18:26:18 +05:30
after do
remove_repository(project)
end
2019-05-18 00:54:41 +05:30
it 'issues/open-issue.html' do |example|
2017-08-17 22:00:37 +05:30
render_issue(example.description, create(:issue, project: project))
end
2019-05-18 00:54:41 +05:30
it 'issues/closed-issue.html' do |example|
2017-08-17 22:00:37 +05:30
render_issue(example.description, create(:closed_issue, project: project))
end
2019-05-18 00:54:41 +05:30
it 'issues/issue-with-task-list.html' do |example|
2017-08-17 22:00:37 +05:30
issue = create(:issue, project: project, description: '- [ ] Task List Item')
render_issue(example.description, issue)
end
2019-05-18 00:54:41 +05:30
it 'issues/issue_with_comment.html' do |example|
2017-08-17 22:00:37 +05:30
issue = create(:issue, project: project)
create(:note, project: project, noteable: issue, note: '- [ ] Task List Item').save
render_issue(example.description, issue)
end
2019-05-18 00:54:41 +05:30
it 'issues/issue_list.html' do |example|
2017-09-10 17:25:29 +05:30
create(:issue, project: project)
2019-02-15 15:39:39 +05:30
get :index, params: {
2017-09-10 17:25:29 +05:30
namespace_id: project.namespace.to_param,
project_id: project
2019-02-15 15:39:39 +05:30
}
2017-09-10 17:25:29 +05:30
expect(response).to be_success
store_frontend_fixture(response, example.description)
end
2017-08-17 22:00:37 +05:30
private
def render_issue(fixture_file_name, issue)
2019-02-15 15:39:39 +05:30
get :show, params: {
2017-08-17 22:00:37 +05:30
namespace_id: project.namespace.to_param,
project_id: project,
id: issue.to_param
2019-02-15 15:39:39 +05:30
}
2017-08-17 22:00:37 +05:30
expect(response).to be_success
store_frontend_fixture(response, fixture_file_name)
end
end
2019-05-18 00:54:41 +05:30
describe API::Issues, '(JavaScript fixtures)', type: :request do
include ApiHelpers
include JavaScriptFixturesHelpers
def get_related_merge_requests(project_id, issue_iid, user = nil)
get api("/projects/#{project_id}/issues/#{issue_iid}/related_merge_requests", user)
end
def create_referencing_mr(user, project, issue)
attributes = {
author: user,
source_project: project,
target_project: project,
source_branch: "master",
target_branch: "test",
assignee: user,
description: "See #{issue.to_reference}"
}
create(:merge_request, attributes).tap do |merge_request|
create(:note, :system, project: issue.project, noteable: issue, author: user, note: merge_request.to_reference(full: true))
end
end
it 'issues/related_merge_requests.json' do |example|
user = create(:user)
project = create(:project, :public, creator_id: user.id, namespace: user.namespace)
issue_title = 'foo'
issue_description = 'closed'
milestone = create(:milestone, title: '1.0.0', project: project)
issue = create :issue,
author: user,
assignees: [user],
project: project,
milestone: milestone,
created_at: generate(:past_time),
updated_at: 1.hour.ago,
title: issue_title,
description: issue_description
project.add_reporter(user)
create_referencing_mr(user, project, issue)
create(:merge_request,
:simple,
author: user,
source_project: project,
target_project: project,
description: "Some description")
project2 = create(:project, :public, creator_id: user.id, namespace: user.namespace)
create_referencing_mr(user, project2, issue).update!(head_pipeline: create(:ci_pipeline))
get_related_merge_requests(project.id, issue.iid, user)
expect(response).to be_success
store_frontend_fixture(response, example.description)
end
end