mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Cleanup harness some
This commit is contained in:
parent
02b98ea61b
commit
ff5d855389
1 changed files with 37 additions and 22 deletions
|
@ -6,7 +6,6 @@ require "./result"
|
||||||
|
|
||||||
module Spectator
|
module Spectator
|
||||||
# Helper class that acts as a gateway between test code and the framework.
|
# Helper class that acts as a gateway between test code and the framework.
|
||||||
# This is essentially an "example runner."
|
|
||||||
#
|
#
|
||||||
# Test code should be wrapped with a call to `.run`.
|
# Test code should be wrapped with a call to `.run`.
|
||||||
# This class will catch all errors raised by the test code.
|
# This class will catch all errors raised by the test code.
|
||||||
|
@ -44,12 +43,23 @@ module Spectator
|
||||||
# It will be reset after the test regardless of the outcome.
|
# It will be reset after the test regardless of the outcome.
|
||||||
# The result of running the test code will be returned.
|
# The result of running the test code will be returned.
|
||||||
def self.run : Result
|
def self.run : Result
|
||||||
harness = new
|
with_harness do |harness|
|
||||||
|
harness.run { yield }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# Instanciates a new harness and yields it.
|
||||||
|
# The `.current` harness is set to the new harness for the duration of the block.
|
||||||
|
# `.current` is reset to the previous value (probably nil) afterwards, even if the block raises.
|
||||||
|
# The result of the block is returned.
|
||||||
|
private def self.with_harness
|
||||||
previous = @@current
|
previous = @@current
|
||||||
@@current = harness
|
begin
|
||||||
result = harness.run { yield }
|
harness = new
|
||||||
|
yield harness
|
||||||
|
ensure
|
||||||
@@current = previous
|
@@current = previous
|
||||||
result
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@deferred = Deque(->).new
|
@deferred = Deque(->).new
|
||||||
|
@ -59,14 +69,17 @@ module Spectator
|
||||||
# The test code should be called from within the block given to this method.
|
# The test code should be called from within the block given to this method.
|
||||||
def run : Result
|
def run : Result
|
||||||
elapsed, error = capture { yield }
|
elapsed, error = capture { yield }
|
||||||
elapsed2, error2 = run_deferred
|
elapsed2, error2 = capture { run_deferred }
|
||||||
translate(elapsed + elapsed2, error || error2)
|
translate(elapsed + elapsed2, error || error2)
|
||||||
end
|
end
|
||||||
|
|
||||||
def report(expectation : Expectation) : Nil
|
def report(expectation : Expectation) : Nil
|
||||||
Log.debug { "Reporting expectation #{expectation}" }
|
Log.debug { "Reporting expectation #{expectation}" }
|
||||||
@expectations << expectation
|
@expectations << expectation
|
||||||
|
|
||||||
|
# TODO: Move this out of harness, maybe to `Example`.
|
||||||
Example.current.name = expectation.description unless Example.current.name?
|
Example.current.name = expectation.description unless Example.current.name?
|
||||||
|
|
||||||
raise ExpectationFailed.new(expectation) if expectation.failed?
|
raise ExpectationFailed.new(expectation) if expectation.failed?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -78,18 +91,25 @@ module Spectator
|
||||||
|
|
||||||
# Yields to run the test code and returns information about the outcome.
|
# Yields to run the test code and returns information about the outcome.
|
||||||
# Returns a tuple with the elapsed time and an error if one occurred (otherwise nil).
|
# Returns a tuple with the elapsed time and an error if one occurred (otherwise nil).
|
||||||
private def capture
|
private def capture : Tuple(Time, Exception?)
|
||||||
error = nil.as(Exception?)
|
error = nil
|
||||||
elapsed = Time.measure do
|
elapsed = Time.measure do
|
||||||
begin
|
error = catch_error { yield }
|
||||||
yield
|
|
||||||
rescue e
|
|
||||||
error = e
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
{elapsed, error}
|
{elapsed, error}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Yields to run a block of code and captures exceptions.
|
||||||
|
# If the block of code raises an error, the error is caught and returned.
|
||||||
|
# If the block doesn't raise an error, then nil is returned.
|
||||||
|
private def catch : Exception?
|
||||||
|
yield
|
||||||
|
rescue e
|
||||||
|
e
|
||||||
|
else
|
||||||
|
nil
|
||||||
|
end
|
||||||
|
|
||||||
# Translates the outcome of running a test to a result.
|
# Translates the outcome of running a test to a result.
|
||||||
# Takes the *elapsed* time and a possible *error* from the test.
|
# Takes the *elapsed* time and a possible *error* from the test.
|
||||||
# Returns a type of `Result`.
|
# Returns a type of `Result`.
|
||||||
|
@ -105,16 +125,11 @@ module Spectator
|
||||||
end
|
end
|
||||||
|
|
||||||
# Runs all deferred blocks.
|
# Runs all deferred blocks.
|
||||||
|
# This method executes code from tests and may raise an error.
|
||||||
|
# It should be wrapped in a call to `#capture`.
|
||||||
private def run_deferred
|
private def run_deferred
|
||||||
Log.debug { "Running deferred operations" }
|
Log.debug { "Running deferred operations" }
|
||||||
error = nil.as(Exception?)
|
|
||||||
elapsed = Time.measure do
|
|
||||||
@deferred.each(&.call)
|
@deferred.each(&.call)
|
||||||
rescue ex
|
|
||||||
error = ex
|
|
||||||
end
|
|
||||||
@deferred.clear
|
|
||||||
{elapsed, error}
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue