blob: 4188521df8e3e9080addd9db89e644ee794567f2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
# frozen_string_literal: true
require 'rake_helper'
RSpec.describe 'gitlab:terraform_states' do
let_it_be(:version) { create(:terraform_state_version) }
let(:logger) { instance_double(Logger) }
let(:helper) { double }
before(:all) do
Rake.application.rake_require 'tasks/gitlab/terraform/migrate'
end
before do
allow(Logger).to receive(:new).with(STDOUT).and_return(logger)
end
describe 'gitlab:terraform_states:migrate' do
subject { run_rake_task('gitlab:terraform_states:migrate') }
it 'invokes the migration helper to move files to object storage' do
expect(Gitlab::Terraform::StateMigrationHelper).to receive(:migrate_to_remote_storage).and_yield(version)
expect(logger).to receive(:info).with('Starting transfer of Terraform states to object storage')
expect(logger).to receive(:info).with(/Transferred Terraform state version ID #{version.id}/)
subject
end
context 'an error is raised while migrating' do
let(:error_message) { 'Something went wrong' }
before do
allow(Gitlab::Terraform::StateMigrationHelper).to receive(:migrate_to_remote_storage).and_raise(StandardError, error_message)
end
it 'logs the error' do
expect(logger).to receive(:info).with('Starting transfer of Terraform states to object storage')
expect(logger).to receive(:error).with("Failed to migrate: #{error_message}")
subject
end
end
end
end
|