2020-04-08 14:13:33 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2023-05-27 22:25:52 +05:30
|
|
|
RSpec.describe X509CertificateRevokeService, feature_category: :system_access do
|
2020-04-08 14:13:33 +05:30
|
|
|
describe '#execute' do
|
|
|
|
let(:service) { described_class.new }
|
2023-01-13 00:05:48 +05:30
|
|
|
let!(:x509_signature_1) { create(:x509_commit_signature, x509_certificate: x509_certificate, verification_status: :verified) }
|
|
|
|
let!(:x509_signature_2) { create(:x509_commit_signature, x509_certificate: x509_certificate, verification_status: :verified) }
|
2020-04-08 14:13:33 +05:30
|
|
|
|
|
|
|
context 'for revoked certificates' do
|
2023-01-13 00:05:48 +05:30
|
|
|
let(:x509_certificate) { create(:x509_certificate, certificate_status: :revoked) }
|
2020-04-08 14:13:33 +05:30
|
|
|
|
|
|
|
it 'update all commit signatures' do
|
|
|
|
expect do
|
|
|
|
service.execute(x509_certificate)
|
|
|
|
|
|
|
|
x509_signature_1.reload
|
|
|
|
x509_signature_2.reload
|
|
|
|
end
|
|
|
|
.to change(x509_signature_1, :verification_status).from('verified').to('unverified')
|
|
|
|
.and change(x509_signature_2, :verification_status).from('verified').to('unverified')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'for good certificates' do
|
|
|
|
let(:x509_certificate) { create(:x509_certificate) }
|
|
|
|
|
|
|
|
it 'do not update any commit signature' do
|
|
|
|
expect do
|
|
|
|
service.execute(x509_certificate)
|
|
|
|
|
|
|
|
x509_signature_1.reload
|
|
|
|
x509_signature_2.reload
|
|
|
|
end
|
|
|
|
.to not_change(x509_signature_1, :verification_status)
|
|
|
|
.and not_change(x509_signature_2, :verification_status)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|