mirror of https://github.com/docusealco/docuseal
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
91 lines
3.2 KiB
91 lines
3.2 KiB
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe SendTemplateUpdatedWebhookRequestJob do
|
|
let(:account) { create(:account) }
|
|
let(:user) { create(:user, account:) }
|
|
let(:template) { create(:template, account:, author: user) }
|
|
let(:webhook_url) { create(:webhook_url, account:, events: ['template.updated']) }
|
|
|
|
before do
|
|
create(:encrypted_config, key: EncryptedConfig::ESIGN_CERTS_KEY,
|
|
value: GenerateCertificate.call.transform_values(&:to_pem))
|
|
end
|
|
|
|
describe '#perform' do
|
|
before do
|
|
stub_request(:post, webhook_url.url).to_return(status: 200)
|
|
end
|
|
|
|
it 'sends a webhook request' do
|
|
described_class.new.perform('template_id' => template.id, 'webhook_url_id' => webhook_url.id)
|
|
|
|
expect(WebMock).to have_requested(:post, webhook_url.url).with(
|
|
body: replace_timestamps({
|
|
'event_type' => 'template.updated',
|
|
'timestamp' => Time.current,
|
|
'data' => Templates::SerializeForApi.call(template.reload)
|
|
}.deep_stringify_keys),
|
|
headers: {
|
|
'Content-Type' => 'application/json',
|
|
'User-Agent' => 'DocuSeal.co Webhook'
|
|
}
|
|
).once
|
|
end
|
|
|
|
it 'sends a webhook request with the secret' do
|
|
webhook_url.update(secret: { 'X-Secret-Header' => 'secret_value' })
|
|
described_class.new.perform('template_id' => template.id, 'webhook_url_id' => webhook_url.id)
|
|
|
|
expect(WebMock).to have_requested(:post, webhook_url.url).with(
|
|
body: replace_timestamps({
|
|
'event_type' => 'template.updated',
|
|
'timestamp' => Time.current,
|
|
'data' => Templates::SerializeForApi.call(template.reload)
|
|
}.deep_stringify_keys),
|
|
headers: {
|
|
'Content-Type' => 'application/json',
|
|
'User-Agent' => 'DocuSeal.co Webhook',
|
|
'X-Secret-Header' => 'secret_value'
|
|
}
|
|
).once
|
|
end
|
|
|
|
it "doesn't send a webhook request if the event is not in the webhook's events" do
|
|
webhook_url.update!(events: ['template.created'])
|
|
|
|
described_class.new.perform('template_id' => template.id, 'webhook_url_id' => webhook_url.id)
|
|
|
|
expect(WebMock).not_to have_requested(:post, webhook_url.url)
|
|
end
|
|
|
|
it 'sends again if the response status is 400 or higher' do
|
|
stub_request(:post, webhook_url.url).to_return(status: 401)
|
|
|
|
expect do
|
|
described_class.new.perform('template_id' => template.id, 'webhook_url_id' => webhook_url.id)
|
|
end.to change(described_class.jobs, :size).by(1)
|
|
|
|
expect(WebMock).to have_requested(:post, webhook_url.url).once
|
|
|
|
args = described_class.jobs.last['args'].first
|
|
|
|
expect(args['attempt']).to eq(1)
|
|
expect(args['last_status']).to eq(401)
|
|
expect(args['webhook_url_id']).to eq(webhook_url.id)
|
|
expect(args['template_id']).to eq(template.id)
|
|
end
|
|
|
|
it "doesn't send again if the max attempts is reached" do
|
|
stub_request(:post, webhook_url.url).to_return(status: 401)
|
|
|
|
expect do
|
|
described_class.new.perform('template_id' => template.id, 'webhook_url_id' => webhook_url.id, 'attempt' => 11)
|
|
end.not_to change(described_class.jobs, :size)
|
|
|
|
expect(WebMock).to have_requested(:post, webhook_url.url).once
|
|
end
|
|
end
|
|
end
|