debian-mirror-gitlab/spec/services/google_cloud/enable_cloudsql_service_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

82 lines
3.6 KiB
Ruby
Raw Normal View History

2022-08-27 11:52:29 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe GoogleCloud::EnableCloudsqlService, feature_category: :deployment_management do
2022-08-27 11:52:29 +05:30
let_it_be(:project) { create(:project) }
2022-11-25 23:54:43 +05:30
let_it_be(:user) { create(:user) }
let_it_be(:params) do
{
google_oauth2_token: 'mock-token',
gcp_project_id: 'mock-gcp-project-id',
environment_name: 'main'
}
end
2022-08-27 11:52:29 +05:30
2022-11-25 23:54:43 +05:30
subject(:result) { described_class.new(project, user, params).execute }
2022-08-27 11:52:29 +05:30
context 'when a project does not have any GCP_PROJECT_IDs configured' do
2022-11-25 23:54:43 +05:30
it 'creates GCP_PROJECT_ID project var' do
expect_next_instance_of(GoogleApi::CloudPlatform::Client) do |instance|
expect(instance).to receive(:enable_cloud_sql_admin).with('mock-gcp-project-id')
expect(instance).to receive(:enable_compute).with('mock-gcp-project-id')
expect(instance).to receive(:enable_service_networking).with('mock-gcp-project-id')
end
2022-08-27 11:52:29 +05:30
2022-11-25 23:54:43 +05:30
expect(result[:status]).to eq(:success)
expect(project.variables.count).to eq(1)
expect(project.variables.first.key).to eq('GCP_PROJECT_ID')
expect(project.variables.first.value).to eq('mock-gcp-project-id')
2022-08-27 11:52:29 +05:30
end
end
context 'when a project has GCP_PROJECT_IDs configured' do
before do
project.variables.build(environment_scope: 'production', key: 'GCP_PROJECT_ID', value: 'prj-prod')
project.variables.build(environment_scope: 'staging', key: 'GCP_PROJECT_ID', value: 'prj-staging')
project.save!
end
2022-10-11 01:57:18 +05:30
after do
project.variables.destroy_all # rubocop:disable Cop/DestroyAll
project.save!
end
2022-08-27 11:52:29 +05:30
it 'enables cloudsql, compute and service networking Google APIs', :aggregate_failures do
expect_next_instance_of(GoogleApi::CloudPlatform::Client) do |instance|
2022-11-25 23:54:43 +05:30
expect(instance).to receive(:enable_cloud_sql_admin).with('mock-gcp-project-id')
expect(instance).to receive(:enable_compute).with('mock-gcp-project-id')
expect(instance).to receive(:enable_service_networking).with('mock-gcp-project-id')
2022-08-27 11:52:29 +05:30
expect(instance).to receive(:enable_cloud_sql_admin).with('prj-prod')
expect(instance).to receive(:enable_compute).with('prj-prod')
expect(instance).to receive(:enable_service_networking).with('prj-prod')
expect(instance).to receive(:enable_cloud_sql_admin).with('prj-staging')
expect(instance).to receive(:enable_compute).with('prj-staging')
expect(instance).to receive(:enable_service_networking).with('prj-staging')
end
expect(result[:status]).to eq(:success)
end
2022-10-11 01:57:18 +05:30
context 'when Google APIs raise an error' do
it 'returns error result' do
allow_next_instance_of(GoogleApi::CloudPlatform::Client) do |instance|
2022-11-25 23:54:43 +05:30
allow(instance).to receive(:enable_cloud_sql_admin).with('mock-gcp-project-id')
allow(instance).to receive(:enable_compute).with('mock-gcp-project-id')
allow(instance).to receive(:enable_service_networking).with('mock-gcp-project-id')
2022-10-11 01:57:18 +05:30
allow(instance).to receive(:enable_cloud_sql_admin).with('prj-prod')
allow(instance).to receive(:enable_compute).with('prj-prod')
allow(instance).to receive(:enable_service_networking).with('prj-prod')
allow(instance).to receive(:enable_cloud_sql_admin).with('prj-staging')
allow(instance).to receive(:enable_compute).with('prj-staging')
allow(instance).to receive(:enable_service_networking).with('prj-staging')
.and_raise(Google::Apis::Error.new('error'))
end
expect(result[:status]).to eq(:error)
expect(result[:message]).to eq('error')
end
end
2022-08-27 11:52:29 +05:30
end
end