1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe SMIMEMetaInformationData, db_strategy: :reset, type: :db_migration do
- let(:smime_certificate) { create(:smime_certificate, fixture: 'smime1@example.com') }
- let(:smime_object) { Certificate::X509::SMIME.new(smime_certificate.pem) }
- describe 'migrate smime_certificates' do
- before do
- smime_certificate.update!(email_addresses: nil)
- end
- it 'stores correct meta information' do
- migrate
- expect(smime_certificate.reload).to have_attributes(
- email_addresses: smime_object.email_addresses,
- issuer_hash: smime_object.issuer_hash,
- subject_hash: smime_object.subject_hash,
- )
- end
- end
- describe 'migrate smime_certificates with invalid PEM' do
- before do
- smime_certificate.update!(pem: 'invalid')
- end
- it 'stores blank meta information and logs warning', :aggregate_failures do
- allow(Rails.logger).to receive(:warn)
- migrate
- expect(smime_certificate.reload).to have_attributes(
- email_addresses: [],
- issuer_hash: '',
- subject_hash: '',
- )
- message = <<~TEXT.squish
- SMIME: The migration of the certificate with fingerprint #{smime_certificate.fingerprint} failed.
- The certificate might not be usable anymore.
- TEXT
- expect(Rails.logger).to have_received(:warn).with(message)
- end
- end
- end
|