Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
edab3aa9
Commit
edab3aa9
authored
Sep 11, 2020
by
Dylan Griffith
Committed by
Sean McGivern
Sep 11, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Revert "Revert "Merge branch...""
This reverts commit
5c234b63
.
parent
3cae13f0
Changes
15
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
294 additions
and
160 deletions
+294
-160
app/controllers/search_controller.rb
app/controllers/search_controller.rb
+11
-0
config/feature_flags/development/block_anonymous_global_searches.yml
...ure_flags/development/block_anonymous_global_searches.yml
+7
-0
ee/app/models/ee/application_setting.rb
ee/app/models/ee/application_setting.rb
+1
-1
ee/config/feature_flags/development/advanced_global_search_for_limited_indexing.yml
...velopment/advanced_global_search_for_limited_indexing.yml
+7
-0
ee/spec/features/search/elastic/global_search_spec.rb
ee/spec/features/search/elastic/global_search_spec.rb
+14
-2
ee/spec/features/search/elastic/snippet_search_spec.rb
ee/spec/features/search/elastic/snippet_search_spec.rb
+22
-10
ee/spec/models/application_setting_spec.rb
ee/spec/models/application_setting_spec.rb
+5
-3
ee/spec/requests/api/search_spec.rb
ee/spec/requests/api/search_spec.rb
+79
-81
ee/spec/services/search/global_service_spec.rb
ee/spec/services/search/global_service_spec.rb
+24
-2
ee/spec/support/features/redacted_search_results_examples.rb
ee/spec/support/features/redacted_search_results_examples.rb
+2
-2
locale/gitlab.pot
locale/gitlab.pot
+3
-0
spec/controllers/search_controller_spec.rb
spec/controllers/search_controller_spec.rb
+61
-33
spec/features/search/user_searches_for_issues_spec.rb
spec/features/search/user_searches_for_issues_spec.rb
+23
-10
spec/features/search/user_searches_for_projects_spec.rb
spec/features/search/user_searches_for_projects_spec.rb
+29
-16
spec/frontend/fixtures/search.rb
spec/frontend/fixtures/search.rb
+6
-0
No files found.
app/controllers/search_controller.rb
View file @
edab3aa9
...
@@ -15,6 +15,7 @@ class SearchController < ApplicationController
...
@@ -15,6 +15,7 @@ class SearchController < ApplicationController
around_action
:allow_gitaly_ref_name_caching
around_action
:allow_gitaly_ref_name_caching
before_action
:block_anonymous_global_searches
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?
...
@@ -128,6 +129,16 @@ class SearchController < ApplicationController
...
@@ -128,6 +129,16 @@ class SearchController < ApplicationController
payload
[
:metadata
][
'meta.search.search'
]
=
params
[
:search
]
payload
[
:metadata
][
'meta.search.search'
]
=
params
[
:search
]
payload
[
:metadata
][
'meta.search.scope'
]
=
params
[
:scope
]
payload
[
:metadata
][
'meta.search.scope'
]
=
params
[
:scope
]
end
end
def
block_anonymous_global_searches
return
if
params
[
:project_id
].
present?
||
params
[
:group_id
].
present?
return
if
current_user
return
unless
::
Feature
.
enabled?
(
:block_anonymous_global_searches
)
store_location_for
(
:user
,
request
.
fullpath
)
redirect_to
new_user_session_path
,
alert:
_
(
'You must be logged in to search across all of GitLab'
)
end
end
end
SearchController
.
prepend_if_ee
(
'EE::SearchController'
)
SearchController
.
prepend_if_ee
(
'EE::SearchController'
)
config/feature_flags/development/block_anonymous_global_searches.yml
0 → 100644
View file @
edab3aa9
---
name
:
block_anonymous_global_searches
introduced_by_url
:
https://gitlab.com/gitlab-org/gitlab/-/merge_requests/41041
rollout_issue_url
:
https://gitlab.com/gitlab-org/gitlab/-/issues/244276
group
:
group::global search
type
:
development
default_enabled
:
false
\ No newline at end of file
ee/app/models/ee/application_setting.rb
View file @
edab3aa9
...
@@ -244,7 +244,7 @@ module EE
...
@@ -244,7 +244,7 @@ module EE
when
Project
when
Project
elasticsearch_indexes_project?
(
scope
)
elasticsearch_indexes_project?
(
scope
)
else
else
false
# Never use elasticsearch for the global scope when limiting is on
::
Feature
.
enabled?
(
:advanced_global_search_for_limited_indexing
)
end
end
end
end
...
...
ee/config/feature_flags/development/advanced_global_search_for_limited_indexing.yml
0 → 100644
View file @
edab3aa9
---
name
:
advanced_global_search_for_limited_indexing
introduced_by_url
:
https://gitlab.com/gitlab-org/gitlab/-/merge_requests/41041
rollout_issue_url
:
https://gitlab.com/gitlab-org/gitlab/-/issues/244276
group
:
group::global search
type
:
development
default_enabled
:
false
\ No newline at end of file
ee/spec/features/search/elastic/global_search_spec.rb
View file @
edab3aa9
...
@@ -266,7 +266,19 @@ RSpec.describe 'Global elastic search', :elastic, :sidekiq_inline do
...
@@ -266,7 +266,19 @@ RSpec.describe 'Global elastic search', :elastic, :sidekiq_inline do
end
end
RSpec
.
describe
'Global elastic search redactions'
,
:elastic
do
RSpec
.
describe
'Global elastic search redactions'
,
:elastic
do
it_behaves_like
'a redacted search results page'
do
context
'when block_anonymous_global_searches is disabled'
do
let
(
:search_path
)
{
explore_root_path
}
before
do
stub_feature_flags
(
block_anonymous_global_searches:
false
)
end
it_behaves_like
'a redacted search results page'
do
let
(
:search_path
)
{
explore_root_path
}
end
end
context
'when block_anonymous_global_searches is enabled'
do
it_behaves_like
'a redacted search results page'
,
include_anonymous:
false
do
let
(
:search_path
)
{
explore_root_path
}
end
end
end
end
end
ee/spec/features/search/elastic/snippet_search_spec.rb
View file @
edab3aa9
...
@@ -37,19 +37,31 @@ RSpec.describe 'Snippet elastic search', :js, :elastic, :aggregate_failures, :si
...
@@ -37,19 +37,31 @@ RSpec.describe 'Snippet elastic search', :js, :elastic, :aggregate_failures, :si
context
'as anonymous user'
do
context
'as anonymous user'
do
let
(
:current_user
)
{
nil
}
let
(
:current_user
)
{
nil
}
it
'finds only public snippets'
do
context
'when block_anonymous_global_searches is enabled'
do
within
(
'.results'
)
do
it
'redirects to login page'
do
expect
(
page
).
to
have_content
(
'public personal snippet'
)
expect
(
page
).
to
have_content
(
'You must be logged in to search across all of GitLab'
)
expect
(
page
).
not_to
have_content
(
'public project snippet'
)
end
end
expect
(
page
).
not_to
have_content
(
'internal personal snippet'
)
context
'when block_anonymous_global_searches is disabled'
do
expect
(
page
).
not_to
have_content
(
'internal project snippet'
)
before
(
:context
)
do
stub_feature_flags
(
block_anonymous_global_searches:
false
)
end
expect
(
page
).
not_to
have_content
(
'authorized personal snippet'
)
it
'finds only public snippets'
do
expect
(
page
).
not_to
have_content
(
'authorized project snippet'
)
within
(
'.results'
)
do
expect
(
page
).
to
have_content
(
'public personal snippet'
)
expect
(
page
).
not_to
have_content
(
'public project snippet'
)
expect
(
page
).
not_to
have_content
(
'private personal snippet'
)
expect
(
page
).
not_to
have_content
(
'internal personal snippet'
)
expect
(
page
).
not_to
have_content
(
'private project snippet'
)
expect
(
page
).
not_to
have_content
(
'internal project snippet'
)
expect
(
page
).
not_to
have_content
(
'authorized personal snippet'
)
expect
(
page
).
not_to
have_content
(
'authorized project snippet'
)
expect
(
page
).
not_to
have_content
(
'private personal snippet'
)
expect
(
page
).
not_to
have_content
(
'private project snippet'
)
end
end
end
end
end
end
end
...
...
ee/spec/models/application_setting_spec.rb
View file @
edab3aa9
...
@@ -407,8 +407,8 @@ RSpec.describe ApplicationSetting do
...
@@ -407,8 +407,8 @@ RSpec.describe ApplicationSetting do
end
end
describe
'#search_using_elasticsearch?'
do
describe
'#search_using_elasticsearch?'
do
# Constructs a truth table
with 16 entries
to run the specs against
# Constructs a truth table to run the specs against
where
(
indexing:
[
true
,
false
],
searching:
[
true
,
false
],
limiting:
[
true
,
false
])
where
(
indexing:
[
true
,
false
],
searching:
[
true
,
false
],
limiting:
[
true
,
false
]
,
advanced_global_search_for_limited_indexing:
[
true
,
false
]
)
with_them
do
with_them
do
let_it_be
(
:included_project_container
)
{
create
(
:elasticsearch_indexed_project
)
}
let_it_be
(
:included_project_container
)
{
create
(
:elasticsearch_indexed_project
)
}
...
@@ -430,12 +430,14 @@ RSpec.describe ApplicationSetting do
...
@@ -430,12 +430,14 @@ RSpec.describe ApplicationSetting do
elasticsearch_search:
searching
,
elasticsearch_search:
searching
,
elasticsearch_limit_indexing:
limiting
elasticsearch_limit_indexing:
limiting
)
)
stub_feature_flags
(
advanced_global_search_for_limited_indexing:
advanced_global_search_for_limited_indexing
)
end
end
context
'global scope'
do
context
'global scope'
do
let
(
:scope
)
{
nil
}
let
(
:scope
)
{
nil
}
it
{
is_expected
.
to
eq
(
only_when_enabled_globally
)
}
it
{
is_expected
.
to
eq
(
indexing
&&
searching
&&
(
!
limiting
||
advanced_global_search_for_limited_indexing
)
)
}
end
end
context
'namespace (in scope)'
do
context
'namespace (in scope)'
do
...
...
ee/spec/requests/api/search_spec.rb
View file @
edab3aa9
...
@@ -61,10 +61,7 @@ RSpec.describe API::Search do
...
@@ -61,10 +61,7 @@ RSpec.describe API::Search do
shared_examples
'elasticsearch enabled'
do
|
level
:|
shared_examples
'elasticsearch enabled'
do
|
level
:|
context
'for merge_requests scope'
,
:sidekiq_inline
do
context
'for merge_requests scope'
,
:sidekiq_inline
do
before
do
before
do
create
(
:labeled_merge_request
,
target_branch:
'feature_1'
,
source_project:
project
,
labels:
[
create
(
:label
),
create
(
:label
)])
create_list
(
:merge_request
,
3
,
:unique_branches
,
source_project:
project
,
author:
create
(
:user
),
milestone:
create
(
:milestone
,
project:
project
),
labels:
[
create
(
:label
)])
create
(
:merge_request
,
target_branch:
'feature_2'
,
source_project:
project
,
author:
create
(
:user
))
create
(
:merge_request
,
target_branch:
'feature_3'
,
source_project:
project
,
milestone:
create
(
:milestone
,
project:
project
))
create
(
:merge_request
,
target_branch:
'feature_4'
,
source_project:
project
)
ensure_elasticsearch_index!
ensure_elasticsearch_index!
end
end
...
@@ -72,19 +69,14 @@ RSpec.describe API::Search do
...
@@ -72,19 +69,14 @@ RSpec.describe API::Search do
it
'avoids N+1 queries'
do
it
'avoids N+1 queries'
do
control
=
ActiveRecord
::
QueryRecorder
.
new
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'merge_requests'
,
search:
'*'
}
}
control
=
ActiveRecord
::
QueryRecorder
.
new
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'merge_requests'
,
search:
'*'
}
}
create_list
(
:merge_request
,
3
,
:unique_branches
,
source_project:
project
,
author:
create
(
:user
),
milestone:
create
(
:milestone
,
project:
project
),
labels:
[
create
(
:label
)])
create
(
:labeled_merge_request
,
target_branch:
'feature_5'
,
source_project:
project
,
labels:
[
create
(
:label
),
create
(
:label
)])
create
(
:merge_request
,
target_branch:
'feature_6'
,
source_project:
project
,
author:
create
(
:user
))
create
(
:merge_request
,
target_branch:
'feature_7'
,
source_project:
project
,
milestone:
create
(
:milestone
,
project:
project
))
create
(
:merge_request
,
target_branch:
'feature_8'
,
source_project:
project
)
ensure_elasticsearch_index!
ensure_elasticsearch_index!
expect
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'merge_requests'
,
search:
'*'
}
}.
not_to
exceed_query_limit
(
control
)
expect
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'merge_requests'
,
search:
'*'
}
}.
not_to
exceed_query_limit
(
control
)
end
end
end
end
context
'for wiki_blobs scope'
,
:sidekiq_
might_not_need_
inline
do
context
'for wiki_blobs scope'
,
:sidekiq_inline
do
before
do
before
do
wiki
=
create
(
:project_wiki
,
project:
project
)
wiki
=
create
(
:project_wiki
,
project:
project
)
create
(
:wiki_page
,
wiki:
wiki
,
title:
'home'
,
content:
"Awesome page"
)
create
(
:wiki_page
,
wiki:
wiki
,
title:
'home'
,
content:
"Awesome page"
)
...
@@ -101,105 +93,105 @@ RSpec.describe API::Search do
...
@@ -101,105 +93,105 @@ RSpec.describe API::Search do
it_behaves_like
'pagination'
,
scope:
'wiki_blobs'
it_behaves_like
'pagination'
,
scope:
'wiki_blobs'
end
end
context
'for commits
scope
'
,
:sidekiq_inline
do
context
'for commits
and blobs
'
,
:sidekiq_inline
do
before
do
before
do
project
.
repository
.
index_commits_and_blobs
project
.
repository
.
index_commits_and_blobs
ensure_elasticsearch_index!
ensure_elasticsearch_index!
get
api
(
endpoint
,
user
),
params:
{
scope:
'commits'
,
search:
'folder'
}
end
end
it_behaves_like
'response is correct'
,
schema:
'public_api/v4/commits_details'
,
size:
2
context
'for commits scope'
do
before
do
it_behaves_like
'pagination'
,
scope:
'commits'
get
api
(
endpoint
,
user
),
params:
{
scope:
'commits'
,
search:
'folder'
}
end
it
'avoids N+1 queries'
do
it_behaves_like
'response is correct'
,
schema:
'public_api/v4/commits_details'
,
size:
2
control
=
ActiveRecord
::
QueryRecorder
.
new
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'commits'
,
search:
'folder'
}
}
project_2
=
create
(
:project
,
:public
,
:repository
,
:wiki_repo
,
name:
'awesome project 2'
)
it_behaves_like
'pagination'
,
scope:
'commits'
project_3
=
create
(
:project
,
:public
,
:repository
,
:wiki_repo
,
name:
'awesome project 3'
)
project_2
.
repository
.
index_commits_and_blobs
project_3
.
repository
.
index_commits_and_blobs
ensure_elasticsearch_index!
it
'avoids N+1 queries'
do
control
=
ActiveRecord
::
QueryRecorder
.
new
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'commits'
,
search:
'folder'
}
}
# Some N+1 queries still exist
project_2
=
create
(
:project
,
:public
,
:repository
,
:wiki_repo
,
name:
'awesome project 2'
)
expect
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'commits'
,
search:
'folder'
}
}.
not_to
exceed_query_limit
(
control
).
with_threshold
(
9
)
project_3
=
create
(
:project
,
:public
,
:repository
,
:wiki_repo
,
name:
'awesome project 3'
)
end
project_2
.
repository
.
index_commits_and_blobs
end
project_3
.
repository
.
index_commits_and_blobs
context
'for blobs scope'
,
:sidekiq_might_not_need_inline
do
ensure_elasticsearch_index!
before
do
project
.
repository
.
index_commits_and_blobs
ensure_elasticsearch_index!
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'monitors'
}
# Some N+1 queries still exist
expect
{
get
api
(
endpoint
,
user
),
params:
{
scope:
'commits'
,
search:
'folder'
}
}.
not_to
exceed_query_limit
(
control
).
with_threshold
(
9
)
end
end
end
it_behaves_like
'response is correct'
,
schema:
'public_api/v4/blobs'
context
'for blobs scope'
do
before
do
it_behaves_like
'pagination'
,
scope:
'blobs'
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'monitors'
}
context
'filters'
do
def
results_filenames
json_response
.
map
{
|
h
|
h
[
'filename'
]
}.
compact
end
end
def
results_paths
it_behaves_like
'response is correct'
,
schema:
'public_api/v4/blobs'
json_response
.
map
{
|
h
|
h
[
'path'
]
}.
compact
end
context
'with an including filter'
do
it_behaves_like
'pagination'
,
scope:
'blobs'
it
'by filename'
do
get
api
(
"/projects/
#{
project
.
id
}
/search"
,
user
),
params:
{
scope:
'blobs'
,
search:
'mon* filename:PROCESS.md'
}
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
context
'filters'
do
expect
(
json_response
.
size
).
to
eq
(
1
)
def
results_filenames
expect
(
results_filenames
).
to
all
(
match
(
%r{PROCESS.md$}
))
json_response
.
map
{
|
h
|
h
[
'filename'
]
}.
compact
end
end
it
'by path'
do
def
results_paths
get
api
(
"/projects/
#{
project
.
id
}
/search"
,
user
),
params:
{
scope:
'blobs'
,
search:
'mon* path:files/markdown'
}
json_response
.
map
{
|
h
|
h
[
'path'
]
}.
compact
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
json_response
.
size
).
to
eq
(
1
)
expect
(
results_paths
).
to
all
(
match
(
%r{^files/markdown/}
))
end
end
it
'by extension'
do
context
'with an including filter'
do
get
api
(
"/projects/
#{
project
.
id
}
/search"
,
user
),
params:
{
scope:
'blobs'
,
search:
'mon* extension:md'
}
it
'by filename'
do
get
api
(
"/projects/
#{
project
.
id
}
/search"
,
user
),
params:
{
scope:
'blobs'
,
search:
'mon* filename:PROCESS.md'
}
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
json_response
.
size
).
to
eq
(
3
)
expect
(
json_response
.
size
).
to
eq
(
1
)
expect
(
results_filenames
).
to
all
(
match
(
%r{PROCESS.md$}
))
end
expect
(
results_filenames
).
to
all
(
match
(
%r{.*.md$}
))
it
'by path'
do
end
get
api
(
"/projects/
#{
project
.
id
}
/search"
,
user
),
params:
{
scope:
'blobs'
,
search:
'mon* path:markdown'
}
end
context
'with an excluding filter'
do
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
it
'by filename'
do
expect
(
json_response
.
size
).
to
eq
(
1
)
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'* -filename:PROCESS.md'
}
expect
(
results_paths
).
to
all
(
match
(
%r{^files/markdown/}
))
end
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
it
'by extension'
do
expect
(
results_filenames
).
not_to
include
(
'PROCESS.md'
)
get
api
(
"/projects/
#{
project
.
id
}
/search"
,
user
),
params:
{
scope:
'blobs'
,
search:
'mon* extension:md'
}
expect
(
json_response
.
size
).
to
eq
(
20
)
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
json_response
.
size
).
to
eq
(
3
)
expect
(
results_filenames
).
to
all
(
match
(
%r{.*.md$}
))
end
end
end
it
'by path'
do
context
'with an excluding filter'
do
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'* -path:files/markdown'
}
it
'by filename'
do
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'* -filename:PROCESS.md'
}
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
results_paths
).
not_to
include
(
a_string_matching
(
%r{^files/markdown/}
)
)
expect
(
results_filenames
).
not_to
include
(
'PROCESS.md'
)
expect
(
json_response
.
size
).
to
eq
(
20
)
expect
(
json_response
.
size
).
to
eq
(
20
)
end
end
it
'by extension
'
do
it
'by path
'
do
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'* -extension:md
'
}
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'* -path:files/markdown
'
}
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
results_paths
).
not_to
include
(
a_string_matching
(
%r{^files/markdown/}
))
expect
(
json_response
.
size
).
to
eq
(
20
)
end
it
'by extension'
do
get
api
(
endpoint
,
user
),
params:
{
scope:
'blobs'
,
search:
'* -extension:md'
}
expect
(
results_filenames
).
not_to
include
(
a_string_matching
(
%r{.*.md$}
))
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
json_response
.
size
).
to
eq
(
20
)
expect
(
results_filenames
).
not_to
include
(
a_string_matching
(
%r{.*.md$}
))
expect
(
json_response
.
size
).
to
eq
(
20
)
end
end
end
end
end
end
end
...
@@ -270,7 +262,7 @@ RSpec.describe API::Search do
...
@@ -270,7 +262,7 @@ RSpec.describe API::Search do
end
end
end
end
context
'for users scope'
,
:sidekiq_inline
do
context
'for users scope'
,
:sidekiq_
might_not_need_
inline
do
before
do
before
do
create_list
(
:user
,
2
).
each
do
|
user
|
create_list
(
:user
,
2
).
each
do
|
user
|
project
.
add_developer
(
user
)
project
.
add_developer
(
user
)
...
@@ -326,7 +318,13 @@ RSpec.describe API::Search do
...
@@ -326,7 +318,13 @@ RSpec.describe API::Search do
stub_ee_application_setting
(
elasticsearch_limit_indexing:
true
)
stub_ee_application_setting
(
elasticsearch_limit_indexing:
true
)
end
end
it_behaves_like
'elasticsearch disabled'
context
'and namespace is indexed'
do
before
do
create
:elasticsearch_indexed_namespace
,
namespace:
group
end
it_behaves_like
'elasticsearch enabled'
,
level: :global
end
end
end
context
'when elasticsearch_limit_indexing off'
do
context
'when elasticsearch_limit_indexing off'
do
...
...
ee/spec/services/search/global_service_spec.rb
View file @
edab3aa9
...
@@ -177,15 +177,37 @@ RSpec.describe Search::GlobalService do
...
@@ -177,15 +177,37 @@ RSpec.describe Search::GlobalService do
end
end
end
end
context
'when
ES is not us
ed'
do
context
'when
elasticearch_search is disabl
ed'
do
before
do
before
do
stub_ee_application_setting
(
elasticsearch_
limit_indexing:
tru
e
)
stub_ee_application_setting
(
elasticsearch_
search:
fals
e
)
end
end
it
'does not include ES-specific scopes'
do
it
'does not include ES-specific scopes'
do
expect
(
described_class
.
new
(
user
,
{}).
allowed_scopes
).
not_to
include
(
'commits'
)
expect
(
described_class
.
new
(
user
,
{}).
allowed_scopes
).
not_to
include
(
'commits'
)
end
end
end
end
context
'when elasticsearch_limit_indexing is enabled'
do
before
do
stub_ee_application_setting
(
elasticsearch_limit_indexing:
true
)
end
context
'when advanced_global_search_for_limited_indexing feature flag is disabled'
do
before
do
stub_feature_flags
(
advanced_global_search_for_limited_indexing:
false
)
end
it
'does not include ES-specific scopes'
do
expect
(
described_class
.
new
(
user
,
{}).
allowed_scopes
).
not_to
include
(
'commits'
)
end
end
context
'when advanced_global_search_for_limited_indexing feature flag is enabled'
do
it
'includes ES-specific scopes'
do
expect
(
described_class
.
new
(
user
,
{}).
allowed_scopes
).
to
include
(
'commits'
)
end
end
end
end
end
context
'confidential notes'
do
context
'confidential notes'
do
...
...
ee/spec/support/features/redacted_search_results_examples.rb
View file @
edab3aa9
# frozen_string_literal: true
# frozen_string_literal: true
RSpec
.
shared_examples
'a redacted search results page'
do
RSpec
.
shared_examples
'a redacted search results page'
do
|
include_anonymous:
true
|
let
(
:public_group
)
{
create
(
:group
,
:public
)
}
let
(
:public_group
)
{
create
(
:group
,
:public
)
}
let
(
:public_restricted_project
)
{
create
(
:project
,
:repository
,
:public
,
:wiki_repo
,
namespace:
public_group
,
name:
'The Project'
)
}
let
(
:public_restricted_project
)
{
create
(
:project
,
:repository
,
:public
,
:wiki_repo
,
namespace:
public_group
,
name:
'The Project'
)
}
let
(
:issue_access_level
)
{
ProjectFeature
::
PRIVATE
}
let
(
:issue_access_level
)
{
ProjectFeature
::
PRIVATE
}
...
@@ -41,7 +41,7 @@ RSpec.shared_examples 'a redacted search results page' do
...
@@ -41,7 +41,7 @@ RSpec.shared_examples 'a redacted search results page' do
end
end
it_behaves_like
'redacted search results page assertions'
,
true
it_behaves_like
'redacted search results page assertions'
,
true
it_behaves_like
'redacted search results page assertions'
,
false
it_behaves_like
'redacted search results page assertions'
,
false
if
include_anonymous
end
end
# Only intended to be used in the above shared examples to avoid duplication of
# Only intended to be used in the above shared examples to avoid duplication of
...
...
locale/gitlab.pot
View file @
edab3aa9
...
@@ -28853,6 +28853,9 @@ msgstr ""
...
@@ -28853,6 +28853,9 @@ msgstr ""
msgid "You must accept our Terms of Service and privacy policy in order to register an account"
msgid "You must accept our Terms of Service and privacy policy in order to register an account"
msgstr ""
msgstr ""
msgid "You must be logged in to search across all of GitLab"
msgstr ""
msgid "You must disassociate %{domain} from all clusters it is attached to before deletion."
msgid "You must disassociate %{domain} from all clusters it is attached to before deletion."
msgstr ""
msgstr ""
...
...
spec/controllers/search_controller_spec.rb
View file @
edab3aa9
...
@@ -95,49 +95,77 @@ RSpec.describe SearchController do
...
@@ -95,49 +95,77 @@ RSpec.describe SearchController do
using
RSpec
::
Parameterized
::
TableSyntax
using
RSpec
::
Parameterized
::
TableSyntax
render_views
render_views
it
'omits pipeline status from load'
do
context
'when block_anonymous_global_searches is disabled'
do
project
=
create
(
:project
,
:public
)
before
do
expect
(
Gitlab
::
Cache
::
Ci
::
ProjectPipelineStatus
).
not_to
receive
(
:load_in_batch_for_projects
)
stub_feature_flags
(
block_anonymous_global_searches:
false
)
end
get
:show
,
params:
{
scope:
'projects'
,
search:
project
.
name
}
it
'omits pipeline status from load'
do
project
=
create
(
:project
,
:public
)
expect
(
Gitlab
::
Cache
::
Ci
::
ProjectPipelineStatus
).
not_to
receive
(
:load_in_batch_for_projects
)
expect
(
assigns
[
:search_objects
].
first
).
to
eq
project
get
:show
,
params:
{
scope:
'projects'
,
search:
project
.
name
}
end
context
'check search term length'
do
expect
(
assigns
[
:search_objects
].
first
).
to
eq
project
let
(
:search_queries
)
do
char_limit
=
SearchService
::
SEARCH_CHAR_LIMIT
term_limit
=
SearchService
::
SEARCH_TERM_LIMIT
{
chars_under_limit:
(
'a'
*
(
char_limit
-
1
)),
chars_over_limit:
(
'a'
*
(
char_limit
+
1
)),
terms_under_limit:
(
'abc '
*
(
term_limit
-
1
)),
terms_over_limit:
(
'abc '
*
(
term_limit
+
1
))
}
end
end
where
(
:string_name
,
:expectation
)
do
context
'check search term length'
do
:chars_under_limit
|
:not_to_set_flash
let
(
:search_queries
)
do
:chars_over_limit
|
:set_chars_flash
char_limit
=
SearchService
::
SEARCH_CHAR_LIMIT
:terms_under_limit
|
:not_to_set_flash
term_limit
=
SearchService
::
SEARCH_TERM_LIMIT
:terms_over_limit
|
:set_terms_flash
{
end
chars_under_limit:
(
'a'
*
(
char_limit
-
1
)),
chars_over_limit:
(
'a'
*
(
char_limit
+
1
)),
terms_under_limit:
(
'abc '
*
(
term_limit
-
1
)),
terms_over_limit:
(
'abc '
*
(
term_limit
+
1
))
}
end
with_them
do
where
(
:string_name
,
:expectation
)
do
it
do
:chars_under_limit
|
:not_to_set_flash
get
:show
,
params:
{
scope:
'projects'
,
search:
search_queries
[
string_name
]
}
:chars_over_limit
|
:set_chars_flash
:terms_under_limit
|
:not_to_set_flash
case
expectation
:terms_over_limit
|
:set_terms_flash
when
:not_to_set_flash
end
expect
(
controller
).
not_to
set_flash
[
:alert
]
when
:set_chars_flash
with_them
do
expect
(
controller
).
to
set_flash
[
:alert
].
to
(
/characters/
)
it
do
when
:set_terms_flash
get
:show
,
params:
{
scope:
'projects'
,
search:
search_queries
[
string_name
]
}
expect
(
controller
).
to
set_flash
[
:alert
].
to
(
/terms/
)
case
expectation
when
:not_to_set_flash
expect
(
controller
).
not_to
set_flash
[
:alert
]
when
:set_chars_flash
expect
(
controller
).
to
set_flash
[
:alert
].
to
(
/characters/
)
when
:set_terms_flash
expect
(
controller
).
to
set_flash
[
:alert
].
to
(
/terms/
)
end
end
end
end
end
end
end
end
end
context
'when block_anonymous_global_searches is enabled'
do
context
'for unauthenticated user'
do
before
do
sign_out
(
user
)
end
it
'redirects to login page'
do
get
:show
,
params:
{
scope:
'projects'
,
search:
'*'
}
expect
(
response
).
to
redirect_to
new_user_session_path
end
end
context
'for authenticated user'
do
it
'succeeds'
do
get
:show
,
params:
{
scope:
'projects'
,
search:
'*'
}
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
end
end
end
end
end
it
'finds issue comments'
do
it
'finds issue comments'
do
...
...
spec/features/search/user_searches_for_issues_spec.rb
View file @
edab3aa9
...
@@ -86,20 +86,33 @@ RSpec.describe 'User searches for issues', :js do
...
@@ -86,20 +86,33 @@ RSpec.describe 'User searches for issues', :js do
end
end
context
'when signed out'
do
context
'when signed out'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
context
'when block_anonymous_global_searches is disabled'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
before
do
before
do
visit
(
search_path
)
stub_feature_flags
(
block_anonymous_global_searches:
false
)
end
visit
(
search_path
)
end
include_examples
'top right search form'
include_examples
'top right search form'
it
'finds an issue'
do
it
'finds an issue'
do
search_for_issue
(
issue1
.
title
)
search_for_issue
(
issue1
.
title
)
page
.
within
(
'.results'
)
do
page
.
within
(
'.results'
)
do
expect
(
page
).
to
have_link
(
issue1
.
title
)
expect
(
page
).
to
have_link
(
issue1
.
title
)
expect
(
page
).
not_to
have_link
(
issue2
.
title
)
expect
(
page
).
not_to
have_link
(
issue2
.
title
)
end
end
end
context
'when block_anonymous_global_searches is enabled'
do
before
do
visit
(
search_path
)
end
it
'is redirected to login page'
do
expect
(
page
).
to
have_content
(
'You must be logged in to search across all of GitLab'
)
end
end
end
end
end
end
...
...
spec/features/search/user_searches_for_projects_spec.rb
View file @
edab3aa9
...
@@ -6,31 +6,44 @@ RSpec.describe 'User searches for projects' do
...
@@ -6,31 +6,44 @@ RSpec.describe 'User searches for projects' do
let!
(
:project
)
{
create
(
:project
,
:public
,
name:
'Shop'
)
}
let!
(
:project
)
{
create
(
:project
,
:public
,
name:
'Shop'
)
}
context
'when signed out'
do
context
'when signed out'
do
include_examples
'top right search form'
context
'when block_anonymous_global_searches is disabled'
do
before
do
stub_feature_flags
(
block_anonymous_global_searches:
false
)
end
it
'finds a project'
do
include_examples
'top right search form'
visit
(
search_path
)
fill_in
(
'dashboard_search'
,
with:
project
.
name
[
0
..
3
])
it
'finds a project'
do
click_button
(
'Search'
)
visit
(
search_path
)
expect
(
page
).
to
have_link
(
project
.
name
)
fill_in
(
'dashboard_search'
,
with:
project
.
name
[
0
..
3
]
)
end
click_button
(
'Search'
)
it
'preserves the group being searched in'
do
expect
(
page
).
to
have_link
(
project
.
name
)
visit
(
search_path
(
group_id:
project
.
namespace
.
id
))
end
submit_search
(
'foo'
)
it
'preserves the group being searched in'
do
visit
(
search_path
(
group_id:
project
.
namespace
.
id
))
expect
(
find
(
'#group_id'
,
visible:
false
).
value
).
to
eq
(
project
.
namespace
.
id
.
to_s
)
submit_search
(
'foo'
)
end
expect
(
find
(
'#group_id'
,
visible:
false
).
value
).
to
eq
(
project
.
namespace
.
id
.
to_s
)
end
it
'preserves the project being searched in'
do
it
'preserves the project being searched in'
do
visit
(
search_path
(
project_id:
project
.
id
))
visit
(
search_path
(
project_id:
project
.
id
))
submit_search
(
'foo'
)
submit_search
(
'foo'
)
expect
(
find
(
'#project_id'
,
visible:
false
).
value
).
to
eq
(
project
.
id
.
to_s
)
end
end
expect
(
find
(
'#project_id'
,
visible:
false
).
value
).
to
eq
(
project
.
id
.
to_s
)
context
'when block_anonymous_global_searches is enabled'
do
it
'is redirected to login page'
do
visit
(
search_path
)
expect
(
page
).
to
have_content
(
'You must be logged in to search across all of GitLab'
)
end
end
end
end
end
end
end
spec/frontend/fixtures/search.rb
View file @
edab3aa9
...
@@ -7,10 +7,16 @@ RSpec.describe SearchController, '(JavaScript fixtures)', type: :controller do
...
@@ -7,10 +7,16 @@ RSpec.describe SearchController, '(JavaScript fixtures)', type: :controller do
render_views
render_views
let_it_be
(
:user
)
{
create
(
:admin
)
}
before
(
:all
)
do
before
(
:all
)
do
clean_frontend_fixtures
(
'search/'
)
clean_frontend_fixtures
(
'search/'
)
end
end
before
do
sign_in
(
user
)
end
it
'search/show.html'
do
it
'search/show.html'
do
get
:show
get
:show
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment