gitlab-ce/spec/lib/gitlab/suggestions/commit_message_spec.rb

200 lines
6.7 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::Suggestions::CommitMessage, feature_category: :code_review_workflow do
include ProjectForksHelper
using RSpec::Parameterized::TableSyntax
def create_suggestion(merge_request, file_path, new_line, to_content, author)
position = Gitlab::Diff::Position.new(old_path: file_path,
new_path: file_path,
old_line: nil,
new_line: new_line,
diff_refs: merge_request.diff_refs)
diff_note = create(:diff_note_on_merge_request,
noteable: merge_request,
author: author,
position: position,
project: project)
create(:suggestion,
:content_from_repo,
note: diff_note,
to_content: to_content)
end
let_it_be(:user) do
create(:user, :commit_email, name: 'Test User', username: 'test.user')
end
let_it_be(:project) do
create(:project, :repository, path: 'project-1', name: 'Project_1')
end
let_it_be(:forked_project) { fork_project(project, nil, repository: true) }
let_it_be(:merge_request_same_project) do
create(:merge_request, source_project: project, target_project: project)
end
let_it_be(:merge_request_from_fork) do
create(:merge_request, source_project: forked_project, target_project: project)
end
let_it_be(:first_author) { merge_request_same_project.author }
let_it_be(:second_author) do
merge_request_from_fork.author.tap do |author|
author.commit_email = author.verified_emails.last
end
end
let_it_be(:suggestion_set_same_project) do
suggestion1 = create_suggestion(
merge_request_same_project, 'files/ruby/popen.rb', 9, '*** SUGGESTION 1 ***', user
)
suggestion2 = create_suggestion(
merge_request_same_project, 'files/ruby/popen.rb', 13, '*** SUGGESTION 2 ***', first_author
)
suggestion3 = create_suggestion(
merge_request_same_project, 'files/ruby/regex.rb', 22, '*** SUGGESTION 3 ***', second_author
)
Gitlab::Suggestions::SuggestionSet.new([suggestion1, suggestion2, suggestion3])
end
let_it_be(:suggestion_set_forked_project) do
suggestion1 = create_suggestion(
merge_request_from_fork, 'files/ruby/popen.rb', 9, '*** SUGGESTION 1 ***', user
)
suggestion2 = create_suggestion(
merge_request_from_fork, 'files/ruby/popen.rb', 13, '*** SUGGESTION 2 ***', first_author
)
suggestion3 = create_suggestion(
merge_request_from_fork, 'files/ruby/regex.rb', 22, '*** SUGGESTION 3 ***', second_author
)
Gitlab::Suggestions::SuggestionSet.new([suggestion1, suggestion2, suggestion3])
end
describe '#message' do
where(:suggestion_set) { [ref(:suggestion_set_same_project), ref(:suggestion_set_forked_project)] }
with_them do
before do
# Updating the suggestion_commit_message on a project shared across specs
# avoids recreating the repository for each spec.
project.update!(suggestion_commit_message: message)
forked_project.update!(suggestion_commit_message: fork_message)
end
let(:fork_message) { nil }
context 'when a custom commit message is not specified' do
let(:expected_message) do
"Apply 3 suggestion(s) to 2 file(s)\n\n" \
"Co-authored-by: #{first_author.name} <#{first_author.email}>\n" \
"Co-authored-by: #{second_author.name} <#{second_author.commit_email}>"
end
context 'and is nil' do
let(:message) { nil }
it 'uses the default commit message' do
expect(described_class
.new(user, suggestion_set)
.message).to eq(expected_message)
end
end
context 'and is an empty string' do
let(:message) { '' }
it 'uses the default commit message' do
expect(described_class
.new(user, suggestion_set)
.message).to eq(expected_message)
end
end
context 'when a custom commit message is specified for forked project' do
let(:message) { nil }
let(:fork_message) { "I'm a sad message that will not be used :(" }
it 'uses the default commit message' do
expect(described_class
.new(user, suggestion_set)
.message).to eq(expected_message)
end
end
end
context 'when a custom commit message is specified' do
let(:message) { "i'm a project message. a user's custom message takes precedence over me :(" }
let(:custom_message) { "hello there! i'm a cool custom commit message." }
it 'shows the custom commit message' do
expect(Gitlab::Suggestions::CommitMessage
.new(user, suggestion_set, custom_message)
.message).to eq(custom_message)
end
end
context 'is specified and includes all placeholders' do
let(:suggestion_author) { suggestion_set.authors.first }
let(:message) do
<<~MESSAGE
***
%{branch_name} %{files_count} %{file_paths}
%{project_name} %{project_path} %{user_full_name}
%{username} %{suggestions_count}
%{co_authored_by}
***
MESSAGE
end
it 'generates a custom commit message' do
expect(Gitlab::Suggestions::CommitMessage
.new(user, suggestion_set)
.message).to eq(
<<~MESSAGE
***
master 2 files/ruby/popen.rb, files/ruby/regex.rb
Project_1 project-1 Test User
test.user 3
Co-authored-by: #{first_author.name} <#{first_author.email}>
Co-authored-by: #{second_author.name} <#{second_author.commit_email}>
***
MESSAGE
)
end
context 'when a custom commit message is specified for forked project' do
let(:fork_message) { "I'm a sad message that will not be used :(" }
it 'uses the target project commit message' do
expect(Gitlab::Suggestions::CommitMessage
.new(user, suggestion_set)
.message).to eq(
<<~MESSAGE
***
master 2 files/ruby/popen.rb, files/ruby/regex.rb
Project_1 project-1 Test User
test.user 3
Co-authored-by: #{first_author.name} <#{first_author.email}>
Co-authored-by: #{second_author.name} <#{second_author.commit_email}>
***
MESSAGE
)
end
end
end
end
end
end