f1479b56b7
In 8278b763d9
the default behaviour of annotation
has changes, which was causing a lot of noise in diffs. We decided in #17382
that it is better to get rid of the whole annotate gem, and instead let people
look at schema.rb for the columns in a table.
Fixes: #17382
65 lines
1.4 KiB
Ruby
65 lines
1.4 KiB
Ruby
# Base class for CI services
|
|
# List methods you need to implement to get your CI service
|
|
# working with GitLab Merge Requests
|
|
class CiService < Service
|
|
default_value_for :category, 'ci'
|
|
|
|
def valid_token?(token)
|
|
self.respond_to?(:token) && self.token.present? && ActiveSupport::SecurityUtils.variable_size_secure_compare(token, self.token)
|
|
end
|
|
|
|
def supported_events
|
|
%w(push)
|
|
end
|
|
|
|
def merge_request_page(iid, sha, ref)
|
|
commit_page(sha, ref)
|
|
end
|
|
|
|
def commit_page(sha, ref)
|
|
build_page(sha, ref)
|
|
end
|
|
|
|
# Return complete url to merge_request page
|
|
#
|
|
# Ex.
|
|
# http://jenkins.example.com:8888/job/test1/scm/bySHA1/12d65c
|
|
#
|
|
def build_page(sha, ref)
|
|
# implement inside child
|
|
end
|
|
|
|
# Return string with build status or :error symbol
|
|
#
|
|
# Allowed states: 'success', 'failed', 'running', 'pending', 'skipped'
|
|
#
|
|
#
|
|
# Ex.
|
|
# @service.merge_request_status(9, '13be4ac', 'dev')
|
|
# # => 'success'
|
|
#
|
|
# @service.merge_request_status(10, '2abe4ac', 'dev)
|
|
# # => 'running'
|
|
#
|
|
#
|
|
def merge_request_status(iid, sha, ref)
|
|
commit_status(sha, ref)
|
|
end
|
|
|
|
# Return string with build status or :error symbol
|
|
#
|
|
# Allowed states: 'success', 'failed', 'running', 'pending', 'skipped'
|
|
#
|
|
#
|
|
# Ex.
|
|
# @service.commit_status('13be4ac', 'master')
|
|
# # => 'success'
|
|
#
|
|
# @service.commit_status('2abe4ac', 'dev')
|
|
# # => 'running'
|
|
#
|
|
#
|
|
def commit_status(sha, ref)
|
|
# implement inside child
|
|
end
|
|
end
|