uh-wm/spec/uh/wm/dispatcher_spec.rb
2015-04-21 12:12:20 +00:00

77 lines
2.4 KiB
Ruby

module Uh
module WM
RSpec.describe Dispatcher do
subject(:dispatcher) { described_class.new }
describe '#[]' do
context 'when given key for existing hook' do
before { dispatcher.hooks[:hook_key] = [:hook] }
it 'returns registered hooks for this key' do
expect(dispatcher[:hook_key]).to eq [:hook]
end
end
context 'when given multiple keys for existing hook' do
before { dispatcher.hooks[%i[hook key]] = [:hook] }
it 'returns registered hooks for this key' do
expect(dispatcher[:hook, :key]).to eq [:hook]
end
end
context 'when given key for unknown hook' do
it 'returns an empty array' do
expect(dispatcher[:unknown_hook]).to eq []
end
end
end
describe '#on' do
it 'registers given hook for given key' do
dispatcher.on(:hook_key) { :hook }
expect(dispatcher.hooks[:hook_key]).to be
end
it 'registers given hook for given multiple keys' do
dispatcher.on(:hook, :key) { :hook }
expect(dispatcher.hooks[%i[hook key]]).to be
end
end
describe '#emit' do
it 'calls hooks registered for given key' do
dispatcher.on(:hook_key) { throw :hook_code }
expect { dispatcher.emit :hook_key }.to throw_symbol :hook_code
end
it 'returns the value returned by a registered hook' do
dispatcher.on(:hook_key) { :hook_code }
expect(dispatcher.emit :hook_key).to eq :hook_code
end
context 'when no hooks are registered for given key' do
it 'does not call another hook' do
dispatcher.on(:hook_key) { throw :hook_code }
expect { dispatcher.emit :other_hook_key }.not_to throw_symbol
end
end
context 'when no hooks are registered at all' do
it 'does not raise any error' do
expect { dispatcher.emit :hook_key }.not_to raise_error
end
end
context 'when args keyword argument is given' do
it 'calls hooks with given args' do
dispatcher.on(:hook_key) { |arg1, arg2| throw arg2 }
expect { dispatcher.emit :hook_key, args: %i[arg1 arg2] }
.to throw_symbol :arg2
end
end
end
end
end
end