Class: MergeRequests::Mergeability::DetailedMergeStatusService
- Inherits:
-
Object
- Object
- MergeRequests::Mergeability::DetailedMergeStatusService
- Includes:
- Gitlab::Utils::StrongMemoize
- Defined in:
- app/services/merge_requests/mergeability/detailed_merge_status_service.rb
Instance Method Summary collapse
- #execute ⇒ Object
-
#initialize(merge_request:) ⇒ DetailedMergeStatusService
constructor
A new instance of DetailedMergeStatusService.
Constructor Details
#initialize(merge_request:) ⇒ DetailedMergeStatusService
Returns a new instance of DetailedMergeStatusService.
8 9 10 |
# File 'app/services/merge_requests/mergeability/detailed_merge_status_service.rb', line 8 def initialize(merge_request:) @merge_request = merge_request end |
Instance Method Details
#execute ⇒ Object
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'app/services/merge_requests/mergeability/detailed_merge_status_service.rb', line 12 def execute return :preparing if preparing? return :checking if checking? return :unchecked if unchecked? if check_results.success? # If everything else is mergeable, but CI is not, the frontend expects two potential states to be returned # See discussion: gitlab.com/gitlab-org/gitlab/-/merge_requests/96778#note_1093063523 if check_ci_results.failed? ci_check_failed_check else :mergeable end else # This check can only fail in EE if check_results.payload[:unsuccessful_check] == :not_approved && merge_request.temporarily_unapproved? return :approvals_syncing end check_results.payload[:unsuccessful_check] end end |