Został zmodyfikowany z MiniTest docs (w ramach konfigurowalnych trybów testowych).
class Burger
def initialize
puts "YOU CREATED A BURGER"
end
def has_cheese?
true
end
def has_pickle?
false
end
end
gem 'minitest'
require 'minitest/unit'
MiniTest::Unit.autorun
class MyMiniTest
class Unit < MiniTest::Unit
def before_suites
# code to run before the first test
p "Before everything"
end
def after_suites
# code to run after the last test
p "After everything"
end
def _run_suites(suites, type)
begin
before_suites
super(suites, type)
ensure
after_suites
end
end
def _run_suite(suite, type)
begin
suite.before_suite if suite.respond_to?(:before_suite)
super(suite, type)
ensure
suite.after_suite if suite.respond_to?(:after_suite)
end
end
end
end
MiniTest::Unit.runner = MyMiniTest::Unit.new
class BurgerTest < MiniTest::Unit::TestCase
def self.before_suite
p "hi"
end
def self.after_suite
p "bye"
end
def setup
@burger = Burger.new
end
def test_has_cheese
assert_equal true, @burger.has_cheese?
end
def test_has_pickle
assert_equal false, @burger.has_pickle?
end
end
pamiętać, że włączyłem używać gem zamiast wersji pakietowej, które nie mają metodę MiniTest::Unit.runner
. Oto wynik.
Run options: --seed 49053
# Running tests:
"Before everything"
"hi"
YOU CREATED A BURGER
.YOU CREATED A BURGER
."bye"
"After everything"
Finished tests in 0.000662s, 3021.1480 tests/s, 3021.1480 assertions/s.
2 tests, 2 assertions, 0 failures, 0 errors, 0 skips
Tak nazywa to #setup
dwa razy, ale .before_suite
i .after_suite
tylko raz, co jest to, czego szukasz myślę.
D'oh! Całkowicie brakowało tego w dokumentach. Dzięki! –
Niestety w wersji 5 runner został usunięty ... Przypuszczam, że wyjaśnia on, dlaczego minitest ma tak wiele rozwidleń, wystarczy go załatać, zanim zadziała ... – nus