Commit cf882088 authored by Mikołaj Wawrzyniak's avatar Mikołaj Wawrzyniak

Merge branch 'fix-opensearch' into 'master'

Fix opensearch for anonymous users

See merge request gitlab-org/gitlab!53056
parents 587486ba 2ea35022
...@@ -9,7 +9,7 @@ class SearchController < ApplicationController ...@@ -9,7 +9,7 @@ class SearchController < ApplicationController
around_action :allow_gitaly_ref_name_caching around_action :allow_gitaly_ref_name_caching
before_action :block_anonymous_global_searches before_action :block_anonymous_global_searches, except: :opensearch
skip_before_action :authenticate_user! skip_before_action :authenticate_user!
requires_cross_project_access if: -> do requires_cross_project_access if: -> do
search_term_present = params[:search].present? || params[:term].present? search_term_present = params[:search].present? || params[:term].present?
......
---
title: Fix opensearch for anonymous users
merge_request: 53056
author:
type: fixed
...@@ -5,6 +5,7 @@ require 'spec_helper' ...@@ -5,6 +5,7 @@ require 'spec_helper'
RSpec.describe SearchController do RSpec.describe SearchController do
include ExternalAuthorizationServiceHelpers include ExternalAuthorizationServiceHelpers
context 'authorized user' do
let(:user) { create(:user) } let(:user) { create(:user) }
before do before do
...@@ -258,20 +259,6 @@ RSpec.describe SearchController do ...@@ -258,20 +259,6 @@ RSpec.describe SearchController do
it_behaves_like 'with external authorization service enabled', :autocomplete, { term: 'hello' } it_behaves_like 'with external authorization service enabled', :autocomplete, { term: 'hello' }
end end
describe 'GET #opensearch' do
render_views
it 'renders xml' do
get :opensearch, format: :xml
doc = Nokogiri::XML.parse(response.body)
expect(response).to have_gitlab_http_status(:ok)
expect(doc.css('OpenSearchDescription ShortName').text).to eq('GitLab')
expect(doc.css('OpenSearchDescription *').map(&:name)).to eq(%w[ShortName Description InputEncoding Image Url SearchForm])
end
end
describe '#append_info_to_payload' do describe '#append_info_to_payload' do
it 'appends search metadata for logging' do it 'appends search metadata for logging' do
last_payload = nil last_payload = nil
...@@ -293,4 +280,21 @@ RSpec.describe SearchController do ...@@ -293,4 +280,21 @@ RSpec.describe SearchController do
expect(last_payload[:metadata]['meta.search.filters.state']).to eq('true') expect(last_payload[:metadata]['meta.search.filters.state']).to eq('true')
end end
end end
end
context 'unauthorized user' do
describe 'GET #opensearch' do
render_views
it 'renders xml' do
get :opensearch, format: :xml
doc = Nokogiri::XML.parse(response.body)
expect(response).to have_gitlab_http_status(:ok)
expect(doc.css('OpenSearchDescription ShortName').text).to eq('GitLab')
expect(doc.css('OpenSearchDescription *').map(&:name)).to eq(%w[ShortName Description InputEncoding Image Url SearchForm])
end
end
end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment