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
0
Merge Requests
0
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
Léo-Paul Géneau
gitlab-ce
Commits
0fad7aa7
Commit
0fad7aa7
authored
Jun 13, 2018
by
Alexis Reigel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add tag filter to admin runners page
parent
d3accd36
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
152 additions
and
1 deletion
+152
-1
app/assets/javascripts/filtered_search/admin_runners_filtered_search_token_keys.js
...ltered_search/admin_runners_filtered_search_token_keys.js
+8
-0
app/assets/javascripts/filtered_search/filtered_search_dropdown_manager.js
...ripts/filtered_search/filtered_search_dropdown_manager.js
+13
-0
app/controllers/admin/runners_controller.rb
app/controllers/admin/runners_controller.rb
+5
-1
app/finders/admin/runners_finder.rb
app/finders/admin/runners_finder.rb
+9
-0
app/services/autocomplete_tags_service.rb
app/services/autocomplete_tags_service.rb
+17
-0
app/views/admin/runners/index.html.haml
app/views/admin/runners/index.html.haml
+18
-0
config/routes/admin.rb
config/routes/admin.rb
+4
-0
locale/gitlab.pot
locale/gitlab.pot
+3
-0
spec/features/admin/admin_runners_spec.rb
spec/features/admin/admin_runners_spec.rb
+50
-0
spec/finders/admin/runners_finder_spec.rb
spec/finders/admin/runners_finder_spec.rb
+8
-0
spec/services/autocomplete_tags_service_spec.rb
spec/services/autocomplete_tags_service_spec.rb
+17
-0
No files found.
app/assets/javascripts/filtered_search/admin_runners_filtered_search_token_keys.js
View file @
0fad7aa7
...
@@ -17,6 +17,14 @@ const tokenKeys = [
...
@@ -17,6 +17,14 @@ const tokenKeys = [
icon
:
'
cube
'
,
icon
:
'
cube
'
,
tag
:
'
type
'
,
tag
:
'
type
'
,
},
},
{
key
:
'
tag
'
,
type
:
'
array
'
,
param
:
'
name[]
'
,
symbol
:
'
~
'
,
icon
:
'
tag
'
,
tag
:
'
~tag
'
,
},
];
];
const
AdminRunnersFilteredSearchTokenKeys
=
new
FilteredSearchTokenKeys
(
tokenKeys
);
const
AdminRunnersFilteredSearchTokenKeys
=
new
FilteredSearchTokenKeys
(
tokenKeys
);
...
...
app/assets/javascripts/filtered_search/filtered_search_dropdown_manager.js
View file @
0fad7aa7
...
@@ -111,6 +111,15 @@ export default class FilteredSearchDropdownManager {
...
@@ -111,6 +111,15 @@ export default class FilteredSearchDropdownManager {
gl
:
NullDropdown
,
gl
:
NullDropdown
,
element
:
this
.
container
.
querySelector
(
'
#js-dropdown-admin-runner-type
'
),
element
:
this
.
container
.
querySelector
(
'
#js-dropdown-admin-runner-type
'
),
},
},
tag
:
{
reference
:
null
,
gl
:
DropdownNonUser
,
extraArguments
:
{
endpoint
:
this
.
getRunnerTagsEndpoint
(),
symbol
:
'
~
'
,
},
element
:
this
.
container
.
querySelector
(
'
#js-dropdown-runner-tag
'
),
},
};
};
supportedTokens
.
forEach
(
type
=>
{
supportedTokens
.
forEach
(
type
=>
{
...
@@ -146,6 +155,10 @@ export default class FilteredSearchDropdownManager {
...
@@ -146,6 +155,10 @@ export default class FilteredSearchDropdownManager {
return
endpoint
;
return
endpoint
;
}
}
getRunnerTagsEndpoint
()
{
return
`
${
this
.
baseEndpoint
}
/admin/runners/tag_list.json`
;
}
static
addWordToInput
(
tokenName
,
tokenValue
=
''
,
clicked
=
false
,
options
=
{})
{
static
addWordToInput
(
tokenName
,
tokenValue
=
''
,
clicked
=
false
,
options
=
{})
{
const
{
uppercaseTokenName
=
false
,
capitalizeTokenValue
=
false
}
=
options
;
const
{
uppercaseTokenName
=
false
,
capitalizeTokenValue
=
false
}
=
options
;
const
input
=
FilteredSearchContainer
.
container
.
querySelector
(
'
.filtered-search
'
);
const
input
=
FilteredSearchContainer
.
container
.
querySelector
(
'
.filtered-search
'
);
...
...
app/controllers/admin/runners_controller.rb
View file @
0fad7aa7
# frozen_string_literal: true
# frozen_string_literal: true
class
Admin::RunnersController
<
Admin
::
ApplicationController
class
Admin::RunnersController
<
Admin
::
ApplicationController
before_action
:runner
,
except:
:index
before_action
:runner
,
except:
[
:index
,
:tag_list
]
def
index
def
index
finder
=
Admin
::
RunnersFinder
.
new
(
params:
params
)
finder
=
Admin
::
RunnersFinder
.
new
(
params:
params
)
...
@@ -48,6 +48,10 @@ class Admin::RunnersController < Admin::ApplicationController
...
@@ -48,6 +48,10 @@ class Admin::RunnersController < Admin::ApplicationController
end
end
end
end
def
tag_list
render
json:
AutocompleteTagsService
.
new
(
Ci
::
Runner
).
run
end
private
private
def
runner
def
runner
...
...
app/finders/admin/runners_finder.rb
View file @
0fad7aa7
...
@@ -11,6 +11,7 @@ class Admin::RunnersFinder < UnionFinder
...
@@ -11,6 +11,7 @@ class Admin::RunnersFinder < UnionFinder
search!
search!
filter_by_status!
filter_by_status!
filter_by_runner_type!
filter_by_runner_type!
filter_by_tag_list!
sort!
sort!
paginate!
paginate!
...
@@ -44,6 +45,14 @@ class Admin::RunnersFinder < UnionFinder
...
@@ -44,6 +45,14 @@ class Admin::RunnersFinder < UnionFinder
filter_by!
(
:type_type
,
Ci
::
Runner
::
AVAILABLE_TYPES
)
filter_by!
(
:type_type
,
Ci
::
Runner
::
AVAILABLE_TYPES
)
end
end
def
filter_by_tag_list!
tag_list
=
@params
[
:tag_name
].
presence
if
tag_list
@runners
=
@runners
.
tagged_with
(
tag_list
)
end
end
def
sort!
def
sort!
@runners
=
@runners
.
order_by
(
sort_key
)
@runners
=
@runners
.
order_by
(
sort_key
)
end
end
...
...
app/services/autocomplete_tags_service.rb
0 → 100644
View file @
0fad7aa7
# frozen_string_literal: true
class
AutocompleteTagsService
def
initialize
(
taggable_type
)
@taggable_type
=
taggable_type
end
# rubocop: disable CodeReuse/ActiveRecord
def
run
@taggable_type
.
all_tags
.
pluck
(
:id
,
:name
).
map
do
|
id
,
name
|
{
id:
id
,
title:
name
}
end
end
# rubocop: enable CodeReuse/ActiveRecord
end
app/views/admin/runners/index.html.haml
View file @
0fad7aa7
...
@@ -92,6 +92,24 @@
...
@@ -92,6 +92,24 @@
=
button_tag
class:
%w[btn btn-link]
do
=
button_tag
class:
%w[btn btn-link]
do
=
runner_type
.
titleize
=
runner_type
.
titleize
#js-dropdown-admin-runner-type
.filtered-search-input-dropdown-menu.dropdown-menu
%ul
{
data:
{
dropdown:
true
}
}
-
Ci
::
Runner
::
AVAILABLE_TYPES
.
each
do
|
runner_type
|
%li
.filter-dropdown-item
{
data:
{
value:
runner_type
}
}
=
button_tag
class:
%w[btn btn-link]
do
=
runner_type
.
titleize
#js-dropdown-runner-tag
.filtered-search-input-dropdown-menu.dropdown-menu
%ul
{
data:
{
dropdown:
true
}
}
%li
.filter-dropdown-item
{
data:
{
value:
'none'
}
}
%button
.btn.btn-link
=
_
(
'No Tag'
)
%li
.divider.droplab-item-ignore
%ul
.filter-dropdown
{
data:
{
dynamic:
true
,
dropdown:
true
}
}
%li
.filter-dropdown-item
%button
.btn.btn-link.js-data-value
{{title}}
=
button_tag
class:
%w[clear-search hidden]
do
=
button_tag
class:
%w[clear-search hidden]
do
=
icon
(
'times'
)
=
icon
(
'times'
)
.filter-dropdown-container
.filter-dropdown-container
...
...
config/routes/admin.rb
View file @
0fad7aa7
...
@@ -120,6 +120,10 @@ namespace :admin do
...
@@ -120,6 +120,10 @@ namespace :admin do
get
:resume
get
:resume
get
:pause
get
:pause
end
end
collection
do
get
:tag_list
,
format: :json
end
end
end
resources
:jobs
,
only: :index
do
resources
:jobs
,
only: :index
do
...
...
locale/gitlab.pot
View file @
0fad7aa7
...
@@ -4943,6 +4943,9 @@ msgstr ""
...
@@ -4943,6 +4943,9 @@ msgstr ""
msgid "No %{providerTitle} repositories available to import"
msgid "No %{providerTitle} repositories available to import"
msgstr ""
msgstr ""
msgid "No Tag"
msgstr ""
msgid "No activities found"
msgid "No activities found"
msgstr ""
msgstr ""
...
...
spec/features/admin/admin_runners_spec.rb
View file @
0fad7aa7
...
@@ -141,6 +141,56 @@ describe "Admin Runners" do
...
@@ -141,6 +141,56 @@ describe "Admin Runners" do
end
end
end
end
describe
'filter by tag'
,
:js
do
it
'shows correct runner when tag matches'
do
create
:ci_runner
,
description:
'runner-blue'
,
tag_list:
[
'blue'
]
create
:ci_runner
,
description:
'runner-red'
,
tag_list:
[
'red'
]
visit
admin_runners_path
expect
(
page
).
to
have_content
'runner-blue'
expect
(
page
).
to
have_content
'runner-red'
input_filtered_search_keys
(
'tag:blue'
)
expect
(
page
).
to
have_content
'runner-blue'
expect
(
page
).
not_to
have_content
'runner-red'
end
it
'shows no runner when tag does not match'
do
create
:ci_runner
,
description:
'runner-blue'
,
tag_list:
[
'blue'
]
create
:ci_runner
,
description:
'runner-red'
,
tag_list:
[
'blue'
]
visit
admin_runners_path
input_filtered_search_keys
(
'tag:red'
)
expect
(
page
).
not_to
have_content
'runner-blue'
expect
(
page
).
not_to
have_content
'runner-blue'
expect
(
page
).
to
have_text
'No runners found'
end
it
'shows correct runner when tag is selected and search term is entered'
do
create
:ci_runner
,
description:
'runner-a-1'
,
tag_list:
[
'blue'
]
create
:ci_runner
,
description:
'runner-a-2'
,
tag_list:
[
'red'
]
create
:ci_runner
,
description:
'runner-b-1'
,
tag_list:
[
'blue'
]
visit
admin_runners_path
input_filtered_search_keys
(
'tag:blue'
)
expect
(
page
).
to
have_content
'runner-a-1'
expect
(
page
).
to
have_content
'runner-b-1'
expect
(
page
).
not_to
have_content
'runner-a-2'
input_filtered_search_keys
(
'tag:blue runner-a'
)
expect
(
page
).
to
have_content
'runner-a-1'
expect
(
page
).
not_to
have_content
'runner-b-1'
expect
(
page
).
not_to
have_content
'runner-a-2'
end
end
it
'sorts by last contact date'
,
:js
do
it
'sorts by last contact date'
,
:js
do
create
(
:ci_runner
,
description:
'runner-1'
,
created_at:
'2018-07-12 15:37'
,
contacted_at:
'2018-07-12 15:37'
)
create
(
:ci_runner
,
description:
'runner-1'
,
created_at:
'2018-07-12 15:37'
,
contacted_at:
'2018-07-12 15:37'
)
create
(
:ci_runner
,
description:
'runner-2'
,
created_at:
'2018-07-12 16:37'
,
contacted_at:
'2018-07-12 16:37'
)
create
(
:ci_runner
,
description:
'runner-2'
,
created_at:
'2018-07-12 16:37'
,
contacted_at:
'2018-07-12 16:37'
)
...
...
spec/finders/admin/runners_finder_spec.rb
View file @
0fad7aa7
...
@@ -37,6 +37,14 @@ describe Admin::RunnersFinder do
...
@@ -37,6 +37,14 @@ describe Admin::RunnersFinder do
end
end
end
end
context
'filter by tag_name'
do
it
'calls the corresponding scope on Ci::Runner'
do
expect
(
Ci
::
Runner
).
to
receive
(
:tagged_with
).
with
(
%w[tag1 tag2]
).
and_call_original
described_class
.
new
(
params:
{
tag_name:
%w[tag1 tag2]
}).
execute
end
end
context
'sort'
do
context
'sort'
do
context
'without sort param'
do
context
'without sort param'
do
it
'sorts by created_at'
do
it
'sorts by created_at'
do
...
...
spec/services/autocomplete_tags_service_spec.rb
0 → 100644
View file @
0fad7aa7
require
'rails_helper'
RSpec
.
describe
AutocompleteTagsService
do
describe
'#run'
do
it
'returns a hash of all tags'
do
create
(
:ci_runner
,
tag_list:
%w[tag1 tag2]
)
create
(
:ci_runner
,
tag_list:
%w[tag1 tag3]
)
create
(
:project
,
tag_list:
%w[tag4]
)
expect
(
described_class
.
new
(
Ci
::
Runner
).
run
).
to
match_array
[
{
id:
kind_of
(
Integer
),
title:
'tag1'
},
{
id:
kind_of
(
Integer
),
title:
'tag2'
},
{
id:
kind_of
(
Integer
),
title:
'tag3'
}
]
end
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