Module: Async::RSpec::Reactor

Defined in:
lib/async/rspec/reactor.rb

Instance Method Summary collapse

Instance Method Details

#notify_failure(exception = $!) ⇒ Object



31
32
33
# File 'lib/async/rspec/reactor.rb', line 31

def notify_failure(exception = $!)
	::RSpec::Support.notify_failure(exception)
end

#run_in_reactor(reactor, duration = nil) ⇒ Object



35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
# File 'lib/async/rspec/reactor.rb', line 35

def run_in_reactor(reactor, duration = nil)
	result = nil
	timer_task = nil
	
	if duration
		timer_task = reactor.async do |task|
			# Wait for the timeout, at any point this task might be cancelled if the user code completes:
			task.annotate("Timer task duration=#{duration}.")
			task.sleep(duration)
			
			# The timeout expired, so generate an error:
			buffer = StringIO.new
			reactor.print_hierarchy(buffer)
			
			# Raise an error so it is logged:
			raise TimeoutError, "Run time exceeded duration #{duration}s:\n#{buffer.string}"
		end
	end
	
	spec_task = reactor.async do |spec_task|
		spec_task.annotate("running example")
		
		result = yield(spec_task)
		
		# We are finished, so stop the timer task if it was started:
		timer_task&.stop
		
		# Now stop the entire reactor:
		raise Async::Stop
	end
	
	begin
		timer_task&.wait
		spec_task.wait
	ensure
		spec_task.stop
	end
	
	return result
end