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
0c404f9e
Commit
0c404f9e
authored
Apr 21, 2021
by
Tiger Watson
Committed by
Matthias Käppler
Apr 21, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Order cluster token by last used
parent
9d9b902a
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
61 additions
and
18 deletions
+61
-18
app/models/clusters/agent.rb
app/models/clusters/agent.rb
+1
-0
app/models/clusters/agent_token.rb
app/models/clusters/agent_token.rb
+3
-1
changelogs/unreleased/322128-token-order.yml
changelogs/unreleased/322128-token-order.yml
+5
-0
db/migrate/20210420012909_index_cluster_agent_tokens_on_last_used_at.rb
...10420012909_index_cluster_agent_tokens_on_last_used_at.rb
+20
-0
db/schema_migrations/20210420012909
db/schema_migrations/20210420012909
+1
-0
db/structure.sql
db/structure.sql
+1
-1
ee/app/graphql/resolvers/clusters/agent_tokens_resolver.rb
ee/app/graphql/resolvers/clusters/agent_tokens_resolver.rb
+1
-1
ee/app/graphql/resolvers/clusters/agents_resolver.rb
ee/app/graphql/resolvers/clusters/agents_resolver.rb
+1
-1
ee/spec/graphql/resolvers/clusters/agent_tokens_resolver_spec.rb
.../graphql/resolvers/clusters/agent_tokens_resolver_spec.rb
+4
-4
ee/spec/requests/api/graphql/project/cluster_agents_spec.rb
ee/spec/requests/api/graphql/project/cluster_agents_spec.rb
+10
-10
spec/models/clusters/agent_spec.rb
spec/models/clusters/agent_spec.rb
+1
-0
spec/models/clusters/agent_token_spec.rb
spec/models/clusters/agent_token_spec.rb
+13
-0
No files found.
app/models/clusters/agent.rb
View file @
0c404f9e
...
@@ -8,6 +8,7 @@ module Clusters
...
@@ -8,6 +8,7 @@ module Clusters
belongs_to
:project
,
class_name:
'::Project'
# Otherwise, it will load ::Clusters::Project
belongs_to
:project
,
class_name:
'::Project'
# Otherwise, it will load ::Clusters::Project
has_many
:agent_tokens
,
class_name:
'Clusters::AgentToken'
has_many
:agent_tokens
,
class_name:
'Clusters::AgentToken'
has_many
:last_used_agent_tokens
,
->
{
order_last_used_at_desc
},
class_name:
'Clusters::AgentToken'
,
inverse_of: :agent
scope
:ordered_by_name
,
->
{
order
(
:name
)
}
scope
:ordered_by_name
,
->
{
order
(
:name
)
}
scope
:with_name
,
->
(
name
)
{
where
(
name:
name
)
}
scope
:with_name
,
->
(
name
)
{
where
(
name:
name
)
}
...
...
app/models/clusters/agent_token.rb
View file @
0c404f9e
...
@@ -6,7 +6,7 @@ module Clusters
...
@@ -6,7 +6,7 @@ module Clusters
include
TokenAuthenticatable
include
TokenAuthenticatable
add_authentication_token_field
:token
,
encrypted: :required
,
token_generator:
->
{
Devise
.
friendly_token
(
50
)
}
add_authentication_token_field
:token
,
encrypted: :required
,
token_generator:
->
{
Devise
.
friendly_token
(
50
)
}
cached_attr_reader
:last_
contact
ed_at
cached_attr_reader
:last_
us
ed_at
self
.
table_name
=
'cluster_agent_tokens'
self
.
table_name
=
'cluster_agent_tokens'
...
@@ -21,6 +21,8 @@ module Clusters
...
@@ -21,6 +21,8 @@ module Clusters
validates
:description
,
length:
{
maximum:
1024
}
validates
:description
,
length:
{
maximum:
1024
}
validates
:name
,
presence:
true
,
length:
{
maximum:
255
}
validates
:name
,
presence:
true
,
length:
{
maximum:
255
}
scope
:order_last_used_at_desc
,
->
{
order
(
::
Gitlab
::
Database
.
nulls_last_order
(
'last_used_at'
,
'DESC'
))
}
def
track_usage
def
track_usage
track_values
=
{
last_used_at:
Time
.
current
.
utc
}
track_values
=
{
last_used_at:
Time
.
current
.
utc
}
...
...
changelogs/unreleased/322128-token-order.yml
0 → 100644
View file @
0c404f9e
---
title
:
Add ability to order cluster token by last used
merge_request
:
59716
author
:
type
:
changed
db/migrate/20210420012909_index_cluster_agent_tokens_on_last_used_at.rb
0 → 100644
View file @
0c404f9e
# frozen_string_literal: true
class
IndexClusterAgentTokensOnLastUsedAt
<
ActiveRecord
::
Migration
[
6.0
]
include
Gitlab
::
Database
::
MigrationHelpers
OLD_INDEX
=
'index_cluster_agent_tokens_on_agent_id'
NEW_INDEX
=
'index_cluster_agent_tokens_on_agent_id_and_last_used_at'
disable_ddl_transaction!
def
up
add_concurrent_index
:cluster_agent_tokens
,
'agent_id, last_used_at DESC NULLS LAST'
,
name:
NEW_INDEX
remove_concurrent_index_by_name
:cluster_agent_tokens
,
OLD_INDEX
end
def
down
add_concurrent_index
:cluster_agent_tokens
,
:agent_id
,
name:
OLD_INDEX
remove_concurrent_index_by_name
:cluster_agent_tokens
,
NEW_INDEX
end
end
db/schema_migrations/20210420012909
0 → 100644
View file @
0c404f9e
c9e8c49bf272ef49d906431bdc11a24abe967a9d7e95976d70c48b21b48a062b
\ No newline at end of file
db/structure.sql
View file @
0c404f9e
...
@@ -22324,7 +22324,7 @@ CREATE INDEX index_ci_variables_on_key ON ci_variables USING btree (key);
...
@@ -22324,7 +22324,7 @@ CREATE INDEX index_ci_variables_on_key ON ci_variables USING btree (key);
CREATE UNIQUE INDEX index_ci_variables_on_project_id_and_key_and_environment_scope ON ci_variables USING btree (project_id, key, environment_scope);
CREATE UNIQUE INDEX index_ci_variables_on_project_id_and_key_and_environment_scope ON ci_variables USING btree (project_id, key, environment_scope);
CREATE INDEX index_cluster_agent_tokens_on_agent_id
ON cluster_agent_tokens USING btree (agent_id
);
CREATE INDEX index_cluster_agent_tokens_on_agent_id
_and_last_used_at ON cluster_agent_tokens USING btree (agent_id, last_used_at DESC NULLS LAST
);
CREATE INDEX index_cluster_agent_tokens_on_created_by_user_id ON cluster_agent_tokens USING btree (created_by_user_id);
CREATE INDEX index_cluster_agent_tokens_on_created_by_user_id ON cluster_agent_tokens USING btree (created_by_user_id);
ee/app/graphql/resolvers/clusters/agent_tokens_resolver.rb
View file @
0c404f9e
...
@@ -12,7 +12,7 @@ module Resolvers
...
@@ -12,7 +12,7 @@ module Resolvers
def
resolve
(
**
args
)
def
resolve
(
**
args
)
return
::
Clusters
::
AgentToken
.
none
unless
can_read_agent_tokens?
return
::
Clusters
::
AgentToken
.
none
unless
can_read_agent_tokens?
agent
.
agent_tokens
agent
.
last_used_
agent_tokens
end
end
private
private
...
...
ee/app/graphql/resolvers/clusters/agents_resolver.rb
View file @
0c404f9e
...
@@ -28,7 +28,7 @@ module Resolvers
...
@@ -28,7 +28,7 @@ module Resolvers
private
private
def
preloads
def
preloads
{
tokens: :agent_tokens
}
{
tokens: :
last_used_
agent_tokens
}
end
end
end
end
end
end
...
...
ee/spec/graphql/resolvers/clusters/agent_tokens_resolver_spec.rb
View file @
0c404f9e
...
@@ -14,8 +14,8 @@ RSpec.describe Resolvers::Clusters::AgentTokensResolver do
...
@@ -14,8 +14,8 @@ RSpec.describe Resolvers::Clusters::AgentTokensResolver do
let
(
:feature_available
)
{
true
}
let
(
:feature_available
)
{
true
}
let
(
:ctx
)
{
Hash
(
current_user:
user
)
}
let
(
:ctx
)
{
Hash
(
current_user:
user
)
}
let!
(
:matching_token1
)
{
create
(
:cluster_agent_token
,
agent:
agent
)
}
let!
(
:matching_token1
)
{
create
(
:cluster_agent_token
,
agent:
agent
,
last_used_at:
5
.
days
.
ago
)
}
let!
(
:mat
hcing_token2
)
{
create
(
:cluster_agent_token
,
agent:
agent
)
}
let!
(
:mat
ching_token2
)
{
create
(
:cluster_agent_token
,
agent:
agent
,
last_used_at:
2
.
days
.
ago
)
}
let!
(
:other_token
)
{
create
(
:cluster_agent_token
)
}
let!
(
:other_token
)
{
create
(
:cluster_agent_token
)
}
subject
{
resolve
(
described_class
,
obj:
agent
,
ctx:
ctx
)
}
subject
{
resolve
(
described_class
,
obj:
agent
,
ctx:
ctx
)
}
...
@@ -24,8 +24,8 @@ RSpec.describe Resolvers::Clusters::AgentTokensResolver do
...
@@ -24,8 +24,8 @@ RSpec.describe Resolvers::Clusters::AgentTokensResolver do
stub_licensed_features
(
cluster_agents:
feature_available
)
stub_licensed_features
(
cluster_agents:
feature_available
)
end
end
it
'returns tokens associated with the agent'
do
it
'returns tokens associated with the agent
, ordered by last_used_at
'
do
expect
(
subject
).
to
contain_exactly
(
matching_token1
,
mathcing_token2
)
expect
(
subject
).
to
eq
([
matching_token2
,
matching_token1
]
)
end
end
context
'feature is not available'
do
context
'feature is not available'
do
...
...
ee/spec/requests/api/graphql/project/cluster_agents_spec.rb
View file @
0c404f9e
...
@@ -50,22 +50,22 @@ RSpec.describe 'Project.cluster_agents' do
...
@@ -50,22 +50,22 @@ RSpec.describe 'Project.cluster_agents' do
end
end
context
'selecting tokens'
do
context
'selecting tokens'
do
let
(
:cluster_agents_fields
)
{
[
:id
,
query_nodes
(
:tokens
,
of:
'ClusterAgentToken'
)]
}
let_it_be
(
:token_1
)
{
create
(
:cluster_agent_token
,
agent:
agents
.
first
)
}
let_it_be
(
:token_2
)
{
create
(
:cluster_agent_token
,
agent:
agents
.
second
)
}
let_it_be
(
:token_3
)
{
create
(
:cluster_agent_token
,
agent:
agents
.
second
,
last_used_at:
2
.
days
.
ago
)
}
before
do
let
(
:cluster_agents_fields
)
{
[
:id
,
query_nodes
(
:tokens
,
of:
'ClusterAgentToken'
)]
}
create
(
:cluster_agent_token
,
agent:
agents
.
first
)
create
(
:cluster_agent_token
,
agent:
agents
.
second
)
end
it
'can select tokens'
do
it
'can select tokens
in last_used_at order
'
do
post_graphql
(
query
,
current_user:
current_user
)
post_graphql
(
query
,
current_user:
current_user
)
tokens
=
graphql_data_at
(
:project
,
:cluster_agents
,
:nodes
,
:tokens
,
:nodes
)
tokens
=
graphql_data_at
(
:project
,
:cluster_agents
,
:nodes
,
:tokens
,
:nodes
)
expect
(
tokens
).
to
contain_exactly
(
expect
(
tokens
).
to
match
([
a_hash_including
(
'id'
=>
be_present
),
a_hash_including
(
'id'
=>
global_id_of
(
token_1
)),
a_hash_including
(
'id'
=>
be_present
)
a_hash_including
(
'id'
=>
global_id_of
(
token_3
)),
)
a_hash_including
(
'id'
=>
global_id_of
(
token_2
))
])
end
end
it
'does not suffer from N+1 performance issues'
do
it
'does not suffer from N+1 performance issues'
do
...
...
spec/models/clusters/agent_spec.rb
View file @
0c404f9e
...
@@ -8,6 +8,7 @@ RSpec.describe Clusters::Agent do
...
@@ -8,6 +8,7 @@ RSpec.describe Clusters::Agent do
it
{
is_expected
.
to
belong_to
(
:created_by_user
).
class_name
(
'User'
).
optional
}
it
{
is_expected
.
to
belong_to
(
:created_by_user
).
class_name
(
'User'
).
optional
}
it
{
is_expected
.
to
belong_to
(
:project
).
class_name
(
'::Project'
)
}
it
{
is_expected
.
to
belong_to
(
:project
).
class_name
(
'::Project'
)
}
it
{
is_expected
.
to
have_many
(
:agent_tokens
).
class_name
(
'Clusters::AgentToken'
)
}
it
{
is_expected
.
to
have_many
(
:agent_tokens
).
class_name
(
'Clusters::AgentToken'
)
}
it
{
is_expected
.
to
have_many
(
:last_used_agent_tokens
).
class_name
(
'Clusters::AgentToken'
)
}
it
{
is_expected
.
to
validate_presence_of
(
:name
)
}
it
{
is_expected
.
to
validate_presence_of
(
:name
)
}
it
{
is_expected
.
to
validate_length_of
(
:name
).
is_at_most
(
63
)
}
it
{
is_expected
.
to
validate_length_of
(
:name
).
is_at_most
(
63
)
}
...
...
spec/models/clusters/agent_token_spec.rb
View file @
0c404f9e
...
@@ -9,6 +9,19 @@ RSpec.describe Clusters::AgentToken do
...
@@ -9,6 +9,19 @@ RSpec.describe Clusters::AgentToken do
it
{
is_expected
.
to
validate_length_of
(
:name
).
is_at_most
(
255
)
}
it
{
is_expected
.
to
validate_length_of
(
:name
).
is_at_most
(
255
)
}
it
{
is_expected
.
to
validate_presence_of
(
:name
)
}
it
{
is_expected
.
to
validate_presence_of
(
:name
)
}
describe
'scopes'
do
describe
'.order_last_used_at_desc'
do
let_it_be
(
:token_1
)
{
create
(
:cluster_agent_token
,
last_used_at:
7
.
days
.
ago
)
}
let_it_be
(
:token_2
)
{
create
(
:cluster_agent_token
,
last_used_at:
nil
)
}
let_it_be
(
:token_3
)
{
create
(
:cluster_agent_token
,
last_used_at:
2
.
days
.
ago
)
}
it
'sorts by last_used_at descending, with null values at last'
do
expect
(
described_class
.
order_last_used_at_desc
)
.
to
eq
([
token_3
,
token_1
,
token_2
])
end
end
end
describe
'#token'
do
describe
'#token'
do
it
'is generated on save'
do
it
'is generated on save'
do
agent_token
=
build
(
:cluster_agent_token
,
token_encrypted:
nil
)
agent_token
=
build
(
:cluster_agent_token
,
token_encrypted:
nil
)
...
...
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