debian-mirror-gitlab/spec/models/commit_spec.rb

156 lines
5.5 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
require 'spec_helper'
2015-12-23 02:04:40 +05:30
describe Commit, models: true do
2015-09-11 14:41:01 +05:30
let(:project) { create(:project) }
let(:commit) { project.commit }
describe 'modules' do
subject { described_class }
it { is_expected.to include_module(Mentionable) }
it { is_expected.to include_module(Participable) }
it { is_expected.to include_module(Referable) }
it { is_expected.to include_module(StaticModel) }
end
describe '#to_reference' do
it 'returns a String reference to the object' do
expect(commit.to_reference).to eq commit.id
end
it 'supports a cross-project reference' do
cross = double('project')
expect(commit.to_reference(cross)).to eq "#{project.to_reference}@#{commit.id}"
end
end
2014-09-02 18:07:02 +05:30
2015-12-23 02:04:40 +05:30
describe '#reference_link_text' do
it 'returns a String reference to the object' do
expect(commit.reference_link_text).to eq commit.short_id
end
it 'supports a cross-project reference' do
cross = double('project')
expect(commit.reference_link_text(cross)).to eq "#{project.to_reference}@#{commit.short_id}"
end
end
2014-09-02 18:07:02 +05:30
describe '#title' do
it "returns no_commit_message when safe_message is blank" do
2015-04-26 12:48:37 +05:30
allow(commit).to receive(:safe_message).and_return('')
expect(commit.title).to eq("--no commit message")
2014-09-02 18:07:02 +05:30
end
it "truncates a message without a newline at 80 characters" do
message = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec sodales id felis id blandit. Vivamus egestas lacinia lacus, sed rutrum mauris.'
2015-04-26 12:48:37 +05:30
allow(commit).to receive(:safe_message).and_return(message)
expect(commit.title).to eq("#{message[0..79]}")
2014-09-02 18:07:02 +05:30
end
it "truncates a message with a newline before 80 characters at the newline" do
message = commit.safe_message.split(" ").first
2015-04-26 12:48:37 +05:30
allow(commit).to receive(:safe_message).and_return(message + "\n" + message)
expect(commit.title).to eq(message)
2014-09-02 18:07:02 +05:30
end
it "does not truncates a message with a newline after 80 but less 100 characters" do
message =<<eos
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec sodales id felis id blandit.
Vivamus egestas lacinia lacus, sed rutrum mauris.
eos
2015-04-26 12:48:37 +05:30
allow(commit).to receive(:safe_message).and_return(message)
expect(commit.title).to eq(message.split("\n").first)
2014-09-02 18:07:02 +05:30
end
end
describe "delegation" do
subject { commit }
2015-04-26 12:48:37 +05:30
it { is_expected.to respond_to(:message) }
it { is_expected.to respond_to(:authored_date) }
it { is_expected.to respond_to(:committed_date) }
it { is_expected.to respond_to(:committer_email) }
it { is_expected.to respond_to(:author_email) }
it { is_expected.to respond_to(:parents) }
it { is_expected.to respond_to(:date) }
it { is_expected.to respond_to(:diffs) }
it { is_expected.to respond_to(:tree) }
it { is_expected.to respond_to(:id) }
it { is_expected.to respond_to(:to_patch) }
2014-09-02 18:07:02 +05:30
end
describe '#closes_issues' do
let(:issue) { create :issue, project: project }
2015-04-26 12:48:37 +05:30
let(:other_project) { create :project, :public }
let(:other_issue) { create :issue, project: other_project }
2014-09-02 18:07:02 +05:30
it 'detects issues that this commit is marked as closing' do
2015-04-26 12:48:37 +05:30
ext_ref = "#{other_project.path_with_namespace}##{other_issue.iid}"
2015-12-23 02:04:40 +05:30
allow(commit).to receive(:safe_message).and_return("Fixes ##{issue.iid} and #{ext_ref}")
expect(commit.closes_issues).to include(issue)
expect(commit.closes_issues).to include(other_issue)
2014-09-02 18:07:02 +05:30
end
end
it_behaves_like 'a mentionable' do
2015-10-24 18:46:33 +05:30
subject { create(:project).commit }
2015-09-11 14:41:01 +05:30
2015-10-24 18:46:33 +05:30
let(:author) { create(:user, email: subject.author_email) }
2015-04-26 12:48:37 +05:30
let(:backref_text) { "commit #{subject.id}" }
2015-09-11 14:41:01 +05:30
let(:set_mentionable_text) do
->(txt) { allow(subject).to receive(:safe_message).and_return(txt) }
end
2014-09-02 18:07:02 +05:30
# Include the subject in the repository stub.
let(:extra_commits) { [subject] }
end
2015-12-23 02:04:40 +05:30
describe '#hook_attrs' do
let(:data) { commit.hook_attrs(with_changed_files: true) }
it { expect(data).to be_a(Hash) }
it { expect(data[:message]).to include('Add submodule from gitlab.com') }
it { expect(data[:timestamp]).to eq('2014-02-27T11:01:38+02:00') }
it { expect(data[:added]).to eq(["gitlab-grack"]) }
it { expect(data[:modified]).to eq([".gitmodules"]) }
it { expect(data[:removed]).to eq([]) }
end
2016-04-02 18:10:28 +05:30
describe '#reverts_commit?' do
let(:another_commit) { double(:commit, revert_description: "This reverts commit #{commit.sha}") }
it { expect(commit.reverts_commit?(another_commit)).to be_falsy }
context 'commit has no description' do
before { allow(commit).to receive(:description?).and_return(false) }
it { expect(commit.reverts_commit?(another_commit)).to be_falsy }
end
context "another_commit's description does not revert commit" do
before { allow(commit).to receive(:description).and_return("Foo Bar") }
it { expect(commit.reverts_commit?(another_commit)).to be_falsy }
end
context "another_commit's description reverts commit" do
before { allow(commit).to receive(:description).and_return("Foo #{another_commit.revert_description} Bar") }
it { expect(commit.reverts_commit?(another_commit)).to be_truthy }
end
context "another_commit's description reverts merged merge request" do
before do
revert_description = "This reverts merge request !foo123"
allow(another_commit).to receive(:revert_description).and_return(revert_description)
allow(commit).to receive(:description).and_return("Foo #{another_commit.revert_description} Bar")
end
it { expect(commit.reverts_commit?(another_commit)).to be_truthy }
end
end
2014-09-02 18:07:02 +05:30
end