free_mutant/lib/mutant/isolation.rb
2014-08-11 15:11:22 +00:00

49 lines
1 KiB
Ruby

module Mutant
# Module providing isolation
module Isolation
Error = Class.new(RuntimeError)
module None
# Call block in isolation
#
# @return [Object]
#
# @raise [Error]
# if block terminates abnormal
#
# @api private
#
def self.call(&block)
block.call
rescue => exception
fail Error, exception
end
end
module Fork
# Call block in isolation
#
# This isolation implements the fork strategy.
# Future strategies will probably use a process pool that can
# handle multiple mutation kills, in-isolation at once.
#
# @return [Object]
# returns block execution result
#
# @raise [Error]
# if block terminates abnormal
#
# @api private
#
def self.call(&block)
Parallel.map([block], in_processes: 1, &block.method(:call)).first
rescue Parallel::DeadWorker => exception
fail Error, exception
end
end # Fork
end # Isolator
end # Mutant