BigW Consortium Gitlab

trigger-build-docs 2.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12
#!/usr/bin/env ruby

require 'gitlab'

#
# Configure credentials to be used with gitlab gem
#
Gitlab.configure do |config|
  config.endpoint       = 'https://gitlab.com/api/v4'
  config.private_token  = ENV["DOCS_API_TOKEN"]  # GitLab Docs bot access token which has only Developer access to gitlab-docs
end

13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
#
# The remote docs project
#
GITLAB_DOCS_REPO = 'gitlab-com/gitlab-docs'.freeze

#
# Truncate the remote docs branch name if it's more than 63 characters
# otherwise we hit the filesystem limit and the directory name where
# NGINX serves the site won't match the branch name.
#
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
  # exists in the docs repo and truncate to max length.
  "preview-#{ENV["CI_COMMIT_REF_SLUG"]}"[0...max]
end

33 34 35
#
# Dummy way to find out in which repo we are, CE or EE
#
36 37
def ee?
  File.exist?('CHANGELOG-EE.md')
38 39 40 41 42 43
end

#
# Create a remote branch in gitlab-docs
#
def create_remote_branch
44 45
  Gitlab.create_branch(GITLAB_DOCS_REPO, docs_branch, 'master')
  puts "Remote branch '#{docs_branch}' created"
46
rescue Gitlab::Error::BadRequest
47
  puts "Remote branch '#{docs_branch}' already exists"
48 49 50 51 52 53
end

#
# Remove a remote branch in gitlab-docs
#
def remove_remote_branch
54 55
  Gitlab.delete_branch(GITLAB_DOCS_REPO, docs_branch)
  puts "Remote branch '#{docs_branch}' deleted"
56 57 58 59 60 61 62
end

#
# Trigger a pipeline in gitlab-docs
#
def trigger_pipeline
  # Overriding vars in https://gitlab.com/gitlab-com/gitlab-docs/blob/master/.gitlab-ci.yml
63
  param_name = ee? ? 'BRANCH_EE' : 'BRANCH_CE'
64 65

  # The review app URL
66
  app_url = "http://#{docs_branch}.#{ENV["DOCS_REVIEW_APPS_DOMAIN"]}/#{ee? ? 'ee' : 'ce'}"
67 68 69

  # Create the pipeline
  puts "=> Triggering a pipeline..."
70
  pipeline = Gitlab.run_trigger(GITLAB_DOCS_REPO, ENV["CI_JOB_TOKEN"], docs_branch, { param_name => ENV["CI_COMMIT_REF_NAME"] })
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92

  puts "=> Pipeline created:"
  puts ""
  puts "https://gitlab.com/gitlab-com/gitlab-docs/pipelines/#{pipeline.id}"
  puts ""
  puts "=> Preview your changes live at:"
  puts ""
  puts app_url
  puts ""
end

#
# When the first argument is deploy then create the branch and trigger pipeline
# When it is 'stop', it deleted the remote branch. That way, we ensure there
# are no stale remote branches and the Review server doesn't fill.
#
case ARGV[0]
when 'deploy'
  create_remote_branch
  trigger_pipeline
when 'cleanup'
  remove_remote_branch
93 94 95 96
else
  puts "Please provide a valid option:
  deploy  - Creates the remote branch and triggers a pipeline
  cleanup - Deletes the remote branch and stops the Review App"
97
end