summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/search_context/controller_concern_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/lib/gitlab/search_context/controller_concern_spec.rb')
-rw-r--r--spec/lib/gitlab/search_context/controller_concern_spec.rb82
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