summaryrefslogtreecommitdiff
path: root/spec/tasks/gitlab/terraform/migrate_rake_spec.rb
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