summaryrefslogtreecommitdiff
path: root/spec/config/smime_signature_settings_spec.rb
blob: 4f0c227d866befce1d398e909037ebe66aa7c6b0 (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
47
48
49
50
51
52
53
54
55
56
require 'fast_spec_helper'

describe SmimeSignatureSettings do
  describe '.parse' do
    let(:default_smime_key) { Rails.root.join('.gitlab_smime_key') }
    let(:default_smime_cert) { Rails.root.join('.gitlab_smime_cert') }

    it 'sets correct default values to disabled' do
      parsed_settings = described_class.parse(nil)

      expect(parsed_settings['enabled']).to be(false)
      expect(parsed_settings['key_file']).to eq(default_smime_key)
      expect(parsed_settings['cert_file']).to eq(default_smime_cert)
    end

    context 'when providing custom values' do
      it 'sets correct default values to disabled' do
        custom_settings = Settingslogic.new({})

        parsed_settings = described_class.parse(custom_settings)

        expect(parsed_settings['enabled']).to be(false)
        expect(parsed_settings['key_file']).to eq(default_smime_key)
        expect(parsed_settings['cert_file']).to eq(default_smime_cert)
      end

      it 'enables smime with default key and cert' do
        custom_settings = Settingslogic.new({
          'enabled' => true
        })

        parsed_settings = described_class.parse(custom_settings)

        expect(parsed_settings['enabled']).to be(true)
        expect(parsed_settings['key_file']).to eq(default_smime_key)
        expect(parsed_settings['cert_file']).to eq(default_smime_cert)
      end

      it 'enables smime with custom key and cert' do
        custom_key = '/custom/key'
        custom_cert = '/custom/cert'
        custom_settings = Settingslogic.new({
          'enabled' => true,
          'key_file' => custom_key,
          'cert_file' => custom_cert
        })

        parsed_settings = described_class.parse(custom_settings)

        expect(parsed_settings['enabled']).to be(true)
        expect(parsed_settings['key_file']).to eq(custom_key)
        expect(parsed_settings['cert_file']).to eq(custom_cert)
      end
    end
  end
end