Commit f9d66965 authored by Kamil Trzciński's avatar Kamil Trzciński

Merge branch 'zj-kubernetes-rollout-invalid' into 'master'

Detect invalid roll out status requests

See merge request !1358
parents c42082b6 1f3969a5
...@@ -3,6 +3,7 @@ class RolloutStatusEntity < Grape::Entity ...@@ -3,6 +3,7 @@ class RolloutStatusEntity < Grape::Entity
expose :instances expose :instances
expose :completion expose :completion
expose :valid?, as: :valid
expose :is_completed do |rollout_status| expose :is_completed do |rollout_status|
rollout_status.complete? rollout_status.complete?
......
---
title: Set deployment status invalid when the environments does not match a k8s label
merge_request:
author:
...@@ -12,20 +12,27 @@ module Gitlab ...@@ -12,20 +12,27 @@ module Gitlab
completion == 100 completion == 100
end end
def valid?
@valid
end
def self.from_specs(*specs) def self.from_specs(*specs)
return new([], valid: false) if specs.empty?
deployments = specs.map { |spec| ::Gitlab::Kubernetes::Deployment.new(spec) } deployments = specs.map { |spec| ::Gitlab::Kubernetes::Deployment.new(spec) }
new(deployments) new(deployments)
end end
def initialize(deployments) def initialize(deployments, valid: true)
@deployments = deployments @valid = valid
@instances = deployments.flat_map(&:instances) @deployments = deployments
@instances = deployments.flat_map(&:instances)
@completion = @completion =
if @instances.empty? if @instances.empty?
100 100
else else
finished = @instances.select {|instance| instance[:status] == 'finished' }.count finished = @instances.select { |instance| instance[:status] == 'finished' }.count
(finished / @instances.count.to_f * 100).to_i (finished / @instances.count.to_f * 100).to_i
end end
......
...@@ -11,6 +11,8 @@ describe Gitlab::Kubernetes::RolloutStatus do ...@@ -11,6 +11,8 @@ describe Gitlab::Kubernetes::RolloutStatus do
end end
let(:specs) { specs_all_finished } let(:specs) { specs_all_finished }
let(:specs_none) { [] }
subject(:rollout_status) { described_class.from_specs(*specs) } subject(:rollout_status) { described_class.from_specs(*specs) }
describe '#deployments' do describe '#deployments' do
...@@ -61,4 +63,16 @@ describe Gitlab::Kubernetes::RolloutStatus do ...@@ -61,4 +63,16 @@ describe Gitlab::Kubernetes::RolloutStatus do
it { is_expected.to be_falsy} it { is_expected.to be_falsy}
end end
end end
describe '#valid?' do
context 'when the specs are passed' do
it { is_expected.to be_valid }
end
context 'when no specs are passed' do
let(:specs) { specs_none }
it { is_expected.not_to be_valid }
end
end
end end
...@@ -13,4 +13,5 @@ describe RolloutStatusEntity do ...@@ -13,4 +13,5 @@ describe RolloutStatusEntity do
it { is_expected.to have_key(:instances) } it { is_expected.to have_key(:instances) }
it { is_expected.to have_key(:completion) } it { is_expected.to have_key(:completion) }
it { is_expected.to have_key(:is_completed) } it { is_expected.to have_key(:is_completed) }
it { is_expected.to have_key(:valid) }
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