Commit 4372795d authored by Kamil Trzciński's avatar Kamil Trzciński

Fix Composite

parent 4e1281a1
...@@ -49,7 +49,7 @@ class CommitStatus < ApplicationRecord ...@@ -49,7 +49,7 @@ class CommitStatus < ApplicationRecord
scope :for_ids, -> (ids) { where(id: ids) } scope :for_ids, -> (ids) { where(id: ids) }
scope :with_preloads, -> do scope :with_preloads, -> do
preload(:project, :taggings, :deployment, :user) preload(:project, :user)
end end
scope :with_needs, -> (names = nil) do scope :with_needs, -> (names = nil) do
......
...@@ -4,12 +4,16 @@ module Gitlab ...@@ -4,12 +4,16 @@ module Gitlab
module Ci module Ci
module Status module Status
class Composite class Composite
include Gitlab::Utils::StrongMemoize
attr_reader :warnings attr_reader :warnings
# This class accepts an array of arrays or array of hashes # This class accepts an array of arrays
# The `status_key` and `allow_failure_key` define an index # The `status_key` and `allow_failure_key` define an index
# or key in each entry # or key in each entry
def initialize(all_statuses, status_key:, allow_failure_key:) def initialize(all_statuses, status_key:, allow_failure_key:)
raise ArgumentError, "all_statuses needs to be an Array" unless all_statuses.is_a?(Array)
@count = 0 @count = 0
@warnings = 0 @warnings = 0
@status_set = Set.new @status_set = Set.new
...@@ -19,34 +23,41 @@ module Gitlab ...@@ -19,34 +23,41 @@ module Gitlab
build_status_set(all_statuses) build_status_set(all_statuses)
end end
# The status calculation is order dependent,
# 1. In some cases we assume that that status is exact
# if the we only have given statues,
# 2. In other cases we assume that status is of that type
# based on what statuses are no longer valid based on the
# data set that we have
def status def status
case strong_memoize(:status) do
when @count.zero? next if @count.zero?
nil
when none? || only_of?(:skipped) if none? || only_of?(:skipped)
warnings? ? 'success' : 'skipped' warnings? ? 'success' : 'skipped'
when only_of?(:success, :skipped) elsif only_of?(:success, :skipped)
'success' 'success'
when only_of?(:created) elsif only_of?(:created)
'created' 'created'
when only_of?(:preparing) elsif only_of?(:preparing)
'preparing' 'preparing'
when only_of?(:success, :skipped, :canceled) elsif only_of?(:canceled, :success, :skipped)
'canceled' 'canceled'
when only_of?(:created, :skipped, :pending) elsif only_of?(:pending, :created, :skipped)
'pending' 'pending'
when any_of?(:running, :pending) elsif any_of?(:running, :pending)
'running' 'running'
when any_of?(:manual) elsif any_of?(:manual)
'manual' 'manual'
when any_of?(:scheduled) elsif any_of?(:scheduled)
'scheduled' 'scheduled'
when any_of?(:preparing) elsif any_of?(:preparing)
'preparing' 'preparing'
when any_of?(:created) elsif any_of?(:created)
'running' 'running'
else else
'failed' 'failed'
end
end end
end end
...@@ -71,6 +82,8 @@ module Gitlab ...@@ -71,6 +82,8 @@ module Gitlab
def build_status_set(all_statuses) def build_status_set(all_statuses)
all_statuses.each do |status| all_statuses.each do |status|
status = Array(status)
@count += 1 @count += 1
@warnings += 1 if count_as_warning?(status) @warnings += 1 if count_as_warning?(status)
next if exclude_from_calculation?(status) next if exclude_from_calculation?(status)
......
...@@ -3,14 +3,6 @@ require 'spec_helper' ...@@ -3,14 +3,6 @@ require 'spec_helper'
describe Gitlab::Ci::Status::Composite do describe Gitlab::Ci::Status::Composite do
set(:pipeline) { create(:ci_pipeline) } set(:pipeline) { create(:ci_pipeline) }
let(:composite_status) do
described_class.new(
all_statuses.pluck(:status, :allow_failure),
status_key: 0,
allow_failure_key: 0
)
end
before(:all) do before(:all) do
@statuses = HasStatus::STATUSES_ENUM.map do |status, idx| @statuses = HasStatus::STATUSES_ENUM.map do |status, idx|
[status, create(:ci_build, pipeline: pipeline, status: status, importing: true)] [status, create(:ci_build, pipeline: pipeline, status: status, importing: true)]
...@@ -37,6 +29,14 @@ describe Gitlab::Ci::Status::Composite do ...@@ -37,6 +29,14 @@ describe Gitlab::Ci::Status::Composite do
let(:all_statuses) do let(:all_statuses) do
statuses.map { |status| @statuses[status] } statuses.map { |status| @statuses[status] }
end end
let(:composite_status) do
described_class.new(
all_statuses.pluck(:status),
status_key: 0,
allow_failure_key: nil
)
end
end end
HasStatus::STATUSES_ENUM.each do |allow_failure_status, _| HasStatus::STATUSES_ENUM.each do |allow_failure_status, _|
...@@ -46,6 +46,14 @@ describe Gitlab::Ci::Status::Composite do ...@@ -46,6 +46,14 @@ describe Gitlab::Ci::Status::Composite do
statuses.map { |status| @statuses[status] } + statuses.map { |status| @statuses[status] } +
[@statuses_with_allow_failure[allow_failure_status]] [@statuses_with_allow_failure[allow_failure_status]]
end end
let(:composite_status) do
described_class.new(
all_statuses.pluck(:status, :allow_failure),
status_key: 0,
allow_failure_key: 1
)
end
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment