debian-mirror-gitlab/app/models/project_services/bamboo_service.rb

154 lines
3.8 KiB
Ruby
Raw Normal View History

2018-11-20 20:47:30 +05:30
# frozen_string_literal: true
2015-04-26 12:48:37 +05:30
class BambooService < CiService
2017-08-17 22:00:37 +05:30
include ReactiveService
2015-04-26 12:48:37 +05:30
prop_accessor :bamboo_url, :build_key, :username, :password
2018-11-08 19:23:39 +05:30
validates :bamboo_url, presence: true, public_url: true, if: :activated?
2015-04-26 12:48:37 +05:30
validates :build_key, presence: true, if: :activated?
validates :username,
presence: true,
2015-12-23 02:04:40 +05:30
if: ->(service) { service.activated? && service.password }
2015-04-26 12:48:37 +05:30
validates :password,
presence: true,
2015-12-23 02:04:40 +05:30
if: ->(service) { service.activated? && service.username }
2015-04-26 12:48:37 +05:30
attr_accessor :response
after_save :compose_service_hook, if: :activated?
2015-10-24 18:46:33 +05:30
before_update :reset_password
2015-04-26 12:48:37 +05:30
def compose_service_hook
hook = service_hook || build_service_hook
hook.save
end
2015-10-24 18:46:33 +05:30
def reset_password
if bamboo_url_changed? && !password_touched?
self.password = nil
end
end
2015-04-26 12:48:37 +05:30
def title
'Atlassian Bamboo CI'
end
def description
'A continuous integration and build server'
end
def help
'You must set up automatic revision labeling and a repository trigger in Bamboo.'
end
2017-08-17 22:00:37 +05:30
def self.to_param
2015-04-26 12:48:37 +05:30
'bamboo'
end
def fields
[
{ type: 'text', name: 'bamboo_url',
2017-09-10 17:25:29 +05:30
placeholder: 'Bamboo root URL like https://bamboo.example.com', required: true },
2015-04-26 12:48:37 +05:30
{ type: 'text', name: 'build_key',
2017-09-10 17:25:29 +05:30
placeholder: 'Bamboo build plan key like KEY', required: true },
2015-04-26 12:48:37 +05:30
{ type: 'text', name: 'username',
placeholder: 'A user with API access, if applicable' },
2017-09-10 17:25:29 +05:30
{ type: 'password', name: 'password' }
2015-04-26 12:48:37 +05:30
]
end
2017-08-17 22:00:37 +05:30
def build_page(sha, ref)
with_reactive_cache(sha, ref) {|cached| cached[:build_page] }
2015-04-26 12:48:37 +05:30
end
2015-12-23 02:04:40 +05:30
2017-08-17 22:00:37 +05:30
def commit_status(sha, ref)
with_reactive_cache(sha, ref) {|cached| cached[:commit_status] }
2015-04-26 12:48:37 +05:30
end
2017-08-17 22:00:37 +05:30
def execute(data)
return unless supported_events.include?(data[:object_kind])
2018-11-08 19:23:39 +05:30
get_path("updateAndBuild.action", { buildKey: build_key })
2017-08-17 22:00:37 +05:30
end
def calculate_reactive_cache(sha, ref)
2018-11-08 19:23:39 +05:30
response = get_path("rest/api/latest/result/byChangeset/#{sha}")
2017-08-17 22:00:37 +05:30
{ build_page: read_build_page(response), commit_status: read_commit_status(response) }
end
2015-04-26 12:48:37 +05:30
2017-08-17 22:00:37 +05:30
private
2019-03-02 22:35:43 +05:30
def get_build_result(response)
return if response.code != 200
# May be nil if no result, a single result hash, or an array if multiple results for a given changeset.
result = response.dig('results', 'results', 'result')
# In case of multiple results, arbitrarily assume the last one is the most relevant.
return result.last if result.is_a?(Array)
result
2018-12-13 13:39:08 +05:30
end
2017-08-17 22:00:37 +05:30
def read_build_page(response)
2019-03-02 22:35:43 +05:30
result = get_build_result(response)
2019-02-15 15:39:39 +05:30
key =
2019-03-02 22:35:43 +05:30
if result.blank?
2019-02-15 15:39:39 +05:30
# If actual build link can't be determined, send user to build summary page.
build_key
else
# If actual build link is available, go to build result page.
2019-03-02 22:35:43 +05:30
result.dig('planResultKey', 'key')
2019-02-15 15:39:39 +05:30
end
build_url("browse/#{key}")
2015-04-26 12:48:37 +05:30
end
2017-08-17 22:00:37 +05:30
def read_commit_status(response)
return :error unless response.code == 200 || response.code == 404
2015-04-26 12:48:37 +05:30
2019-03-02 22:35:43 +05:30
result = get_build_result(response)
status =
if result.blank?
'Pending'
else
result.dig('buildState')
end
return :error unless status.present?
2015-04-26 12:48:37 +05:30
if status.include?('Success')
'success'
elsif status.include?('Failed')
'failed'
elsif status.include?('Pending')
'pending'
else
:error
end
end
def build_url(path)
2019-02-15 15:39:39 +05:30
Gitlab::Utils.append_path(bamboo_url, path)
end
2018-11-08 19:23:39 +05:30
def get_path(path, query_params = {})
url = build_url(path)
if username.blank? && password.blank?
2018-11-08 19:23:39 +05:30
Gitlab::HTTP.get(url, verify: false, query: query_params)
else
2018-11-08 19:23:39 +05:30
query_params[:os_authType] = 'basic'
Gitlab::HTTP.get(url,
verify: false,
query: query_params,
basic_auth: {
username: username,
password: password
})
end
2015-04-26 12:48:37 +05:30
end
end