123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe Certificate::ApplySSLCertificates, :aggregate_failures, type: :model do
- describe '.ensure_fresh_ssl_context' do
- def current_store
- OpenSSL::SSL::SSLContext::DEFAULT_CERT_STORE
- end
- context 'with a custom certificate present' do
- it 'changes the context' do
- create(:ssl_certificate, fixture: 'RootCA')
- expect { described_class.ensure_fresh_ssl_context }.to change { current_store }
- expect { described_class.ensure_fresh_ssl_context }.not_to change { current_store }
- create(:ssl_certificate, fixture: 'ChainCA')
- expect { described_class.ensure_fresh_ssl_context }.to change { current_store }
- end
- end
- context 'without custom certificates present' do
- it 'changes the context' do
- expect { described_class.ensure_fresh_ssl_context }.to change { current_store }
- end
- end
- end
- describe '.extract_metadata' do
- it 'imports CA certificates correctly' do
- expect(create(:ssl_certificate, fixture: 'RootCA')).to have_attributes(
- fingerprint: 'de4abd259187d7b5f2713ff7a97eb54dd5fe9d86',
- subject: '/emailAddress=RootCA@example.com/C=DE/ST=Berlin/L=Berlin/O=Example Security/OU=IT Department/CN=example.com',
- not_before: Time.zone.parse('2023-08-01 09:47:39 UTC'),
- not_after: Time.zone.parse('2043-07-27 09:47:39 UTC'),
- )
- expect(create(:ssl_certificate, fixture: 'IntermediateCA')).to have_attributes(
- fingerprint: 'd1badcd237d6d2c6f0c62b5ccb21c2130b24855e',
- subject: '/C=DE/ST=Berlin/O=Example Security/OU=IT Department/CN=example.com/emailAddress=IntermediateCA@example.com',
- not_before: Time.zone.parse('2023-08-01 09:47:39 UTC'),
- not_after: Time.zone.parse('2043-07-27 09:47:39 UTC'),
- )
- end
- it 'imports connection certificates correctly' do
- certificate = File.read(Localhost::Authority.fetch('localhost').certificate_path)
- expect(create(:ssl_certificate, certificate: certificate)).to have_attributes(
- subject: 'DNS:localhost',
- )
- end
- it 'rejects other certificates' do
- expect { create(:ssl_certificate, certificate: Rails.root.join('spec/fixtures/files/smime/smime1@example.com.crt').read) }.to raise_error(ActiveRecord::RecordInvalid, 'Validation failed: The certificate is not valid for SSL usage. Please check e.g. the validity period or the extensions.')
- end
- end
- end
|