diff options
| author | Achilleas Pipinellis <axil@gitlab.com> | 2018-03-08 12:04:34 +0100 | 
|---|---|---|
| committer | Achilleas Pipinellis <axil@gitlab.com> | 2018-03-08 14:22:59 +0100 | 
| commit | 471728f8fb7747638c24d918302d6bdcb6d152f2 (patch) | |
| tree | 737542f8a6bbd62395ff68d4385b6f9f8d39fc79 /scripts/trigger-build-docs | |
| parent | 95016507d49c3099afde0ef3909377bf70061dc3 (diff) | |
| download | gitlab-ce-471728f8fb7747638c24d918302d6bdcb6d152f2.tar.gz | |
Wait for the pipeline to start before canceling itdocs/trigger-script
Diffstat (limited to 'scripts/trigger-build-docs')
| -rwxr-xr-x | scripts/trigger-build-docs | 19 | 
1 files changed, 14 insertions, 5 deletions
| diff --git a/scripts/trigger-build-docs b/scripts/trigger-build-docs index ae8cac0cf02..c9aaba91aa0 100755 --- a/scripts/trigger-build-docs +++ b/scripts/trigger-build-docs @@ -24,8 +24,8 @@ def docs_branch    # The maximum string length a file can have on a filesystem (ext4)    # is 63 characters. Let's use something smaller to be 100% sure.    max = 42 -  # Prefix the remote branch with 'preview-' in order to avoid -  # name conflicts in the rare case the branch name already +  # Prefix the remote branch with the slug of the project in order +  # to avoid name conflicts in the rare case the branch name already    # exists in the docs repo and truncate to max length.    "#{slug}-#{ENV["CI_COMMIT_REF_SLUG"]}"[0...max]  end @@ -41,12 +41,21 @@ def create_remote_branch    Gitlab.create_branch(GITLAB_DOCS_REPO, docs_branch, 'master')    puts "=> Remote branch '#{docs_branch}' created" -  # Get the latest pipeline ID which is also the first -  pipeline_id = Gitlab.pipelines(GITLAB_DOCS_REPO, { ref: docs_branch }).last.id +  pipelines = nil + +  # Wait until the pipeline is started +  loop do +    sleep 1 +    puts "=> Waiting for pipeline to start..." +    pipelines = Gitlab.pipelines(GITLAB_DOCS_REPO, { ref: docs_branch }) +    break if pipelines.any? +  end + +  # Get the first pipeline ID which should be the only one for the branch +  pipeline_id = pipelines.first.id    # Cancel the pipeline    Gitlab.cancel_pipeline(GITLAB_DOCS_REPO, pipeline_id) -  puts "=> Canceled uneeded pipeline #{pipeline_id} for '#{docs_branch}'"  rescue Gitlab::Error::BadRequest    puts "=> Remote branch '#{docs_branch}' already exists"  end | 
