gitlab-org--gitlab-foss/spec/views/projects/merge_requests/edit.html.haml_spec.rb

62 lines
2.1 KiB
Ruby
Raw Normal View History

require 'spec_helper'
describe 'projects/merge_requests/edit.html.haml' do
include Devise::Test::ControllerHelpers
include ProjectForksHelper
let(:user) { create(:user) }
let(:project) { create(:project, :repository) }
let(:forked_project) { fork_project(project, user, repository: true) }
let(:unlink_project) { Projects::UnlinkForkService.new(forked_project, user) }
2016-09-02 09:00:57 -04:00
let(:milestone) { create(:milestone, project: project) }
2016-08-09 09:43:15 -04:00
let(:closed_merge_request) do
project.add_developer(user)
create(:closed_merge_request,
source_project: forked_project,
target_project: project,
2016-09-02 09:00:57 -04:00
author: user,
assignees: [user],
2016-09-02 09:00:57 -04:00
milestone: milestone)
end
before do
assign(:project, project)
2019-07-24 16:19:23 -04:00
assign(:target_project, project)
assign(:merge_request, closed_merge_request)
2018-09-07 08:29:19 -04:00
assign(:mr_presenter, closed_merge_request.present(current_user: user))
allow(view).to receive(:can?).and_return(true)
2016-08-09 09:43:15 -04:00
allow(view).to receive(:current_user)
.and_return(User.find(closed_merge_request.author_id))
end
2016-08-10 09:36:30 -04:00
context 'when a merge request without fork' do
it "shows editable fields" do
unlink_project.execute
closed_merge_request.reload
2016-08-09 09:43:15 -04:00
render
expect(rendered).to have_field('merge_request[title]')
expect(rendered).to have_field('merge_request[description]')
expect(rendered).to have_selector('input[name="merge_request[label_ids][]"]', visible: false)
2016-08-09 09:43:15 -04:00
expect(rendered).to have_selector('#merge_request_milestone_id', visible: false)
expect(rendered).not_to have_selector('#merge_request_target_branch', visible: false)
end
end
2016-08-10 09:36:30 -04:00
context 'when a merge request with an existing source project is closed' do
2016-08-09 09:43:15 -04:00
it "shows editable fields" do
render
expect(rendered).to have_field('merge_request[title]')
expect(rendered).to have_field('merge_request[description]')
expect(rendered).to have_selector('input[name="merge_request[label_ids][]"]', visible: false)
2016-08-09 09:43:15 -04:00
expect(rendered).to have_selector('#merge_request_milestone_id', visible: false)
expect(rendered).to have_selector('#merge_request_target_branch', visible: false)
end
end
end