gitlab-org--gitlab-foss/app/models/project_services/bamboo_service.rb

131 lines
3.4 KiB
Ruby
Raw Normal View History

2014-10-16 12:34:19 -04:00
class BambooService < CiService
include ReactiveService
2014-10-16 12:34:19 -04:00
prop_accessor :bamboo_url, :build_key, :username, :password
2015-12-01 18:45:36 -05:00
validates :bamboo_url, presence: true, url: true, if: :activated?
2014-10-16 12:34:19 -04:00
validates :build_key, presence: true, if: :activated?
2015-02-03 00:15:44 -05:00
validates :username,
presence: true,
2015-12-15 14:37:23 -05:00
if: ->(service) { service.activated? && service.password }
2015-02-03 00:15:44 -05:00
validates :password,
presence: true,
2015-12-15 14:37:23 -05:00
if: ->(service) { service.activated? && service.username }
2014-10-16 12:34:19 -04:00
attr_accessor :response
after_save :compose_service_hook, if: :activated?
before_update :reset_password
2014-10-16 12:34:19 -04:00
def compose_service_hook
hook = service_hook || build_service_hook
hook.save
end
def reset_password
if bamboo_url_changed? && !password_touched?
self.password = nil
end
end
2014-10-16 12:34:19 -04:00
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
def self.to_param
2014-10-16 12:34:19 -04:00
'bamboo'
end
def fields
[
{ type: 'text', name: 'bamboo_url',
placeholder: 'Bamboo root URL like https://bamboo.example.com', required: true },
2014-10-16 12:34:19 -04:00
{ type: 'text', name: 'build_key',
placeholder: 'Bamboo build plan key like KEY', required: true },
2014-10-16 12:34:19 -04:00
{ type: 'text', name: 'username',
placeholder: 'A user with API access, if applicable' },
{ type: 'password', name: 'password' }
2014-10-16 12:34:19 -04:00
]
end
def build_page(sha, ref)
with_reactive_cache(sha, ref) {|cached| cached[:build_page] }
2014-10-16 12:34:19 -04:00
end
def commit_status(sha, ref)
with_reactive_cache(sha, ref) {|cached| cached[:commit_status] }
end
2014-10-16 12:34:19 -04:00
def execute(data)
return unless supported_events.include?(data[:object_kind])
get_path("updateAndBuild.action?buildKey=#{build_key}")
end
def calculate_reactive_cache(sha, ref)
response = get_path("rest/api/latest/result?label=#{sha}")
{ build_page: read_build_page(response), commit_status: read_commit_status(response) }
end
private
def read_build_page(response)
if response.code != 200 || response['results']['results']['size'] == '0'
2014-10-16 12:34:19 -04:00
# If actual build link can't be determined, send user to build summary page.
URI.join("#{bamboo_url}/", "browse/#{build_key}").to_s
2014-10-16 12:34:19 -04:00
else
# If actual build link is available, go to build result page.
result_key = response['results']['results']['result']['planResultKey']['key']
URI.join("#{bamboo_url}/", "browse/#{result_key}").to_s
2014-10-16 12:34:19 -04:00
end
end
def read_commit_status(response)
return :error unless response.code == 200 || response.code == 404
2014-10-16 12:34:19 -04:00
status = if response.code == 404 || response['results']['results']['size'] == '0'
2014-10-16 12:34:19 -04:00
'Pending'
else
response['results']['results']['result']['buildState']
2014-10-16 12:34:19 -04:00
end
if status.include?('Success')
'success'
elsif status.include?('Failed')
'failed'
elsif status.include?('Pending')
'pending'
else
:error
end
end
def build_url(path)
URI.join("#{bamboo_url}/", path).to_s
end
def get_path(path)
url = build_url(path)
if username.blank? && password.blank?
HTTParty.get(url, verify: false)
else
url << '&os_authType=basic'
HTTParty.get(url, verify: false,
basic_auth: {
username: username,
password: password
})
end
2014-10-16 12:34:19 -04:00
end
end