debian-mirror-gitlab/spec/initializers/secret_token_spec.rb

221 lines
7.3 KiB
Ruby
Raw Normal View History

2016-09-13 17:45:13 +05:30
require 'spec_helper'
2018-11-08 19:23:39 +05:30
require_relative '../../config/initializers/01_secret_token'
2016-09-13 17:45:13 +05:30
2017-09-10 17:25:29 +05:30
describe 'create_tokens' do
2017-08-17 22:00:37 +05:30
include StubENV
2016-09-13 17:45:13 +05:30
let(:secrets) { ActiveSupport::OrderedOptions.new }
2019-07-31 22:56:46 +05:30
HEX_KEY = /\h{128}/.freeze
RSA_KEY = /\A-----BEGIN RSA PRIVATE KEY-----\n.+\n-----END RSA PRIVATE KEY-----\n\Z/m.freeze
2017-08-17 22:00:37 +05:30
2016-09-13 17:45:13 +05:30
before do
allow(File).to receive(:write)
allow(File).to receive(:delete)
allow(Rails).to receive_message_chain(:application, :secrets).and_return(secrets)
allow(Rails).to receive_message_chain(:root, :join) { |string| string }
allow(self).to receive(:warn)
allow(self).to receive(:exit)
end
2017-08-17 22:00:37 +05:30
context 'setting secret keys' do
2016-09-13 17:45:13 +05:30
context 'when none of the secrets exist' do
before do
2017-08-17 22:00:37 +05:30
stub_env('SECRET_KEY_BASE', nil)
2016-09-13 17:45:13 +05:30
allow(File).to receive(:exist?).with('.secret').and_return(false)
allow(File).to receive(:exist?).with('config/secrets.yml').and_return(false)
allow(self).to receive(:warn_missing_secret)
end
2017-08-17 22:00:37 +05:30
it 'generates different hashes for secret_key_base, otp_key_base, and db_key_base' do
2016-09-13 17:45:13 +05:30
create_tokens
keys = secrets.values_at(:secret_key_base, :otp_key_base, :db_key_base)
expect(keys.uniq).to eq(keys)
2017-08-17 22:00:37 +05:30
expect(keys).to all(match(HEX_KEY))
end
2018-03-17 18:26:18 +05:30
it 'generates an RSA key for openid_connect_signing_key' do
2017-08-17 22:00:37 +05:30
create_tokens
2018-03-17 18:26:18 +05:30
keys = secrets.values_at(:openid_connect_signing_key)
2017-08-17 22:00:37 +05:30
expect(keys.uniq).to eq(keys)
expect(keys).to all(match(RSA_KEY))
2016-09-13 17:45:13 +05:30
end
it 'warns about the secrets to add to secrets.yml' do
expect(self).to receive(:warn_missing_secret).with('secret_key_base')
expect(self).to receive(:warn_missing_secret).with('otp_key_base')
expect(self).to receive(:warn_missing_secret).with('db_key_base')
2018-03-17 18:26:18 +05:30
expect(self).to receive(:warn_missing_secret).with('openid_connect_signing_key')
2016-09-13 17:45:13 +05:30
create_tokens
end
it 'writes the secrets to secrets.yml' do
expect(File).to receive(:write).with('config/secrets.yml', any_args) do |filename, contents, options|
new_secrets = YAML.load(contents)[Rails.env]
expect(new_secrets['secret_key_base']).to eq(secrets.secret_key_base)
expect(new_secrets['otp_key_base']).to eq(secrets.otp_key_base)
expect(new_secrets['db_key_base']).to eq(secrets.db_key_base)
2018-03-17 18:26:18 +05:30
expect(new_secrets['openid_connect_signing_key']).to eq(secrets.openid_connect_signing_key)
2016-09-13 17:45:13 +05:30
end
create_tokens
end
it 'does not write a .secret file' do
expect(File).not_to receive(:write).with('.secret')
create_tokens
end
end
context 'when the other secrets all exist' do
before do
secrets.db_key_base = 'db_key_base'
2018-03-17 18:26:18 +05:30
secrets.openid_connect_signing_key = 'openid_connect_signing_key'
2016-09-13 17:45:13 +05:30
allow(File).to receive(:exist?).with('.secret').and_return(true)
allow(File).to receive(:read).with('.secret').and_return('file_key')
end
context 'when secret_key_base exists in the environment and secrets.yml' do
before do
2017-08-17 22:00:37 +05:30
stub_env('SECRET_KEY_BASE', 'env_key')
2016-09-13 17:45:13 +05:30
secrets.secret_key_base = 'secret_key_base'
secrets.otp_key_base = 'otp_key_base'
2018-03-17 18:26:18 +05:30
secrets.openid_connect_signing_key = 'openid_connect_signing_key'
2016-09-13 17:45:13 +05:30
end
it 'does not issue a warning' do
expect(self).not_to receive(:warn)
create_tokens
end
it 'uses the environment variable' do
create_tokens
expect(secrets.secret_key_base).to eq('env_key')
end
it 'does not update secrets.yml' do
expect(File).not_to receive(:write)
create_tokens
end
end
context 'when secret_key_base and otp_key_base exist' do
before do
secrets.secret_key_base = 'secret_key_base'
secrets.otp_key_base = 'otp_key_base'
2018-03-17 18:26:18 +05:30
secrets.openid_connect_signing_key = 'openid_connect_signing_key'
2016-09-13 17:45:13 +05:30
end
it 'does not write any files' do
expect(File).not_to receive(:write)
create_tokens
end
2019-02-15 15:39:39 +05:30
it 'sets the keys to the values from the environment and secrets.yml' do
2016-09-13 17:45:13 +05:30
create_tokens
expect(secrets.secret_key_base).to eq('secret_key_base')
expect(secrets.otp_key_base).to eq('otp_key_base')
expect(secrets.db_key_base).to eq('db_key_base')
2018-03-17 18:26:18 +05:30
expect(secrets.openid_connect_signing_key).to eq('openid_connect_signing_key')
2016-09-13 17:45:13 +05:30
end
it 'deletes the .secret file' do
expect(File).to receive(:delete).with('.secret')
create_tokens
end
end
context 'when secret_key_base and otp_key_base do not exist' do
before do
allow(File).to receive(:exist?).with('config/secrets.yml').and_return(true)
allow(YAML).to receive(:load_file).with('config/secrets.yml').and_return('test' => secrets.to_h.stringify_keys)
allow(self).to receive(:warn_missing_secret)
end
it 'uses the file secret' do
expect(File).to receive(:write) do |filename, contents, options|
new_secrets = YAML.load(contents)[Rails.env]
expect(new_secrets['secret_key_base']).to eq('file_key')
expect(new_secrets['otp_key_base']).to eq('file_key')
expect(new_secrets['db_key_base']).to eq('db_key_base')
2018-03-17 18:26:18 +05:30
expect(new_secrets['openid_connect_signing_key']).to eq('openid_connect_signing_key')
2016-09-13 17:45:13 +05:30
end
create_tokens
expect(secrets.otp_key_base).to eq('file_key')
end
it 'keeps the other secrets as they were' do
create_tokens
expect(secrets.db_key_base).to eq('db_key_base')
end
it 'warns about the missing secrets' do
expect(self).to receive(:warn_missing_secret).with('secret_key_base')
expect(self).to receive(:warn_missing_secret).with('otp_key_base')
create_tokens
end
it 'deletes the .secret file' do
expect(File).to receive(:delete).with('.secret')
create_tokens
end
end
end
context 'when db_key_base is blank but exists in secrets.yml' do
before do
secrets.otp_key_base = 'otp_key_base'
secrets.secret_key_base = 'secret_key_base'
yaml_secrets = secrets.to_h.stringify_keys.merge('db_key_base' => '<%= an_erb_expression %>')
allow(File).to receive(:exist?).with('.secret').and_return(false)
allow(File).to receive(:exist?).with('config/secrets.yml').and_return(true)
allow(YAML).to receive(:load_file).with('config/secrets.yml').and_return('test' => yaml_secrets)
allow(self).to receive(:warn_missing_secret)
end
it 'warns about updating db_key_base' do
expect(self).to receive(:warn_missing_secret).with('db_key_base')
create_tokens
end
it 'warns about the blank value existing in secrets.yml and exits' do
expect(self).to receive(:warn) do |warning|
expect(warning).to include('db_key_base')
expect(warning).to include('<%= an_erb_expression %>')
end
create_tokens
end
it 'does not update secrets.yml' do
expect(self).to receive(:exit).with(1).and_call_original
expect(File).not_to receive(:write)
expect { create_tokens }.to raise_error(SystemExit)
end
end
end
end