diff options
Diffstat (limited to 'spec/services/pages_domains/retry_acme_order_service_spec.rb')
-rw-r--r-- | spec/services/pages_domains/retry_acme_order_service_spec.rb | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/spec/services/pages_domains/retry_acme_order_service_spec.rb b/spec/services/pages_domains/retry_acme_order_service_spec.rb new file mode 100644 index 00000000000..0185f10864c --- /dev/null +++ b/spec/services/pages_domains/retry_acme_order_service_spec.rb @@ -0,0 +1,37 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe PagesDomains::RetryAcmeOrderService do + let(:domain) { create(:pages_domain, auto_ssl_enabled: true, auto_ssl_failed: true) } + + let(:service) { described_class.new(domain) } + + it 'clears auto_ssl_failed' do + expect do + service.execute + end.to change { domain.auto_ssl_failed }.from(true).to(false) + end + + it 'schedules renewal worker' do + expect(PagesDomainSslRenewalWorker).to receive(:perform_async).with(domain.id).and_return(nil).once + + service.execute + end + + it "doesn't schedule renewal worker if Let's Encrypt integration is not enabled" do + domain.update!(auto_ssl_enabled: false) + + expect(PagesDomainSslRenewalWorker).not_to receive(:new) + + service.execute + end + + it "doesn't schedule renewal worker if auto ssl has not failed yet" do + domain.update!(auto_ssl_failed: false) + + expect(PagesDomainSslRenewalWorker).not_to receive(:new) + + service.execute + end +end |