discourse/spec/lib/discourse_event_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

106 lines
2.3 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
RSpec.describe DiscourseEvent do
2013-02-05 13:16:51 -06:00
2013-02-12 22:45:10 -06:00
describe "#events" do
it "defaults to {}" do
2016-09-05 05:14:28 -05:00
begin
original_events = DiscourseEvent.events
DiscourseEvent.instance_variable_set(:@events, nil)
expect(DiscourseEvent.events).to eq({})
ensure
DiscourseEvent.instance_variable_set(:@events, original_events)
end
2013-02-12 22:45:10 -06:00
end
describe "key value" do
it "defaults to an empty set" do
2015-01-09 10:34:37 -06:00
expect(DiscourseEvent.events["event42"]).to eq(Set.new)
2013-02-12 22:45:10 -06:00
end
end
end
context 'when calling events' do
2013-02-05 13:16:51 -06:00
2013-02-12 22:45:10 -06:00
let(:harvey) {
OpenStruct.new(
name: 'Harvey Dent',
job: 'District Attorney'
)
}
2013-02-05 13:16:51 -06:00
let(:event_handler) do
Proc.new { |user| user.name = 'Two Face' }
end
2013-02-05 13:16:51 -06:00
before do
DiscourseEvent.on(:acid_face, &event_handler)
end
after do
DiscourseEvent.off(:acid_face, &event_handler)
2013-02-05 13:16:51 -06:00
end
2013-02-12 22:45:10 -06:00
context 'when event does not exist' do
it "does not raise an error" do
DiscourseEvent.trigger(:missing_event)
end
2013-02-05 13:16:51 -06:00
end
2013-02-12 22:45:10 -06:00
context 'when single event exists' do
it "doesn't raise an error" do
DiscourseEvent.trigger(:acid_face, harvey)
end
it "changes the name" do
DiscourseEvent.trigger(:acid_face, harvey)
2015-01-09 10:34:37 -06:00
expect(harvey.name).to eq('Two Face')
2013-02-12 22:45:10 -06:00
end
2013-02-05 13:16:51 -06:00
end
2013-02-12 22:45:10 -06:00
context 'when multiple events exist' do
let(:event_handler_2) do
Proc.new { |user| user.job = 'Supervillain' }
end
2013-02-12 22:45:10 -06:00
before do
DiscourseEvent.on(:acid_face, &event_handler_2)
2013-02-05 13:16:51 -06:00
DiscourseEvent.trigger(:acid_face, harvey)
end
after do
DiscourseEvent.off(:acid_face, &event_handler_2)
end
2013-02-12 22:45:10 -06:00
it 'triggers both events' do
expect(harvey.job).to eq('Supervillain')
2015-01-09 10:34:37 -06:00
expect(harvey.name).to eq('Two Face')
2013-02-05 13:16:51 -06:00
end
end
describe '#all_off' do
let(:event_handler_2) do
Proc.new { |user| user.job = 'Supervillain' }
end
before do
DiscourseEvent.on(:acid_face, &event_handler_2)
end
2013-02-05 13:16:51 -06:00
it 'removes all handlers with a key' do
harvey.job = 'gardening'
DiscourseEvent.all_off(:acid_face)
DiscourseEvent.trigger(:acid_face, harvey) # Doesn't change anything
expect(harvey.job).to eq('gardening')
end
end
end
2013-02-05 13:16:51 -06:00
end