Skip to content

Commit

Permalink
Merge pull request #385 from guard/backport_383_fix_transition_to_sto…
Browse files Browse the repository at this point in the history
…pped

backport #383
  • Loading branch information
e2 committed Apr 30, 2016
2 parents 2b60237 + d0ce6c6 commit 01a028a
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 20 deletions.
4 changes: 2 additions & 2 deletions lib/listen/listener.rb
Original file line number Diff line number Diff line change
Expand Up @@ -63,11 +63,11 @@ def initialize(*dirs, &block)

state :initializing, to: :backend_started

state :backend_started, to: [:frontend_ready] do
state :backend_started, to: [:frontend_ready, :stopped] do
backend.start
end

state :frontend_ready, to: [:processing_events] do
state :frontend_ready, to: [:processing_events, :stopped] do
processor.setup
end

Expand Down
53 changes: 35 additions & 18 deletions spec/lib/listen/listener_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -137,13 +137,43 @@
allow(backend).to receive(:start)
allow(processor).to receive(:setup)
allow(processor).to receive(:resume)
subject.start
end

it 'terminates' do
allow(backend).to receive(:stop)
allow(processor).to receive(:teardown)
subject.stop
context 'when fully started' do
before do
subject.start
end

it 'terminates' do
allow(backend).to receive(:stop)
allow(processor).to receive(:teardown)
subject.stop
end
end

context 'when frontend is ready' do
before do
subject.transition :backend_started
subject.transition :frontend_ready
end

it 'terminates' do
allow(backend).to receive(:stop)
allow(processor).to receive(:teardown)
subject.stop
end
end

context 'when only backend is already started' do
before do
subject.transition :backend_started
end

it 'terminates' do
allow(backend).to receive(:stop)
allow(processor).to receive(:teardown)
subject.stop
end
end
end

Expand Down Expand Up @@ -304,17 +334,4 @@
end
end
end

describe 'processing changes' do
before do
allow(backend).to receive(:start)
end
end

context 'when listener is stopped' do
before do
subject.stop
allow(silencer).to receive(:silenced?) { true }
end
end
end

0 comments on commit 01a028a

Please sign in to comment.