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
db8993ab
Commit
db8993ab
authored
Feb 02, 2021
by
Zack Cuddy
Committed by
Phil Hughes
Feb 02, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Global Search - UX Refresh for Sort Button
Replaces HAML dropdown with GitLab UI. Updates naming.
parent
d7046d7b
Changes
21
Hide whitespace changes
Inline
Side-by-side
Showing
21 changed files
with
458 additions
and
112 deletions
+458
-112
app/assets/javascripts/search/index.js
app/assets/javascripts/search/index.js
+2
-0
app/assets/javascripts/search/sort/components/app.vue
app/assets/javascripts/search/sort/components/app.vue
+103
-0
app/assets/javascripts/search/sort/constants.js
app/assets/javascripts/search/sort/constants.js
+19
-0
app/assets/javascripts/search/sort/index.js
app/assets/javascripts/search/sort/index.js
+27
-0
app/helpers/search_helper.rb
app/helpers/search_helper.rb
+12
-0
app/helpers/sorting_helper.rb
app/helpers/sorting_helper.rb
+1
-20
app/helpers/sorting_titles_values_helper.rb
app/helpers/sorting_titles_values_helper.rb
+0
-8
app/views/search/_results_status.html.haml
app/views/search/_results_status.html.haml
+1
-1
app/views/search/_sort_dropdown.html.haml
app/views/search/_sort_dropdown.html.haml
+0
-14
changelogs/unreleased/273328-global-search-sort-ux.yml
changelogs/unreleased/273328-global-search-sort-ux.yml
+5
-0
ee/app/helpers/ee/search_helper.rb
ee/app/helpers/ee/search_helper.rb
+14
-0
ee/app/views/search/_sort_by_relevancy.haml
ee/app/views/search/_sort_by_relevancy.haml
+0
-2
ee/spec/helpers/search_helper_spec.rb
ee/spec/helpers/search_helper_spec.rb
+39
-0
ee/spec/views/search/_sort_dropdown.html.haml_spec.rb
ee/spec/views/search/_sort_dropdown.html.haml_spec.rb
+0
-37
locale/gitlab.pot
locale/gitlab.pot
+3
-3
spec/features/search/user_searches_for_issues_spec.rb
spec/features/search/user_searches_for_issues_spec.rb
+1
-1
spec/features/search/user_searches_for_merge_requests_spec.rb
.../features/search/user_searches_for_merge_requests_spec.rb
+26
-8
spec/frontend/search/mock_data.js
spec/frontend/search/mock_data.js
+16
-0
spec/frontend/search/sort/components/app_spec.js
spec/frontend/search/sort/components/app_spec.js
+168
-0
spec/helpers/search_helper_spec.rb
spec/helpers/search_helper_spec.rb
+21
-0
spec/helpers/sorting_helper_spec.rb
spec/helpers/sorting_helper_spec.rb
+0
-18
No files found.
app/assets/javascripts/search/index.js
View file @
db8993ab
...
@@ -5,6 +5,7 @@ import { queryToObject } from '~/lib/utils/url_utility';
...
@@ -5,6 +5,7 @@ import { queryToObject } from '~/lib/utils/url_utility';
import
createStore
from
'
./store
'
;
import
createStore
from
'
./store
'
;
import
{
initTopbar
}
from
'
./topbar
'
;
import
{
initTopbar
}
from
'
./topbar
'
;
import
{
initSidebar
}
from
'
./sidebar
'
;
import
{
initSidebar
}
from
'
./sidebar
'
;
import
{
initSearchSort
}
from
'
./sort
'
;
export
const
initSearchApp
=
()
=>
{
export
const
initSearchApp
=
()
=>
{
// Similar to url_utility.decodeUrlParameter
// Similar to url_utility.decodeUrlParameter
...
@@ -16,6 +17,7 @@ export const initSearchApp = () => {
...
@@ -16,6 +17,7 @@ export const initSearchApp = () => {
initTopbar
(
store
);
initTopbar
(
store
);
initSidebar
(
store
);
initSidebar
(
store
);
initSearchSort
(
store
);
setHighlightClass
(
query
.
search
);
// Code Highlighting
setHighlightClass
(
query
.
search
);
// Code Highlighting
refreshCounts
();
// Other Scope Tab Counts
refreshCounts
();
// Other Scope Tab Counts
...
...
app/assets/javascripts/search/sort/components/app.vue
0 → 100644
View file @
db8993ab
<
script
>
import
{
mapState
,
mapActions
}
from
'
vuex
'
;
import
{
GlButtonGroup
,
GlButton
,
GlDropdown
,
GlDropdownItem
,
GlTooltipDirective
,
}
from
'
@gitlab/ui
'
;
import
{
SORT_DIRECTION_UI
}
from
'
../constants
'
;
export
default
{
name
:
'
GlobalSearchSort
'
,
components
:
{
GlButtonGroup
,
GlButton
,
GlDropdown
,
GlDropdownItem
,
},
directives
:
{
GlTooltip
:
GlTooltipDirective
,
},
props
:
{
searchSortOptions
:
{
type
:
Array
,
required
:
true
,
},
},
computed
:
{
...
mapState
([
'
query
'
]),
selectedSortOption
:
{
get
()
{
const
{
sort
}
=
this
.
query
;
if
(
!
sort
)
{
return
this
.
searchSortOptions
[
0
];
}
const
sortOption
=
this
.
searchSortOptions
.
find
((
option
)
=>
{
if
(
!
option
.
sortable
)
{
return
option
.
sortParam
===
sort
;
}
return
Object
.
values
(
option
.
sortParam
).
indexOf
(
sort
)
!==
-
1
;
});
// Handle invalid sort param
return
sortOption
||
this
.
searchSortOptions
[
0
];
},
set
(
value
)
{
this
.
setQuery
({
key
:
'
sort
'
,
value
});
this
.
applyQuery
();
},
},
sortDirectionData
()
{
if
(
!
this
.
selectedSortOption
.
sortable
)
{
return
SORT_DIRECTION_UI
.
disabled
;
}
return
this
.
query
?.
sort
?.
includes
(
'
asc
'
)
?
SORT_DIRECTION_UI
.
asc
:
SORT_DIRECTION_UI
.
desc
;
},
},
methods
:
{
...
mapActions
([
'
applyQuery
'
,
'
setQuery
'
]),
handleSortChange
(
option
)
{
if
(
!
option
.
sortable
)
{
this
.
selectedSortOption
=
option
.
sortParam
;
}
else
{
// Default new sort options to desc
this
.
selectedSortOption
=
option
.
sortParam
.
desc
;
}
},
handleSortDirectionChange
()
{
this
.
selectedSortOption
=
this
.
sortDirectionData
.
direction
===
'
desc
'
?
this
.
selectedSortOption
.
sortParam
.
asc
:
this
.
selectedSortOption
.
sortParam
.
desc
;
},
},
};
</
script
>
<
template
>
<gl-button-group>
<gl-dropdown
:text=
"selectedSortOption.title"
:right=
"true"
class=
"w-100"
>
<gl-dropdown-item
v-for=
"sortOption in searchSortOptions"
:key=
"sortOption.title"
is-check-item
:is-checked=
"sortOption.title === selectedSortOption.title"
@
click=
"handleSortChange(sortOption)"
>
{{
sortOption
.
title
}}
</gl-dropdown-item
>
</gl-dropdown>
<gl-button
v-gl-tooltip
:disabled=
"!selectedSortOption.sortable"
:title=
"sortDirectionData.tooltip"
:icon=
"sortDirectionData.icon"
@
click=
"handleSortDirectionChange"
/>
</gl-button-group>
</
template
>
app/assets/javascripts/search/sort/constants.js
0 → 100644
View file @
db8993ab
import
{
__
}
from
'
~/locale
'
;
export
const
SORT_DIRECTION_UI
=
{
disabled
:
{
direction
:
null
,
tooltip
:
''
,
icon
:
'
sort-highest
'
,
},
desc
:
{
direction
:
'
desc
'
,
tooltip
:
__
(
'
Sort direction: Descending
'
),
icon
:
'
sort-highest
'
,
},
asc
:
{
direction
:
'
asc
'
,
tooltip
:
__
(
'
Sort direction: Ascending
'
),
icon
:
'
sort-lowest
'
,
},
};
app/assets/javascripts/search/sort/index.js
0 → 100644
View file @
db8993ab
import
Vue
from
'
vue
'
;
import
Translate
from
'
~/vue_shared/translate
'
;
import
GlobalSearchSort
from
'
./components/app.vue
'
;
Vue
.
use
(
Translate
);
export
const
initSearchSort
=
(
store
)
=>
{
const
el
=
document
.
getElementById
(
'
js-search-sort
'
);
if
(
!
el
)
return
false
;
let
{
searchSortOptions
}
=
el
.
dataset
;
searchSortOptions
=
JSON
.
parse
(
searchSortOptions
);
return
new
Vue
({
el
,
store
,
render
(
createElement
)
{
return
createElement
(
GlobalSearchSort
,
{
props
:
{
searchSortOptions
,
},
});
},
});
};
app/helpers/search_helper.rb
View file @
db8993ab
...
@@ -129,6 +129,18 @@ module SearchHelper
...
@@ -129,6 +129,18 @@ module SearchHelper
@search_service
||=
::
SearchService
.
new
(
current_user
,
params
.
merge
(
confidential:
Gitlab
::
Utils
.
to_boolean
(
params
[
:confidential
])))
@search_service
||=
::
SearchService
.
new
(
current_user
,
params
.
merge
(
confidential:
Gitlab
::
Utils
.
to_boolean
(
params
[
:confidential
])))
end
end
def
search_sort_options
options
=
[]
options
<<
{
title:
_
(
'Created date'
),
sortable:
true
,
sortParam:
{
asc:
'created_asc'
,
desc:
'created_desc'
}
}
end
private
private
# Autocomplete results for various settings pages
# Autocomplete results for various settings pages
...
...
app/helpers/sorting_helper.rb
View file @
db8993ab
...
@@ -30,8 +30,7 @@ module SortingHelper
...
@@ -30,8 +30,7 @@ module SortingHelper
sort_value_contacted_date
=>
sort_title_contacted_date
,
sort_value_contacted_date
=>
sort_title_contacted_date
,
sort_value_relative_position
=>
sort_title_relative_position
,
sort_value_relative_position
=>
sort_title_relative_position
,
sort_value_size
=>
sort_title_size
,
sort_value_size
=>
sort_title_size
,
sort_value_expire_date
=>
sort_title_expire_date
,
sort_value_expire_date
=>
sort_title_expire_date
sort_value_relevant
=>
sort_title_relevant
}
}
end
end
...
@@ -85,13 +84,6 @@ module SortingHelper
...
@@ -85,13 +84,6 @@ module SortingHelper
}
}
end
end
def
search_reverse_sort_options_hash
{
sort_value_recently_created
=>
sort_value_oldest_created
,
sort_value_oldest_created
=>
sort_value_recently_created
}
end
def
groups_sort_options_hash
def
groups_sort_options_hash
{
{
sort_value_name
=>
sort_title_name
,
sort_value_name
=>
sort_title_name
,
...
@@ -229,10 +221,6 @@ module SortingHelper
...
@@ -229,10 +221,6 @@ module SortingHelper
sort_options_hash
[
sort_value
]
sort_options_hash
[
sort_value
]
end
end
def
search_sort_option_title
(
sort_value
)
sort_options_hash
[
sort_value
]
end
def
sort_direction_icon
(
sort_value
)
def
sort_direction_icon
(
sort_value
)
case
sort_value
case
sort_value
when
sort_value_milestone
,
sort_value_due_date
,
/_asc\z/
when
sort_value_milestone
,
sort_value_due_date
,
/_asc\z/
...
@@ -271,13 +259,6 @@ module SortingHelper
...
@@ -271,13 +259,6 @@ module SortingHelper
sort_direction_button
(
url
,
reverse_sort
,
sort_value
)
sort_direction_button
(
url
,
reverse_sort
,
sort_value
)
end
end
def
search_sort_direction_button
(
sort_value
)
reverse_sort
=
search_reverse_sort_options_hash
[
sort_value
]
url
=
page_filter_path
(
sort:
reverse_sort
)
sort_direction_button
(
url
,
reverse_sort
,
sort_value
)
end
def
packages_sort_options_hash
def
packages_sort_options_hash
{
{
sort_value_recently_created
=>
sort_title_created_date
,
sort_value_recently_created
=>
sort_title_created_date
,
...
...
app/helpers/sorting_titles_values_helper.rb
View file @
db8993ab
...
@@ -166,10 +166,6 @@ module SortingTitlesValuesHelper
...
@@ -166,10 +166,6 @@ module SortingTitlesValuesHelper
s_
(
'SortOptions|Expired date'
)
s_
(
'SortOptions|Expired date'
)
end
end
def
sort_title_relevant
s_
(
'SortOptions|Relevant'
)
end
# Values.
# Values.
def
sort_value_access_level_asc
def
sort_value_access_level_asc
'access_level_asc'
'access_level_asc'
...
@@ -330,10 +326,6 @@ module SortingTitlesValuesHelper
...
@@ -330,10 +326,6 @@ module SortingTitlesValuesHelper
def
sort_value_expire_date
def
sort_value_expire_date
'expired_asc'
'expired_asc'
end
end
def
sort_value_relevant
'relevant'
end
end
end
SortingHelper
.
include_if_ee
(
'::EE::SortingTitlesValuesHelper'
)
SortingHelper
.
include_if_ee
(
'::EE::SortingTitlesValuesHelper'
)
app/views/search/_results_status.html.haml
View file @
db8993ab
...
@@ -22,4 +22,4 @@
...
@@ -22,4 +22,4 @@
=
_
(
"in group %{link_to_group}"
).
html_safe
%
{
link_to_group:
link_to_group
}
=
_
(
"in group %{link_to_group}"
).
html_safe
%
{
link_to_group:
link_to_group
}
-
if
search_service
.
show_sort_dropdown?
-
if
search_service
.
show_sort_dropdown?
.gl-md-display-flex.gl-flex-direction-column
.gl-md-display-flex.gl-flex-direction-column
=
render
partial:
'search/sort_dropdown'
#js-search-sort
{
data:
{
"search-sort-options"
=>
search_sort_options
.
to_json
}
}
app/views/search/_sort_dropdown.html.haml
deleted
100644 → 0
View file @
d7046d7b
-
sort_value
=
@sort
-
sort_title
=
search_sort_option_title
(
sort_value
)
.dropdown.gl-display-inline-block.gl-ml-3.filter-dropdown-container
.btn-group
{
role:
'group'
}
.btn-group
{
role:
'group'
}
%button
.dropdown-menu-toggle
{
type:
'button'
,
data:
{
toggle:
'dropdown'
,
display:
'static'
},
class:
'btn btn-default'
}
=
sort_title
=
sprite_icon
(
'chevron-down'
,
css_class:
'dropdown-menu-toggle-icon gl-top-3'
)
%ul
.dropdown-menu.dropdown-menu-right.dropdown-menu-selectable.dropdown-menu-sort
%li
=
render_if_exists
(
'search/sort_by_relevancy'
,
sort_title:
sort_title
)
=
sortable_item
(
sort_title_recently_created
,
page_filter_path
(
sort:
sort_value_recently_created
),
sort_title
)
=
search_sort_direction_button
(
sort_value
)
changelogs/unreleased/273328-global-search-sort-ux.yml
0 → 100644
View file @
db8993ab
---
title
:
Global Search - UX Refresh for Sort Button
merge_request
:
52387
author
:
type
:
changed
ee/app/helpers/ee/search_helper.rb
View file @
db8993ab
...
@@ -116,6 +116,20 @@ module EE
...
@@ -116,6 +116,20 @@ module EE
tag
.
div
(
message
.
html_safe
,
data:
{
testid:
'es-status-marker'
,
enabled:
enabled
})
tag
.
div
(
message
.
html_safe
,
data:
{
testid:
'es-status-marker'
,
enabled:
enabled
})
end
end
override
:search_sort_options
def
search_sort_options
options
=
[]
if
search_service
.
use_elasticsearch?
options
<<
{
title:
_
(
'Most relevant'
),
sortable:
false
,
sortParam:
'relevant'
}
end
options
+
super
end
private
private
def
recent_epics_autocomplete
(
term
)
def
recent_epics_autocomplete
(
term
)
...
...
ee/app/views/search/_sort_by_relevancy.haml
deleted
100644 → 0
View file @
d7046d7b
-
if
search_service
.
use_elasticsearch?
=
sortable_item
(
sort_title_relevant
,
page_filter_path
(
sort:
sort_value_relevant
),
sort_title
)
ee/spec/helpers/search_helper_spec.rb
View file @
db8993ab
...
@@ -247,4 +247,43 @@ RSpec.describe SearchHelper do
...
@@ -247,4 +247,43 @@ RSpec.describe SearchHelper do
end
end
end
end
end
end
describe
'#search_sort_options_json'
do
let
(
:user
)
{
create
(
:user
)
}
mock_relevant_sort
=
{
title:
_
(
'Most relevant'
),
sortable:
false
,
sortParam:
'relevant'
}
mock_created_sort
=
{
title:
_
(
'Created date'
),
sortable:
true
,
sortParam:
{
asc:
'created_asc'
,
desc:
'created_desc'
}
}
before
do
allow
(
self
).
to
receive
(
:current_user
).
and_return
(
user
)
end
context
'with advanced search enabled'
do
before
do
stub_ee_application_setting
(
search_using_elasticsearch:
true
)
end
it
'returns the correct data'
do
expect
(
search_sort_options
).
to
eq
([
mock_relevant_sort
,
mock_created_sort
])
end
end
context
'with basic search enabled'
do
it
'returns the correct data'
do
expect
(
search_sort_options
).
to
eq
([
mock_created_sort
])
end
end
end
end
end
ee/spec/views/search/_sort_dropdown.html.haml_spec.rb
deleted
100644 → 0
View file @
d7046d7b
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
'search/_sort_dropdown'
do
context
'when the search page is opened'
do
before
do
@scope
=
'issues'
end
context
'with advanced search'
do
before
do
@search_service
=
instance_double
(
SearchService
,
use_elasticsearch?:
true
)
end
it
'displays the correct sort elements'
do
render
expect
(
rendered
).
to
have_selector
(
'a'
,
text:
'Relevant'
)
expect
(
rendered
).
to
have_selector
(
'a'
,
text:
'Last created'
)
end
end
context
'without advanced search'
do
before
do
@search_service
=
instance_double
(
SearchService
,
use_elasticsearch?:
false
)
end
it
'displays the correct sort elements'
do
render
expect
(
rendered
).
not_to
have_selector
(
'a'
,
text:
'Relevant'
)
expect
(
rendered
).
to
have_selector
(
'a'
,
text:
'Last created'
)
end
end
end
end
locale/gitlab.pot
View file @
db8993ab
...
@@ -19071,6 +19071,9 @@ msgstr ""
...
@@ -19071,6 +19071,9 @@ msgstr ""
msgid "More than %{number_commits_distance} commits different with %{default_branch}"
msgid "More than %{number_commits_distance} commits different with %{default_branch}"
msgstr ""
msgstr ""
msgid "Most relevant"
msgstr ""
msgid "Most stars"
msgid "Most stars"
msgstr ""
msgstr ""
...
@@ -27287,9 +27290,6 @@ msgstr ""
...
@@ -27287,9 +27290,6 @@ msgstr ""
msgid "SortOptions|Recently starred"
msgid "SortOptions|Recently starred"
msgstr ""
msgstr ""
msgid "SortOptions|Relevant"
msgstr ""
msgid "SortOptions|Size"
msgid "SortOptions|Size"
msgstr ""
msgstr ""
...
...
spec/features/search/user_searches_for_issues_spec.rb
View file @
db8993ab
...
@@ -75,7 +75,7 @@ RSpec.describe 'User searches for issues', :js do
...
@@ -75,7 +75,7 @@ RSpec.describe 'User searches for issues', :js do
expect
(
page
.
all
(
'.search-result-row'
).
last
).
to
have_link
(
issue1
.
title
)
expect
(
page
.
all
(
'.search-result-row'
).
last
).
to
have_link
(
issue1
.
title
)
end
end
find
(
'
.reverse-sort-btn
'
).
click
find
(
'
[data-testid="sort-highest-icon"]
'
).
click
page
.
within
(
'.results'
)
do
page
.
within
(
'.results'
)
do
expect
(
page
.
all
(
'.search-result-row'
).
first
).
to
have_link
(
issue1
.
title
)
expect
(
page
.
all
(
'.search-result-row'
).
first
).
to
have_link
(
issue1
.
title
)
...
...
spec/features/search/user_searches_for_merge_requests_spec.rb
View file @
db8993ab
...
@@ -5,8 +5,14 @@ require 'spec_helper'
...
@@ -5,8 +5,14 @@ require 'spec_helper'
RSpec
.
describe
'User searches for merge requests'
,
:js
do
RSpec
.
describe
'User searches for merge requests'
,
:js
do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
,
namespace:
user
.
namespace
)
}
let
(
:project
)
{
create
(
:project
,
namespace:
user
.
namespace
)
}
let!
(
:merge_request1
)
{
create
(
:merge_request
,
title:
'Foo'
,
source_project:
project
,
target_project:
project
)
}
let!
(
:merge_request1
)
{
create
(
:merge_request
,
title:
'Merge Request Foo'
,
source_project:
project
,
target_project:
project
,
created_at:
1
.
hour
.
ago
)
}
let!
(
:merge_request2
)
{
create
(
:merge_request
,
:simple
,
title:
'Bar'
,
source_project:
project
,
target_project:
project
)
}
let!
(
:merge_request2
)
{
create
(
:merge_request
,
:simple
,
title:
'Merge Request Bar'
,
source_project:
project
,
target_project:
project
)
}
def
search_for_mr
(
search
)
fill_in
(
'dashboard_search'
,
with:
search
)
find
(
'.btn-search'
).
click
select_search_scope
(
'Merge requests'
)
end
before
do
before
do
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
...
@@ -18,9 +24,7 @@ RSpec.describe 'User searches for merge requests', :js do
...
@@ -18,9 +24,7 @@ RSpec.describe 'User searches for merge requests', :js do
include_examples
'top right search form'
include_examples
'top right search form'
it
'finds a merge request'
do
it
'finds a merge request'
do
fill_in
(
'dashboard_search'
,
with:
merge_request1
.
title
)
search_for_mr
(
merge_request1
.
title
)
find
(
'.btn-search'
).
click
select_search_scope
(
'Merge requests'
)
page
.
within
(
'.results'
)
do
page
.
within
(
'.results'
)
do
expect
(
page
).
to
have_link
(
merge_request1
.
title
)
expect
(
page
).
to
have_link
(
merge_request1
.
title
)
...
@@ -28,6 +32,22 @@ RSpec.describe 'User searches for merge requests', :js do
...
@@ -28,6 +32,22 @@ RSpec.describe 'User searches for merge requests', :js do
end
end
end
end
it
'sorts by created date'
do
search_for_mr
(
'Merge Request'
)
page
.
within
(
'.results'
)
do
expect
(
page
.
all
(
'.search-result-row'
).
first
).
to
have_link
(
merge_request2
.
title
)
expect
(
page
.
all
(
'.search-result-row'
).
last
).
to
have_link
(
merge_request1
.
title
)
end
find
(
'[data-testid="sort-highest-icon"]'
).
click
page
.
within
(
'.results'
)
do
expect
(
page
.
all
(
'.search-result-row'
).
first
).
to
have_link
(
merge_request1
.
title
)
expect
(
page
.
all
(
'.search-result-row'
).
last
).
to
have_link
(
merge_request2
.
title
)
end
end
context
'when on a project page'
do
context
'when on a project page'
do
it
'finds a merge request'
do
it
'finds a merge request'
do
find
(
'[data-testid="project-filter"]'
).
click
find
(
'[data-testid="project-filter"]'
).
click
...
@@ -38,9 +58,7 @@ RSpec.describe 'User searches for merge requests', :js do
...
@@ -38,9 +58,7 @@ RSpec.describe 'User searches for merge requests', :js do
click_on
(
project
.
full_name
)
click_on
(
project
.
full_name
)
end
end
fill_in
(
'dashboard_search'
,
with:
merge_request1
.
title
)
search_for_mr
(
merge_request1
.
title
)
find
(
'.btn-search'
).
click
select_search_scope
(
'Merge requests'
)
page
.
within
(
'.results'
)
do
page
.
within
(
'.results'
)
do
expect
(
page
).
to
have_link
(
merge_request1
.
title
)
expect
(
page
).
to
have_link
(
merge_request1
.
title
)
...
...
spec/frontend/search/mock_data.js
View file @
db8993ab
...
@@ -45,3 +45,19 @@ export const MOCK_PROJECTS = [
...
@@ -45,3 +45,19 @@ export const MOCK_PROJECTS = [
id
:
'
test_2
'
,
id
:
'
test_2
'
,
},
},
];
];
export
const
MOCK_SORT_OPTIONS
=
[
{
title
:
'
Most relevant
'
,
sortable
:
false
,
sortParam
:
'
relevant
'
,
},
{
title
:
'
Created date
'
,
sortable
:
true
,
sortParam
:
{
asc
:
'
created_asc
'
,
desc
:
'
created_desc
'
,
},
},
];
spec/frontend/search/sort/components/app_spec.js
0 → 100644
View file @
db8993ab
import
Vuex
from
'
vuex
'
;
import
{
createLocalVue
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
GlButtonGroup
,
GlButton
,
GlDropdown
,
GlDropdownItem
}
from
'
@gitlab/ui
'
;
import
{
MOCK_QUERY
,
MOCK_SORT_OPTIONS
}
from
'
jest/search/mock_data
'
;
import
GlobalSearchSort
from
'
~/search/sort/components/app.vue
'
;
import
{
SORT_DIRECTION_UI
}
from
'
~/search/sort/constants
'
;
const
localVue
=
createLocalVue
();
localVue
.
use
(
Vuex
);
describe
(
'
GlobalSearchSort
'
,
()
=>
{
let
wrapper
;
const
actionSpies
=
{
setQuery
:
jest
.
fn
(),
applyQuery
:
jest
.
fn
(),
};
const
defaultProps
=
{
searchSortOptions
:
MOCK_SORT_OPTIONS
,
};
const
createComponent
=
(
initialState
,
props
)
=>
{
const
store
=
new
Vuex
.
Store
({
state
:
{
query
:
MOCK_QUERY
,
...
initialState
,
},
actions
:
actionSpies
,
});
wrapper
=
shallowMount
(
GlobalSearchSort
,
{
localVue
,
store
,
propsData
:
{
...
defaultProps
,
...
props
,
},
});
};
afterEach
(()
=>
{
wrapper
.
destroy
();
wrapper
=
null
;
});
const
findSortButtonGroup
=
()
=>
wrapper
.
find
(
GlButtonGroup
);
const
findSortDropdown
=
()
=>
wrapper
.
find
(
GlDropdown
);
const
findSortDirectionButton
=
()
=>
wrapper
.
find
(
GlButton
);
const
findDropdownItems
=
()
=>
findSortDropdown
().
findAll
(
GlDropdownItem
);
const
findDropdownItemsText
=
()
=>
findDropdownItems
().
wrappers
.
map
((
w
)
=>
w
.
text
());
describe
(
'
template
'
,
()
=>
{
beforeEach
(()
=>
{
createComponent
();
});
it
(
'
renders Sort Button Group
'
,
()
=>
{
expect
(
findSortButtonGroup
().
exists
()).
toBe
(
true
);
});
it
(
'
renders Sort Dropdown
'
,
()
=>
{
expect
(
findSortDropdown
().
exists
()).
toBe
(
true
);
});
it
(
'
renders Sort Direction Button
'
,
()
=>
{
expect
(
findSortDirectionButton
().
exists
()).
toBe
(
true
);
});
});
describe
(
'
Sort Dropdown Items
'
,
()
=>
{
describe
(
'
renders
'
,
()
=>
{
beforeEach
(()
=>
{
createComponent
();
});
it
(
'
an instance for each namespace
'
,
()
=>
{
expect
(
findDropdownItemsText
()).
toStrictEqual
(
MOCK_SORT_OPTIONS
.
map
((
option
)
=>
option
.
title
),
);
});
});
describe
.
each
`
sortQuery | value
${
null
}
|
${
MOCK_SORT_OPTIONS
[
0
].
title
}
${
'
asdf
'
}
|
${
MOCK_SORT_OPTIONS
[
0
].
title
}
${
MOCK_SORT_OPTIONS
[
0
].
sortParam
}
|
${
MOCK_SORT_OPTIONS
[
0
].
title
}
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
desc
}
|
${
MOCK_SORT_OPTIONS
[
1
].
title
}
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
asc
}
|
${
MOCK_SORT_OPTIONS
[
1
].
title
}
`
(
'
selected
'
,
({
sortQuery
,
value
})
=>
{
describe
(
`when sort option is
${
sortQuery
}
`
,
()
=>
{
beforeEach
(()
=>
{
createComponent
({
query
:
{
sort
:
sortQuery
}
});
});
it
(
'
is set correctly
'
,
()
=>
{
expect
(
findSortDropdown
().
attributes
(
'
text
'
)).
toBe
(
value
);
});
});
});
});
describe
.
each
`
description | sortQuery | sortUi | disabled
${
'
non-sortable
'
}
|
${
MOCK_SORT_OPTIONS
[
0
].
sortParam
}
|
${
SORT_DIRECTION_UI
.
disabled
}
|
${
'
true
'
}
${
'
descending sortable
'
}
|
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
desc
}
|
${
SORT_DIRECTION_UI
.
desc
}
|
${
undefined
}
${
'
ascending sortable
'
}
|
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
asc
}
|
${
SORT_DIRECTION_UI
.
asc
}
|
${
undefined
}
`
(
'
Sort Direction Button
'
,
({
description
,
sortQuery
,
sortUi
,
disabled
})
=>
{
describe
(
`when sort option is
${
description
}
`
,
()
=>
{
beforeEach
(()
=>
{
createComponent
({
query
:
{
sort
:
sortQuery
}
});
});
it
(
'
sets the UI correctly
'
,
()
=>
{
expect
(
findSortDirectionButton
().
attributes
(
'
disabled
'
)).
toBe
(
disabled
);
expect
(
findSortDirectionButton
().
attributes
(
'
title
'
)).
toBe
(
sortUi
.
tooltip
);
expect
(
findSortDirectionButton
().
attributes
(
'
icon
'
)).
toBe
(
sortUi
.
icon
);
});
});
});
describe
(
'
actions
'
,
()
=>
{
describe
.
each
`
description | index | value
${
'
non-sortable
'
}
|
${
0
}
|
${
MOCK_SORT_OPTIONS
[
0
].
sortParam
}
${
'
sortable
'
}
|
${
1
}
|
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
desc
}
`
(
'
handleSortChange
'
,
({
description
,
index
,
value
})
=>
{
describe
(
`when clicking a
${
description
}
option`
,
()
=>
{
beforeEach
(()
=>
{
createComponent
();
findDropdownItems
().
at
(
index
).
vm
.
$emit
(
'
click
'
);
});
it
(
'
calls setQuery and applyQuery correctly
'
,
()
=>
{
expect
(
actionSpies
.
setQuery
).
toHaveBeenCalledTimes
(
1
);
expect
(
actionSpies
.
applyQuery
).
toHaveBeenCalledTimes
(
1
);
expect
(
actionSpies
.
setQuery
).
toHaveBeenCalledWith
(
expect
.
any
(
Object
),
{
key
:
'
sort
'
,
value
,
});
});
});
});
describe
.
each
`
description | sortQuery | value
${
'
descending
'
}
|
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
desc
}
|
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
asc
}
${
'
ascending
'
}
|
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
asc
}
|
${
MOCK_SORT_OPTIONS
[
1
].
sortParam
.
desc
}
`
(
'
handleSortDirectionChange
'
,
({
description
,
sortQuery
,
value
})
=>
{
describe
(
`when toggling a
${
description
}
option`
,
()
=>
{
beforeEach
(()
=>
{
createComponent
({
query
:
{
sort
:
sortQuery
}
});
findSortDirectionButton
().
vm
.
$emit
(
'
click
'
);
});
it
(
'
calls setQuery and applyQuery correctly
'
,
()
=>
{
expect
(
actionSpies
.
setQuery
).
toHaveBeenCalledTimes
(
1
);
expect
(
actionSpies
.
applyQuery
).
toHaveBeenCalledTimes
(
1
);
expect
(
actionSpies
.
setQuery
).
toHaveBeenCalledWith
(
expect
.
any
(
Object
),
{
key
:
'
sort
'
,
value
,
});
});
});
});
});
});
spec/helpers/search_helper_spec.rb
View file @
db8993ab
...
@@ -610,4 +610,25 @@ RSpec.describe SearchHelper do
...
@@ -610,4 +610,25 @@ RSpec.describe SearchHelper do
end
end
end
end
end
end
describe
'#search_sort_options'
do
let
(
:user
)
{
create
(
:user
)
}
mock_created_sort
=
{
title:
_
(
'Created date'
),
sortable:
true
,
sortParam:
{
asc:
'created_asc'
,
desc:
'created_desc'
}
}
before
do
allow
(
self
).
to
receive
(
:current_user
).
and_return
(
user
)
end
it
'returns the correct data'
do
expect
(
search_sort_options
).
to
eq
([
mock_created_sort
])
end
end
end
end
spec/helpers/sorting_helper_spec.rb
View file @
db8993ab
...
@@ -50,24 +50,6 @@ RSpec.describe SortingHelper do
...
@@ -50,24 +50,6 @@ RSpec.describe SortingHelper do
end
end
end
end
describe
'#search_sort_direction_button'
do
before
do
set_sorting_url
'test_label'
end
it
'keeps label filter param'
do
expect
(
search_sort_direction_button
(
'created_asc'
)).
to
include
(
'label_name=test_label'
)
end
it
'returns icon with sort-lowest when sort is asc'
do
expect
(
search_sort_direction_button
(
'created_asc'
)).
to
include
(
'sort-lowest'
)
end
it
'returns icon with sort-highest when sort is desc'
do
expect
(
search_sort_direction_button
(
'created_desc'
)).
to
include
(
'sort-highest'
)
end
end
def
stub_controller_path
(
value
)
def
stub_controller_path
(
value
)
allow
(
helper
.
controller
).
to
receive
(
:controller_path
).
and_return
(
value
)
allow
(
helper
.
controller
).
to
receive
(
:controller_path
).
and_return
(
value
)
end
end
...
...
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