uh-wm/spec/uh/wm/runner_spec.rb
2015-04-22 08:14:45 +00:00

192 lines
5.7 KiB
Ruby

SomeLayout = Class.new do
include Factories
define_method(:register) { |*_| }
define_method(:suggest_geo) { build_geo 0, 0, 42, 42 }
define_method(:<<) { |*_| }
define_method(:remove) { |*_| }
define_method(:update) { |*_| }
end
module Uh
module WM
RSpec.describe Runner do
let(:env) { Env.new(StringIO.new) }
subject(:runner) { described_class.new env }
before do
env.layout_class = SomeLayout
env.rc_path = 'non_existent_run_control.rb'
end
it 'has a dispatcher' do
expect(runner.events).to be_a Dispatcher
end
it 'is not stopped' do
expect(runner).not_to be_stopped
end
describe '#stopped?' do
context 'when not stopped' do
it 'returns false' do
expect(runner.stopped?).to be false
end
end
context 'when stopped' do
before { runner.stop! }
it 'returns true' do
expect(runner.stopped?).to be true
end
end
end
describe '#stop!' do
it 'sets the runner as stopped' do
expect { runner.stop! }
.to change { runner.stopped? }
.from(false).to(true)
end
end
describe '#manager' do
it 'returns the manager' do
expect(runner.manager).to be_a Manager
end
it 'sets the manager modifier as env modifier' do
expect(runner.manager.modifier).to eq env.modifier
end
end
describe '#evaluate_run_control' do
it 'evaluates the run control file with RunControl and current env' do
expect(RunControl).to receive(:evaluate).with env
runner.evaluate_run_control
end
end
describe '#register_event_hooks' do
it 'registers quit event hook' do
runner.register_event_hooks
expect(runner).to receive :stop!
runner.events.emit :quit
end
context 'layout hooks' do
it 'registers for :connected event' do
runner.register_event_hooks
expect(env.layout).to receive(:register).with :display
runner.events.emit :connected, args: :display
end
it 'registers for :configure event' do
runner.register_event_hooks
expect(runner.events.emit :configure, args: :window)
.to eq build_geo 0, 0, 42, 42
end
it 'registers for :manage event' do
runner.register_event_hooks
expect(env.layout).to receive(:<<).with :client
runner.events.emit :manage, args: :client
end
it 'registers for :unmanage event' do
runner.register_event_hooks
expect(env.layout).to receive(:remove).with :client
runner.events.emit :unmanage, args: :client
end
it 'registers for :change event' do
runner.register_event_hooks
expect(env.layout).to receive(:update).with :client
runner.events.emit :change, args: :client
end
end
context 'keys hooks' do
it 'registers for :key' do
env.keybinds[:f] = -> { }
runner.register_event_hooks
expect(runner.events[:key, :f]).not_to be_empty
end
it 'registers for :key with combined key bindings' do
env.keybinds[[:f, :shift]] = -> { }
runner.register_event_hooks
expect(runner.events[:key, :f, :shift]).not_to be_empty
end
it 'registers code evaluation with the actions handler' do
env.keybinds[:f] = code = proc { }
runner.register_event_hooks
expect(runner.actions).to receive(:evaluate).with code
runner.events.emit :key, :f
end
end
end
describe '#connect_manager' do
let(:manager) { instance_spy Manager }
subject(:runner) { described_class.new env, manager: manager }
it 'connects the manager' do
expect(runner.manager).to receive :connect
runner.connect_manager
end
it 'tells the manager to grab keys for env key bindings' do
env.keybinds[:f] = -> { }
expect(runner.manager).to receive(:grab_key).with :f
runner.connect_manager
end
end
describe '#worker' do
it 'returns a worker' do
expect(runner.worker).to respond_to :work_events
end
it 'setups the read callback to tell manager to handle pending events' do
expect(runner.manager).to receive :handle_pending_events
runner.worker.on_read.call
end
it 'setups the read_next callback to tell manager to handle next event' do
expect(runner.manager).to receive :handle_next_event
runner.worker.on_read_next.call
end
it 'setups the timeout callback to tell manager to flush the output' do
expect(runner.manager).to receive :flush
runner.worker.on_timeout.call
end
end
describe '#run_until' do
it 'tells the worker to watch the manager' do
expect(runner.worker).to receive(:watch).with runner.manager
runner.run_until { true }
end
it 'tells the worker to work events until given block is true' do
block = proc { }
allow(block).to receive(:call).and_return(false, false, false, true)
expect(runner.worker).to receive(:work_events).exactly(3).times
runner.run_until &block
end
end
describe '#terminate' do
it 'tells the manager to disconnect' do
expect(runner.manager).to receive :disconnect
runner.terminate
end
end
end
end
end