mirror of
https://github.com/discourse/discourse.git
synced 2024-11-30 12:13:43 +08:00
c9dab6fd08
It's very easy to forget to add `require 'rails_helper'` at the top of every core/plugin spec file, and omissions can cause some very confusing/sporadic errors. By setting this flag in `.rspec`, we can remove the need for `require 'rails_helper'` entirely.
40 lines
1.3 KiB
Ruby
40 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
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)) }
|
|
|
|
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
|
|
end
|
|
|
|
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
|
|
end
|
|
end
|