Merge branch 'bugfix/ci_handle_retried_jobs_v4.0' into 'release/v4.0'

ci: add find job id argument job status (backport v4.0)

See merge request espressif/esp-idf!7954
This commit is contained in:
Angus Gratton 2020-03-18 16:02:23 +08:00
commit 718af6ed07

View file

@ -96,12 +96,14 @@ class Gitlab(object):
return raw_data_list
def find_job_id(self, job_name, pipeline_id=None):
def find_job_id(self, job_name, pipeline_id=None, job_status="success"):
"""
Get Job ID from job name of specific pipeline
:param job_name: job name
:param pipeline_id: If None, will get pipeline id from CI pre-defined variable.
:param job_status: status of job. One pipeline could have multiple jobs with same name after retry.
job_status is used to filter these jobs.
:return: a list of job IDs (parallel job will generate multiple jobs)
"""
job_id_list = []
@ -112,7 +114,7 @@ class Gitlab(object):
for job in jobs:
match = self.JOB_NAME_PATTERN.match(job.name)
if match:
if match.group(1) == job_name:
if match.group(1) == job_name and job.status == job_status:
job_id_list.append({"id": job.id, "parallel_num": match.group(3)})
return job_id_list