Commit c878b3d0 authored by Sanad Liaquat's avatar Sanad Liaquat

Merge branch 'qa-shl-cache-pats' into 'master'

Create and use PersonalAccessTokenCache

See merge request gitlab-org/gitlab!64492
parents 961497de 7ecb563e
...@@ -87,6 +87,7 @@ module QA ...@@ -87,6 +87,7 @@ module QA
autoload :CiVariable, 'qa/resource/ci_variable' autoload :CiVariable, 'qa/resource/ci_variable'
autoload :Runner, 'qa/resource/runner' autoload :Runner, 'qa/resource/runner'
autoload :PersonalAccessToken, 'qa/resource/personal_access_token' autoload :PersonalAccessToken, 'qa/resource/personal_access_token'
autoload :PersonalAccessTokenCache, 'qa/resource/personal_access_token_cache'
autoload :ProjectAccessToken, 'qa/resource/project_access_token' autoload :ProjectAccessToken, 'qa/resource/project_access_token'
autoload :User, 'qa/resource/user' autoload :User, 'qa/resource/user'
autoload :ProjectMilestone, 'qa/resource/project_milestone' autoload :ProjectMilestone, 'qa/resource/project_milestone'
......
...@@ -11,21 +11,25 @@ module QA ...@@ -11,21 +11,25 @@ module QA
# This *could* be different than the api_client.user or the api_user provided by the QA::Resource::ApiFabricator module # This *could* be different than the api_client.user or the api_user provided by the QA::Resource::ApiFabricator module
attr_writer :user attr_writer :user
attribute :token do attribute :token
Page::Profile::PersonalAccessTokens.perform(&:created_access_token)
end
# Only Admins can create PAT via the API. # Only Admins can create PAT via the API.
# If Runtime::Env.admin_personal_access_token is provided, fabricate via the API, # If Runtime::Env.admin_personal_access_token is provided, fabricate via the API,
# else, fabricate via the browser. # else, fabricate via the browser.
def fabricate_via_api! def fabricate_via_api!
if Runtime::Env.admin_personal_access_token && !@user.nil? @token = QA::Resource::PersonalAccessTokenCache.get_token_for_username(user.username)
self.api_client = Runtime::API::Client.as_admin return if @token
super resource = if Runtime::Env.admin_personal_access_token && !@user.nil?
else self.api_client = Runtime::API::Client.as_admin
fabricate!
end super
else
fabricate!
end
QA::Resource::PersonalAccessTokenCache.set_token_for_username(user.username, self.token)
resource
end end
# When a user is not provided, use default user # When a user is not provided, use default user
...@@ -66,6 +70,8 @@ module QA ...@@ -66,6 +70,8 @@ module QA
# Expire in 2 days just in case the token is created just before midnight # Expire in 2 days just in case the token is created just before midnight
token_page.fill_expiry_date(Time.now.utc.to_date + 2) token_page.fill_expiry_date(Time.now.utc.to_date + 2)
token_page.click_create_token_button token_page.click_create_token_button
self.token = Page::Profile::PersonalAccessTokens.perform(&:created_access_token)
end end
end end
end end
......
# frozen_string_literal: true
module QA
module Resource
class PersonalAccessTokenCache
@personal_access_tokens = {}
def self.get_token_for_username(username)
@personal_access_tokens[username]
end
def self.set_token_for_username(username, token)
@personal_access_tokens[username] = token
end
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment