diff options
Diffstat (limited to 'spec/lib/gitlab/search_context/controller_concern_spec.rb')
-rw-r--r-- | spec/lib/gitlab/search_context/controller_concern_spec.rb | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/spec/lib/gitlab/search_context/controller_concern_spec.rb b/spec/lib/gitlab/search_context/controller_concern_spec.rb new file mode 100644 index 00000000000..16784cafb76 --- /dev/null +++ b/spec/lib/gitlab/search_context/controller_concern_spec.rb @@ -0,0 +1,82 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe Gitlab::SearchContext::ControllerConcern, type: :controller do + controller(ApplicationController) do + include Gitlab::SearchContext::ControllerConcern + end + + let(:project) { nil } + let(:group) { nil } + let(:snippet) { nil } + let(:snippets) { [] } + let(:ref) { nil } + + let(:builder) { Gitlab::SearchContext::Builder.new(controller.view_context) } + + subject(:search_context) { controller.search_context } + + def weak_assign(ivar, value) + return if value.nil? + + controller.instance_variable_set(ivar.to_sym, value) + end + + before do + weak_assign(:@project, project) + weak_assign(:@group, group) + weak_assign(:@ref, ref) + weak_assign(:@snippet, snippet) + weak_assign(:@snippets, snippets) + + allow(Gitlab::SearchContext::Builder).to receive(:new).and_return(builder) + end + + shared_examples 'has the proper context' do + it :aggregate_failures do + expected_group = project ? project.group : group + expected_snippets = [snippet, *snippets].compact + + expect(builder).to receive(:with_project).with(project).and_call_original if project + expect(builder).to receive(:with_group).with(expected_group).and_call_original if expected_group + expect(builder).to receive(:with_ref).with(ref).and_call_original if ref + expected_snippets.each do |snippet| + expect(builder).to receive(:with_snippet).with(snippet).and_call_original + end + + is_expected.to be_a(Gitlab::SearchContext) + end + end + + context 'exposing @project' do + let(:project) { create(:project) } + + it_behaves_like 'has the proper context' + + context 'when the project is owned by a group' do + let(:project) { create(:project, group: create(:group)) } + + it_behaves_like 'has the proper context' + end + end + + context 'exposing @group' do + let(:group) { create(:group) } + + it_behaves_like 'has the proper context' + end + + context 'exposing @snippet, @snippets' do + let(:snippet) { create(:snippet) } + let(:snippets) { create_list(:snippet, 3) } + + it_behaves_like 'has the proper context' + end + + context 'exposing @ref' do + let(:ref) { Gitlab::Git::EMPTY_TREE_ID } + + it_behaves_like 'has the proper context' + end +end |