gitlab-org--gitlab-foss/spec/migrations/migrate_kubernetes_service_...

124 lines
4.6 KiB
Ruby
Raw Normal View History

require 'spec_helper'
require Rails.root.join('db', 'post_migrate', '20171124104327_migrate_kubernetes_service_to_new_clusters_architectures.rb')
describe MigrateKubernetesServiceToNewClustersArchitectures, :migration do
2017-12-14 17:56:23 +00:00
context 'when unique KubernetesService exists' do
shared_examples 'KubernetesService migration' do
let(:sample_num) { 2 }
let(:projects) { create_list(:project, sample_num) }
let!(:kubernetes_services) do
projects.map do |project|
create(:kubernetes_service,
project: project,
active: active,
api_url: "https://kubernetes#{project.id}.com",
token: defined?(token) ? token : "token#{project.id}",
ca_pem: "ca_pem#{project.id}")
end
2017-12-14 17:56:23 +00:00
end
2017-12-14 17:56:23 +00:00
it 'migrates the KubernetesService to Platform::Kubernetes' do
expect{ migrate! }.to change { Clusters::Cluster.count }.by(sample_num)
projects.each do |project|
project.clusters.last.tap do |cluster|
expect(cluster.enabled).to eq(active)
expect(cluster.platform_kubernetes.api_url).to eq(project.kubernetes_service.api_url)
expect(cluster.platform_kubernetes.ca_pem).to eq(project.kubernetes_service.ca_pem)
expect(cluster.platform_kubernetes.token).to eq(project.kubernetes_service.token)
expect(project.kubernetes_service).not_to be_active
expect(project.kubernetes_service.properties['migrated']).to be_truthy
end
end
end
end
2017-12-14 17:56:23 +00:00
context 'when KubernetesService is active' do
let(:active) { true }
2017-12-14 17:56:23 +00:00
it_behaves_like 'KubernetesService migration'
end
2017-12-14 17:56:23 +00:00
context 'when KubernetesService is not active' do
let(:active) { false }
2017-12-14 17:56:23 +00:00
# Platforms::Kubernetes validates `token` reagdless of the activeness
# KubernetesService validates `token` if only it's activated
# However, in this migration file, there are no validations because of the migration specific model class
# therefore, Validation Error will not happen in this case and just migrate data
let(:token) { '' }
2017-12-14 17:56:23 +00:00
it_behaves_like 'KubernetesService migration'
end
end
2017-12-14 17:56:23 +00:00
context 'when unique KubernetesService spawned from Service Template' do
2017-12-15 13:43:25 +00:00
let(:sample_num) { 2 }
let(:projects) { create_list(:project, sample_num) }
let!(:kubernetes_service_template) do
create(:kubernetes_service,
project: nil,
template: true,
api_url: "https://sample.kubernetes.com",
token: "token-sample",
ca_pem: "ca_pem-sample")
end
let!(:kubernetes_services) do
projects.map do |project|
create(:kubernetes_service,
project: project,
api_url: kubernetes_service_template.api_url,
token: kubernetes_service_template.token,
ca_pem: kubernetes_service_template.ca_pem)
end
end
it 'migrates the KubernetesService to Platform::Kubernetes without template' do
expect{ migrate! }.to change { Clusters::Cluster.count }.by(sample_num)
2017-12-15 13:43:25 +00:00
projects.each do |project|
project.clusters.last.tap do |cluster|
expect(cluster.platform_kubernetes.api_url).to eq(project.kubernetes_service.api_url)
expect(cluster.platform_kubernetes.ca_pem).to eq(project.kubernetes_service.ca_pem)
expect(cluster.platform_kubernetes.token).to eq(project.kubernetes_service.token)
expect(project.kubernetes_service).not_to be_active
expect(project.kubernetes_service.properties['migrated']).to be_truthy
end
end
end
2017-12-14 17:56:23 +00:00
end
2017-12-14 17:56:23 +00:00
context 'when synced KubernetesService exists' do
2017-12-15 13:43:25 +00:00
let(:project) { create(:project) }
let(:cluster) { create(:cluster, :provided_by_gcp, projects: [project]) }
let!(:platform_kubernetes) { cluster.platform_kubernetes }
let!(:kubernetes_service) do
create(:kubernetes_service,
project: project,
active: cluster.enabled,
api_url: platform_kubernetes.api_url,
token: platform_kubernetes.token,
ca_pem: platform_kubernetes.ca_cert)
end
2017-12-14 17:56:23 +00:00
it 'does not migrate the KubernetesService' do # Because the corresponding Platform::Kubernetes already exists
2017-12-15 13:43:25 +00:00
expect{ migrate! }.not_to change { Clusters::Cluster.count }
2017-12-15 13:43:25 +00:00
expect(kubernetes_service).to be_active
expect(kubernetes_service.properties['migrated']).to be_falsy
end
end
2017-12-14 17:56:23 +00:00
context 'when KubernetesService does not exist' do
2017-12-15 13:43:25 +00:00
let!(:project) { create(:project) }
2017-12-15 13:43:25 +00:00
it 'does not migrate the KubernetesService' do
expect{ migrate! }.not_to change { Clusters::Cluster.count }
2017-12-14 17:56:23 +00:00
end
end
end