1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/railties/test/test_unit/reporter_test.rb

75 lines
1.8 KiB
Ruby
Raw Normal View History

2015-01-24 05:41:33 -05:00
require 'abstract_unit'
require 'rails/test_unit/reporter'
class TestUnitReporterTest < ActiveSupport::TestCase
class ExampleTest < Minitest::Test
def woot; end
end
setup do
@output = StringIO.new
@reporter = Rails::TestUnitReporter.new @output
end
test "prints rerun snippet to run a single failed test" do
2015-02-03 21:54:50 -05:00
@reporter.record(failed_test)
2015-01-24 05:41:33 -05:00
@reporter.report
assert_match %r{^bin/rails test .*test/test_unit/reporter_test.rb:6$}, @output.string
assert_rerun_snippet_count 1
end
test "prints rerun snippet for every failed test" do
2015-02-03 21:54:50 -05:00
@reporter.record(failed_test)
@reporter.record(failed_test)
@reporter.record(failed_test)
2015-01-24 05:41:33 -05:00
@reporter.report
assert_rerun_snippet_count 3
end
test "does not print snippet for successful and skipped tests" do
2015-02-03 21:54:50 -05:00
@reporter.record(passing_test)
@reporter.record(skipped_test)
2015-01-24 05:41:33 -05:00
@reporter.report
assert_rerun_snippet_count 0
end
test "prints rerun snippet for skipped tests if run in verbose mode" do
verbose = Rails::TestUnitReporter.new @output, verbose: true
2015-02-03 21:54:50 -05:00
verbose.record(skipped_test)
2015-01-24 05:41:33 -05:00
verbose.report
assert_rerun_snippet_count 1
end
private
def assert_rerun_snippet_count(snippet_count)
assert_equal snippet_count, @output.string.scan(%r{^bin/rails test }).size
end
def failed_test
ft = ExampleTest.new(:woot)
ft.failures << begin
raise Minitest::Assertion, "boo"
rescue Minitest::Assertion => e
e
end
ft
end
def passing_test
ExampleTest.new(:woot)
end
def skipped_test
st = ExampleTest.new(:woot)
st.failures << begin
raise Minitest::Skip
rescue Minitest::Assertion => e
e
end
st
end
end