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
7c4f1e53
Commit
7c4f1e53
authored
Feb 18, 2022
by
Mark Lapierre
Committed by
Ramya Authappan
Feb 18, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add delete test users tool
parent
fc1c1aaa
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
87 additions
and
0 deletions
+87
-0
qa/Rakefile
qa/Rakefile
+5
-0
qa/qa/tools/delete_test_users.rb
qa/qa/tools/delete_test_users.rb
+82
-0
No files found.
qa/Rakefile
View file @
7c4f1e53
...
...
@@ -64,4 +64,9 @@ desc "Deletes resources created during E2E test runs"
task
:delete_test_resources
,
:file_pattern
do
|
t
,
args
|
QA
::
Tools
::
DeleteTestResources
.
new
(
args
[
:file_pattern
]).
run
end
desc
"Deletes test users"
task
:delete_test_users
,
[
:delete_before
,
:dry_run
,
:exclude_users
]
do
|
t
,
args
|
QA
::
Tools
::
DeleteTestUsers
.
new
(
args
).
run
end
# rubocop:enable Rails/RakeEnvironment
qa/qa/tools/delete_test_users.rb
0 → 100644
View file @
7c4f1e53
# frozen_string_literal: true
# This script deletes users with a username starting with "qa-user-"
# - Specify `delete_before` to delete only keys that were created before the given date (default: yesterday)
# - If `dry_run` is true the script will list the users to be deleted by username, but it won't delete them
# - Specify `exclude_users` as a comma-separated list of usernames to not delete.
#
# Required environment variables: GITLAB_QA_ACCESS_TOKEN and GITLAB_ADDRESS
# - GITLAB_QA_ACCESS_TOKEN must have admin API access
module
QA
module
Tools
class
DeleteTestUsers
include
Support
::
API
ITEMS_PER_PAGE
=
'100'
EXCLUDE_USERS
=
%w[qa-user-abc123]
.
freeze
FALSY_VALUES
=
%w[false no 0]
.
freeze
def
initialize
(
delete_before:
(
Date
.
today
-
1
).
to_s
,
dry_run:
'false'
,
exclude_users:
nil
)
raise
ArgumentError
,
"Please provide GITLAB_ADDRESS"
unless
ENV
[
'GITLAB_ADDRESS'
]
raise
ArgumentError
,
"Please provide GITLAB_QA_ACCESS_TOKEN"
unless
ENV
[
'GITLAB_QA_ACCESS_TOKEN'
]
@api_client
=
Runtime
::
API
::
Client
.
new
(
ENV
[
'GITLAB_ADDRESS'
],
personal_access_token:
ENV
[
'GITLAB_QA_ACCESS_TOKEN'
])
@dry_run
=
!
FALSY_VALUES
.
include?
(
dry_run
.
to_s
.
downcase
)
@delete_before
=
Date
.
parse
(
delete_before
)
@page_no
=
'1'
@exclude_users
=
Array
(
exclude_users
.
to_s
.
split
(
','
))
+
EXCLUDE_USERS
end
def
run
puts
"Deleting users with a username starting with 'qa-user-' created before
#{
@delete_before
}
..."
while
page_no
.
present?
users
=
fetch_test_users
delete_test_users
(
users
)
if
users
.
present?
end
puts
"
\n
Done"
end
private
attr_reader
:dry_run
,
:page_no
alias_method
:dry_run?
,
:dry_run
def
fetch_test_users
puts
"Fetching QA test users from page
#{
page_no
}
..."
response
=
get
Runtime
::
API
::
Request
.
new
(
@api_client
,
"/users"
,
page:
page_no
,
per_page:
ITEMS_PER_PAGE
).
url
# When we reach the last page, the x-next-page header is a blank string
@page_no
=
response
.
headers
[
:x_next_page
].
to_s
JSON
.
parse
(
response
.
body
).
select
do
|
user
|
user
[
'username'
].
start_with?
(
'qa-user-'
,
'test-user-'
)
\
&&
(
user
[
'name'
]
==
'QA Tests'
||
user
[
'name'
].
start_with?
(
'QA User'
))
\
&&
!
@exclude_users
.
include?
(
user
[
'username'
])
\
&&
Date
.
parse
(
user
.
fetch
(
'created_at'
,
Date
.
today
.
to_s
))
<
@delete_before
end
end
def
delete_test_users
(
users
)
usernames
=
users
.
map
{
|
user
|
user
[
'username'
]
}.
join
(
', '
)
if
dry_run?
puts
"Dry run: found users with usernames
#{
usernames
}
"
return
end
puts
"Deleting
#{
users
.
length
}
users with usernames
#{
usernames
}
..."
users
.
each
do
|
user
|
delete_response
=
delete
Runtime
::
API
::
Request
.
new
(
@api_client
,
"/users/
#{
user
[
'id'
]
}
"
,
hard_delete:
'true'
).
url
dot_or_f
=
delete_response
.
code
==
204
?
"
\e
[32m.
\e
[0m"
:
"
\e
[31mF
\e
[0m"
print
dot_or_f
end
print
"
\n
"
end
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