debian-mirror-gitlab/spec/models/clusters/applications/helm_spec.rb

138 lines
3.8 KiB
Ruby
Raw Normal View History

2019-07-07 11:18:12 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
require 'rails_helper'
describe Clusters::Applications::Helm do
2018-03-27 19:54:05 +05:30
include_examples 'cluster application core specs', :clusters_applications_helm
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
describe '.available' do
subject { described_class.available }
2018-05-09 12:01:36 +05:30
2018-11-18 11:00:15 +05:30
let!(:installed_cluster) { create(:clusters_applications_helm, :installed) }
2019-07-07 11:18:12 +05:30
let!(:updated_cluster) { create(:clusters_applications_helm, :updated) }
2018-05-09 12:01:36 +05:30
before do
create(:clusters_applications_helm, :errored)
end
2019-07-07 11:18:12 +05:30
it { is_expected.to contain_exactly(installed_cluster, updated_cluster) }
2018-11-18 11:00:15 +05:30
end
2019-07-31 22:56:46 +05:30
describe '#can_uninstall?' do
2019-10-12 21:52:04 +05:30
context "with other existing applications" do
Clusters::Cluster::APPLICATIONS.keys.each do |application_name|
next if application_name == 'helm'
it "is false when #{application_name} is installed" do
cluster_application = create("clusters_applications_#{application_name}".to_sym)
helm = cluster_application.cluster.application_helm
expect(helm.allowed_to_uninstall?).to be_falsy
end
end
2019-07-31 22:56:46 +05:30
2019-10-12 21:52:04 +05:30
it 'executes a single query only' do
cluster_application = create(:clusters_applications_ingress)
helm = cluster_application.cluster.application_helm
2019-07-31 22:56:46 +05:30
2019-10-12 21:52:04 +05:30
query_count = ActiveRecord::QueryRecorder.new { helm.allowed_to_uninstall? }.count
expect(query_count).to eq(1)
end
end
context "without other existing applications" do
subject { helm.can_uninstall? }
let(:helm) { create(:clusters_applications_helm) }
it { is_expected.to be_truthy }
end
2019-07-31 22:56:46 +05:30
end
2018-11-18 11:00:15 +05:30
describe '#issue_client_cert' do
let(:application) { create(:clusters_applications_helm) }
subject { application.issue_client_cert }
it 'returns a new cert' do
is_expected.to be_kind_of(Gitlab::Kubernetes::Helm::Certificate)
expect(subject.cert_string).not_to eq(application.ca_cert)
expect(subject.key_string).not_to eq(application.ca_key)
end
2018-05-09 12:01:36 +05:30
end
2018-03-17 18:26:18 +05:30
describe '#install_command' do
2018-03-27 19:54:05 +05:30
let(:helm) { create(:clusters_applications_helm) }
2018-03-17 18:26:18 +05:30
2018-03-27 19:54:05 +05:30
subject { helm.install_command }
2018-03-17 18:26:18 +05:30
2018-03-27 19:54:05 +05:30
it { is_expected.to be_an_instance_of(Gitlab::Kubernetes::Helm::InitCommand) }
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
it 'is initialized with 1 arguments' do
2018-03-27 19:54:05 +05:30
expect(subject.name).to eq('helm')
2018-03-17 18:26:18 +05:30
end
2018-11-18 11:00:15 +05:30
2019-07-07 11:18:12 +05:30
it 'has cert files' do
2018-11-18 11:00:15 +05:30
expect(subject.files[:'ca.pem']).to be_present
expect(subject.files[:'ca.pem']).to eq(helm.ca_cert)
expect(subject.files[:'cert.pem']).to be_present
expect(subject.files[:'key.pem']).to be_present
cert = OpenSSL::X509::Certificate.new(subject.files[:'cert.pem'])
expect(cert.not_after).to be > 999.years.from_now
end
2018-11-20 20:47:30 +05:30
describe 'rbac' do
2019-02-15 15:39:39 +05:30
context 'rbac cluster' do
it { expect(subject).to be_rbac }
2018-11-20 20:47:30 +05:30
end
2019-02-15 15:39:39 +05:30
context 'non rbac cluster' do
2018-11-20 20:47:30 +05:30
before do
2019-02-15 15:39:39 +05:30
helm.cluster.platform_kubernetes.abac!
2018-11-20 20:47:30 +05:30
end
2019-02-15 15:39:39 +05:30
it { expect(subject).not_to be_rbac }
2018-11-20 20:47:30 +05:30
end
end
2018-03-17 18:26:18 +05:30
end
2019-10-12 21:52:04 +05:30
describe '#uninstall_command' do
let(:helm) { create(:clusters_applications_helm) }
subject { helm.uninstall_command }
it { is_expected.to be_an_instance_of(Gitlab::Kubernetes::Helm::ResetCommand) }
it 'has name' do
expect(subject.name).to eq('helm')
end
it 'has cert files' do
expect(subject.files[:'ca.pem']).to be_present
expect(subject.files[:'ca.pem']).to eq(helm.ca_cert)
expect(subject.files[:'cert.pem']).to be_present
expect(subject.files[:'key.pem']).to be_present
cert = OpenSSL::X509::Certificate.new(subject.files[:'cert.pem'])
expect(cert.not_after).to be > 999.years.from_now
end
describe 'rbac' do
context 'rbac cluster' do
it { expect(subject).to be_rbac }
end
context 'non rbac cluster' do
before do
helm.cluster.platform_kubernetes.abac!
end
it { expect(subject).not_to be_rbac }
end
end
end
2018-03-17 18:26:18 +05:30
end