49 lines
1 KiB
Ruby
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
|