Fix for default logger being cleaned up before Spectator runs

Resolves https://github.com/icy-arctic-fox/spectator/issues/27
This commit is contained in:
Michael Miller 2021-05-27 15:17:27 -06:00
parent 55398709de
commit edb18dcf95
No known key found for this signature in database
GPG key ID: FB9F12F7C646A4AD

View file

@ -98,8 +98,21 @@ module Spectator
config.random config.random
end end
# Trick for detecting if a constant is defined.
# Includes the block of code if the *constant* is defined.
private macro on_defined(constant)
{% if constant.resolve? %}
{{yield}}
{% end %}
end
# Builds the tests and runs the framework. # Builds the tests and runs the framework.
private def run private def run
# Silence default logger, only if it's used somewhere in the program.
on_defined(::Log) do
::Log.setup_from_env(default_level: :none)
end
# Build the test suite and run it. # Build the test suite and run it.
suite = ::Spectator::SpecBuilder.build(config.example_filter) suite = ::Spectator::SpecBuilder.build(config.example_filter)
Runner.new(suite, config).run Runner.new(suite, config).run