2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-06-16 01:49:57 +08:00
|
|
|
describe WebHookEvent do
|
|
|
|
let(:event) { WebHookEvent.new(status: 200, web_hook: Fabricate(:web_hook)) }
|
|
|
|
let(:failed_event) { WebHookEvent.new(status: 400, web_hook: Fabricate(:web_hook)) }
|
|
|
|
|
2017-11-08 14:08:30 +08:00
|
|
|
describe '.purge_old' do
|
|
|
|
before do
|
|
|
|
SiteSetting.retain_web_hook_events_period_days = 1
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should be able to purge old web hook events" do
|
|
|
|
web_hook = Fabricate(:web_hook)
|
|
|
|
web_hook_event = WebHookEvent.create!(status: 200, web_hook: web_hook)
|
|
|
|
WebHookEvent.create!(status: 200, web_hook: web_hook, created_at: 2.days.ago)
|
|
|
|
|
|
|
|
expect { described_class.purge_old }
|
|
|
|
.to change { WebHookEvent.count }.by(-1)
|
|
|
|
|
|
|
|
expect(WebHookEvent.find(web_hook_event.id)).to eq(web_hook_event)
|
|
|
|
end
|
2016-06-16 01:49:57 +08:00
|
|
|
end
|
|
|
|
|
2017-11-08 14:08:30 +08:00
|
|
|
describe '#update_web_hook_delivery_status' do
|
|
|
|
it 'update last delivery status for associated WebHook record' do
|
|
|
|
event.update_web_hook_delivery_status
|
|
|
|
|
|
|
|
expect(event.web_hook.last_delivery_status)
|
|
|
|
.to eq(WebHook.last_delivery_statuses[:successful])
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sets last delivery status to failed' do
|
|
|
|
failed_event.update_web_hook_delivery_status
|
|
|
|
|
|
|
|
expect(failed_event.web_hook.last_delivery_status)
|
|
|
|
.to eq(WebHook.last_delivery_statuses[:failed])
|
|
|
|
end
|
2016-06-16 01:49:57 +08:00
|
|
|
end
|
|
|
|
end
|