2017-09-10 17:25:29 +05:30
|
|
|
class BuildDetailsEntity < JobEntity
|
|
|
|
expose :coverage, :erased_at, :duration
|
|
|
|
expose :tag_list, as: :tags
|
|
|
|
expose :user, using: UserEntity
|
|
|
|
expose :runner, using: RunnerEntity
|
|
|
|
expose :pipeline, using: PipelineEntity
|
|
|
|
|
2018-05-09 12:01:36 +05:30
|
|
|
expose :metadata, using: BuildMetadataEntity
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
expose :erased_by, if: -> (*) { build.erased? }, using: UserEntity
|
2018-03-17 18:26:18 +05:30
|
|
|
expose :erase_path, if: -> (*) { build.erasable? && can?(current_user, :erase_build, build) } do |build|
|
2017-09-10 17:25:29 +05:30
|
|
|
erase_project_job_path(project, build)
|
|
|
|
end
|
|
|
|
|
|
|
|
expose :merge_request, if: -> (*) { can?(current_user, :read_merge_request, build.merge_request) } do
|
|
|
|
expose :iid do |build|
|
|
|
|
build.merge_request.iid
|
|
|
|
end
|
|
|
|
|
|
|
|
expose :path do |build|
|
|
|
|
project_merge_request_path(build.merge_request.project,
|
|
|
|
build.merge_request)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
expose :new_issue_path, if: -> (*) { can?(request.current_user, :create_issue, project) && build.failed? } do |build|
|
|
|
|
new_project_issue_path(project, issue: build_failed_issue_options)
|
|
|
|
end
|
|
|
|
|
|
|
|
expose :raw_path do |build|
|
|
|
|
raw_project_job_path(project, build)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def build_failed_issue_options
|
2018-03-17 18:26:18 +05:30
|
|
|
{ title: "Job Failed ##{build.id}",
|
|
|
|
description: "Job [##{build.id}](#{project_job_path(project, build)}) failed for #{build.sha}:\n" }
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def current_user
|
|
|
|
request.current_user
|
|
|
|
end
|
|
|
|
|
|
|
|
def project
|
|
|
|
build.project
|
|
|
|
end
|
|
|
|
end
|