summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/background_migration/digest_column_spec.rb
blob: a25dcb060054329918a298623bc62d25e52d0183 (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
46
# frozen_string_literal: true

require 'spec_helper'

describe Gitlab::BackgroundMigration::DigestColumn, :migration, schema: 20180913142237 do
  let(:personal_access_tokens) { table(:personal_access_tokens) }
  let(:users) { table(:users) }

  subject { described_class.new }

  describe '#perform' do
    context 'token is not yet hashed' do
      before do
        users.create(id: 1, email: 'user@example.com', projects_limit: 10)
        personal_access_tokens.create!(id: 1, user_id: 1, name: 'pat-01', token: 'token-01')
      end

      it 'saves token digest' do
        expect { subject.perform(PersonalAccessToken, :token, :token_digest, 1, 2) }.to(
          change { PersonalAccessToken.find(1).token_digest }.from(nil).to(Gitlab::CryptoHelper.sha256('token-01')))
      end

      it 'erases token' do
        expect { subject.perform(PersonalAccessToken, :token, :token_digest, 1, 2) }.to(
          change { PersonalAccessToken.find(1).read_attribute(:token) }.from('token-01').to(nil))
      end
    end

    context 'token is already hashed' do
      before do
        users.create(id: 1, email: 'user@example.com', projects_limit: 10)
        personal_access_tokens.create!(id: 1, user_id: 1, name: 'pat-01', token_digest: 'token-digest-01')
      end

      it 'does not change existing token digest' do
        expect { subject.perform(PersonalAccessToken, :token, :token_digest, 1, 2) }.not_to(
          change { PersonalAccessToken.find(1).token_digest })
      end

      it 'leaves token empty' do
        expect { subject.perform(PersonalAccessToken, :token, :token_digest, 1, 2) }.not_to(
          change { PersonalAccessToken.find(1).read_attribute(:token) }.from(nil))
      end
    end
  end
end