96 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| require 'spec_helper'
 | |
| 
 | |
| describe Gitlab::Git::MergeBase do
 | |
|   set(:project) { create(:project, :repository) }
 | |
|   let(:repository) { project.repository }
 | |
|   subject(:merge_base) { described_class.new(repository, refs) }
 | |
| 
 | |
|   shared_context 'existing refs with a merge base', :existing_refs do
 | |
|     let(:refs) do
 | |
|       %w(304d257dcb821665ab5110318fc58a007bd104ed 0031876facac3f2b2702a0e53a26e89939a42209)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   shared_context 'when passing a missing ref', :missing_ref do
 | |
|     let(:refs) do
 | |
|       %w(304d257dcb821665ab5110318fc58a007bd104ed aaaa)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   shared_context 'when passing refs that do not have a common ancestor', :no_common_ancestor do
 | |
|     let(:refs) { ['304d257dcb821665ab5110318fc58a007bd104ed', TestEnv::BRANCH_SHA['orphaned-branch']] }
 | |
|   end
 | |
| 
 | |
|   describe '#sha' do
 | |
|     context 'when the refs exist', :existing_refs do
 | |
|       it 'returns the SHA of the merge base' do
 | |
|         expect(merge_base.sha).not_to be_nil
 | |
|       end
 | |
| 
 | |
|       it 'memoizes the result' do
 | |
|         expect(repository).to receive(:merge_base).once.and_call_original
 | |
| 
 | |
|         2.times { merge_base.sha }
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when passing a missing ref', :missing_ref do
 | |
|       it 'does not call merge_base on the repository but raises an error' do
 | |
|         expect(repository).not_to receive(:merge_base)
 | |
| 
 | |
|         expect { merge_base.sha }.to raise_error(Gitlab::Git::UnknownRef)
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     it 'returns `nil` when the refs do not have a common ancestor', :no_common_ancestor do
 | |
|       expect(merge_base.sha).to be_nil
 | |
|     end
 | |
| 
 | |
|     it 'returns a merge base when passing 2 branch names' do
 | |
|       merge_base = described_class.new(repository, %w(master feature))
 | |
| 
 | |
|       expect(merge_base.sha).to be_present
 | |
|     end
 | |
| 
 | |
|     it 'returns a merge base when passing a tag name' do
 | |
|       merge_base = described_class.new(repository, %w(master v1.0.0))
 | |
| 
 | |
|       expect(merge_base.sha).to be_present
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe '#commit' do
 | |
|     context 'for existing refs with a merge base', :existing_refs  do
 | |
|       it 'finds the commit for the merge base' do
 | |
|         expect(merge_base.commit).to be_a(Commit)
 | |
|       end
 | |
| 
 | |
|       it 'only looks up the commit once' do
 | |
|         expect(repository).to receive(:commit_by).once.and_call_original
 | |
| 
 | |
|         2.times { merge_base.commit }
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     it 'does not try to find the commit when there is no sha', :no_common_ancestor do
 | |
|       expect(repository).not_to receive(:commit_by)
 | |
| 
 | |
|       merge_base.commit
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe '#unknown_refs', :missing_ref do
 | |
|     it 'returns the the refs passed that are not part of the repository' do
 | |
|       expect(merge_base.unknown_refs).to contain_exactly('aaaa')
 | |
|     end
 | |
| 
 | |
|     it 'only looks up the commits once' do
 | |
|       expect(merge_base).to receive(:commits_for_refs).once.and_call_original
 | |
| 
 | |
|       2.times { merge_base.unknown_refs }
 | |
|     end
 | |
|   end
 | |
| end
 |