diff options
| author | Lin Jen-Shin <godfat@godfat.org> | 2016-12-14 19:24:31 +0800 | 
|---|---|---|
| committer | Lin Jen-Shin <godfat@godfat.org> | 2016-12-14 19:24:31 +0800 | 
| commit | 367024f1707ebbf986e5f25ac208f24e35746389 (patch) | |
| tree | 8ff45ed585720aa4eb2f5a6c772a2a20f89b946f /spec/models/commit_spec.rb | |
| parent | 101cde38cf6d5506ea37c5f912fb4c37af50c541 (diff) | |
| parent | 3a90612660ab90225907ec6d79032905885c2507 (diff) | |
| download | gitlab-ce-367024f1707ebbf986e5f25ac208f24e35746389.tar.gz | |
Merge remote-tracking branch 'upstream/master' into show-commit-status-from-latest-pipeline
* upstream/master: (557 commits)
  Fix wrong error message expectation in API::Commits spec
  Move admin settings spinach feature to rspec
  Encode when migrating ProcessCommitWorker jobs
  Prevent overflow with vertical scroll when we have space to show content
  Make rubocop happy
  API: Ability to cherry-pick a commit
  Be smarter when finding a sudoed user in API::Helpers
  Backport hooks on group policies for the EE-specific implementation
  API: Ability to get group's project in simple representation
  Add AddLowerPathIndexToRoutes to setup_postgresql.rake
  For single line git commit messages, the close quote should be on the same line as the open quote
  added border-radius and padding to labels
  Allow all alphanumeric characters in file names (!8002)
  Add failing test for #20190
  Don't allow blank MR titles in API
  Replace static fixture for awards_handler_spec (!7661)
  Crontab typo '* */6' -> '0 */6' (4x/day not 1x-per-min-for-1h 4x/day)
  Fix test
  Tweak style and add back wording
  Clean up commit copy to clipboard and make consistent
  ...
Diffstat (limited to 'spec/models/commit_spec.rb')
| -rw-r--r-- | spec/models/commit_spec.rb | 42 | 
1 files changed, 33 insertions, 9 deletions
| diff --git a/spec/models/commit_spec.rb b/spec/models/commit_spec.rb index 62b77ef86c5..b81fab0372a 100644 --- a/spec/models/commit_spec.rb +++ b/spec/models/commit_spec.rb @@ -34,24 +34,30 @@ describe Commit, models: true do    end    describe '#to_reference' do +    let(:project) { create(:project, path: 'sample-project') } +    let(:commit)  { project.commit } +      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}" +      another_project = build(:project, name: 'another-project', namespace: project.namespace) +      expect(commit.to_reference(another_project)).to eq "sample-project@#{commit.id}"      end    end    describe '#reference_link_text' do +    let(:project) { create(:project, path: 'sample-project') } +    let(:commit)  { project.commit } +      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}" +      another_project = build(:project, name: 'another-project', namespace: project.namespace) +      expect(commit.reference_link_text(another_project)).to eq "sample-project@#{commit.short_id}"      end    end @@ -173,25 +179,26 @@ eos    describe '#reverts_commit?' do      let(:another_commit) { double(:commit, revert_description: "This reverts commit #{commit.sha}") } +    let(:user) { commit.author } -    it { expect(commit.reverts_commit?(another_commit)).to be_falsy } +    it { expect(commit.reverts_commit?(another_commit, user)).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 } +      it { expect(commit.reverts_commit?(another_commit, user)).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 } +      it { expect(commit.reverts_commit?(another_commit, user)).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 } +      it { expect(commit.reverts_commit?(another_commit, user)).to be_truthy }      end      context "another_commit's description reverts merged merge request" do @@ -201,7 +208,7 @@ eos          allow(commit).to receive(:description).and_return("Foo #{another_commit.revert_description} Bar")        end -      it { expect(commit.reverts_commit?(another_commit)).to be_truthy } +      it { expect(commit.reverts_commit?(another_commit, user)).to be_truthy }      end    end @@ -297,4 +304,21 @@ eos        expect(commit.uri_type('this/path/doesnt/exist')).to be_nil      end    end + +  describe '.from_hash' do +    let(:new_commit) { described_class.from_hash(commit.to_hash, project) } + +    it 'returns a Commit' do +      expect(new_commit).to be_an_instance_of(described_class) +    end + +    it 'wraps a Gitlab::Git::Commit' do +      expect(new_commit.raw).to be_an_instance_of(Gitlab::Git::Commit) +    end + +    it 'stores the correct commit fields' do +      expect(new_commit.id).to eq(commit.id) +      expect(new_commit.message).to eq(commit.message) +    end +  end  end | 
