diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-03-31 19:27:02 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-03-31 19:27:02 +0000 |
commit | 44d033747da39826bcf6e50adc26e7130159f90b (patch) | |
tree | 9557e682489fc8f776bccb70618927d533edc184 /scripts/api/get_package_and_test_job.rb | |
parent | a47a6d6fd56f92497b164d45ff9b53023202c4b1 (diff) | |
download | gitlab-ce-44d033747da39826bcf6e50adc26e7130159f90b.tar.gz |
Add latest changes from gitlab-org/gitlab@15-10-stable-ee
Diffstat (limited to 'scripts/api/get_package_and_test_job.rb')
-rw-r--r-- | scripts/api/get_package_and_test_job.rb | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/scripts/api/get_package_and_test_job.rb b/scripts/api/get_package_and_test_job.rb new file mode 100644 index 00000000000..dbc29f754d0 --- /dev/null +++ b/scripts/api/get_package_and_test_job.rb @@ -0,0 +1,39 @@ +# frozen_string_literal: true + +require 'gitlab' + +require_relative 'default_options' + +class GetPackageAndTestJob + def initialize(options) + @project = options.fetch(:project) + @pipeline_id = options.fetch(:pipeline_id) + + # If api_token is nil, it's set to '' to allow unauthenticated requests (for forks). + api_token = options.fetch(:api_token, '') + + warn "No API token given." if api_token.empty? + + @client = Gitlab.client( + endpoint: options.fetch(:endpoint) || API::DEFAULT_OPTIONS[:endpoint], + private_token: api_token + ) + end + + def execute + package_and_test_job = nil + + client.pipeline_bridges(project, pipeline_id, scope: 'failed', per_page: 100).auto_paginate do |job| + if job['name'].include?('package-and-test') + package_and_test_job = job + break + end + end + + package_and_test_job + end + + private + + attr_reader :project, :pipeline_id, :exclude_allowed_to_fail_jobs, :client +end |