Commit 8c0768d3 authored by Tiffany Rea's avatar Tiffany Rea Committed by Sanad Liaquat

Use a separate user to avoid same namespace

parent 62d706c5
...@@ -38,6 +38,7 @@ module QA ...@@ -38,6 +38,7 @@ module QA
set_path(full_path, name) set_path(full_path, name)
import_project(full_path) import_project(full_path)
wait_for_success wait_for_success
go_to_project(name)
end end
private private
......
...@@ -5,14 +5,26 @@ require 'faker' ...@@ -5,14 +5,26 @@ require 'faker'
require 'base64' require 'base64'
module QA module QA
context 'Verify', :github, only: { subdomain: :staging } do context 'Verify', :github, :requires_admin, only: { subdomain: :staging }, quarantine: { issue: 'https://gitlab.com/gitlab-org/gitlab/-/issues/335045', type: :bug } do
include Support::Api include Support::Api
describe 'Pipeline for project mirrors Github' do describe 'Pipeline for project mirrors Github' do
let(:commit_message) { "Update #{github_data[:file_name]} - #{Time.now}" } let(:commit_message) { "Update #{github_data[:file_name]} - #{Time.now}" }
let(:project_name) { 'github-project-with-pipeline' } let(:project_name) { 'github-project-with-pipeline' }
let(:api_client) { Runtime::API::Client.new(:gitlab) }
let(:github_client) { Github::Client::Repos::Contents.new oauth_token: github_data[:access_token] } let(:github_client) { Github::Client::Repos::Contents.new oauth_token: github_data[:access_token] }
let(:admin_api_client) { Runtime::API::Client.as_admin }
let(:user_api_client) { Runtime::API::Client.new(:gitlab, user: user) }
let(:group) do
Resource::Group.fabricate_via_api!
end
let(:user) do
Resource::User.fabricate_via_api! do |resource|
resource.api_client = admin_api_client
resource.hard_delete_on_api_removal = true
end
end
let(:import_project) do let(:import_project) do
EE::Resource::ImportRepoWithCICD.fabricate_via_browser_ui! do |project| EE::Resource::ImportRepoWithCICD.fabricate_via_browser_ui! do |project|
...@@ -24,13 +36,21 @@ module QA ...@@ -24,13 +36,21 @@ module QA
end end
before do before do
Flow::Login.sign_in # Create both tokens before logging in the first time so that we don't need to log out in the middle of the test
admin_api_client.personal_access_token
user_api_client.personal_access_token
group.add_member(user, Resource::Members::AccessLevel::OWNER)
Flow::Login.sign_in(as: user)
group.visit!
import_project import_project
Page::Project::Menu.perform(&:click_ci_cd_pipelines) Page::Project::Menu.perform(&:click_ci_cd_pipelines)
end end
after do after do
remove_project remove_project
group.remove_via_api!
user.remove_via_api!
end end
it 'user commits to GitHub triggers CI pipeline', testcase: 'https://gitlab.com/gitlab-org/quality/testcases/-/issues/144' do it 'user commits to GitHub triggers CI pipeline', testcase: 'https://gitlab.com/gitlab-org/quality/testcases/-/issues/144' do
...@@ -57,6 +77,8 @@ module QA ...@@ -57,6 +77,8 @@ module QA
end end
def edit_github_file def edit_github_file
Runtime::Logger.info "Making changes to Github file."
file = github_client.get github_data[:repo_owner], github_data[:repo_name], github_data[:file_name] file = github_client.get github_data[:repo_owner], github_data[:repo_name], github_data[:file_name]
file_sha = file.body['sha'] file_sha = file.body['sha']
file_path = file.body['path'] file_path = file.body['path']
...@@ -73,17 +95,23 @@ module QA ...@@ -73,17 +95,23 @@ module QA
end end
def import_project_id def import_project_id
request = Runtime::API::Request.new(api_client, import_project.api_get_path) request = Runtime::API::Request.new(user_api_client, import_project.api_get_path)
JSON.parse(get(request.url))['id'] JSON.parse(get(request.url))['id']
end end
def trigger_project_mirror def trigger_project_mirror
request = Runtime::API::Request.new(api_client, "/projects/#{import_project_id}/mirror/pull") Runtime::Logger.info "Triggering pull mirror request."
post(request.url, nil)
request = Runtime::API::Request.new(user_api_client, "/projects/#{import_project_id}/mirror/pull")
Support::Retrier.retry_until(max_attempts: 6, sleep_interval: 10) do
response = post(request.url, nil)
Runtime::Logger.info "Mirror pull request response: #{response}"
response.code == Support::Api::HTTP_STATUS_OK
end
end end
def remove_project def remove_project
delete_project_request = Runtime::API::Request.new(api_client, "/projects/#{CGI.escape("#{Runtime::Namespace.path}/#{import_project.name}")}") delete_project_request = Runtime::API::Request.new(user_api_client, "/projects/#{CGI.escape("#{Runtime::Namespace.path}/#{import_project.name}")}")
delete delete_project_request.url delete delete_project_request.url
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