Class: JUnitFormatter
Instance Attribute Summary
#exceptions, #tally, #timer
Instance Method Summary
collapse
#switch
#abort, #before, #exception?, #failure?, #print, #register
Constructor Details
6
7
8
9
|
# File 'lib/mspec/runner/formatters/junit.rb', line 6
def initialize(out=nil)
super
@tests = []
end
|
Instance Method Details
#after(state = nil) ⇒ Object
11
12
13
14
|
# File 'lib/mspec/runner/formatters/junit.rb', line 11
def after(state = nil)
super
@tests << {:test => state, :exception => false} unless exception?
end
|
#exception(exception) ⇒ Object
16
17
18
19
|
# File 'lib/mspec/runner/formatters/junit.rb', line 16
def exception(exception)
super
@tests << {:test => exception, :exception => true}
end
|
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
# File 'lib/mspec/runner/formatters/junit.rb', line 21
def finish
switch
time = @timer.elapsed
tests = @tally.counter.examples
errors = @tally.counter.errors
failures = @tally.counter.failures
printf "\n<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n <testsuites\n testCount=\"\#{tests}\"\n errorCount=\"\#{errors}\"\n failureCount=\"\#{failures}\"\n timeCount=\"\#{time}\" time=\"\#{time}\">\n <testsuite\n tests=\"\#{tests}\"\n errors=\"\#{errors}\"\n failures=\"\#{failures}\"\n time=\"\#{time}\"\n name=\"Spec Output For \#{::RUBY_NAME} (\#{::RUBY_VERSION})\">\n XML\n @tests.each do |h|\n description = encode_for_xml h[:test].description\n\n printf <<-XML, \"Spec\", description, 0.0\n <testcase classname=\"%s\" name=\"%s\" time=\"%f\">\n XML\n if h[:exception]\n outcome = h[:test].failure? ? \"failure\" : \"error\"\n message = encode_for_xml h[:test].message\n backtrace = encode_for_xml h[:test].backtrace\n print <<-XML\n <\#{outcome} message=\"error in \#{description}\" type=\"\#{outcome}\">\n \#{message}\n \#{backtrace}\n </\#{outcome}>\n XML\n end\n print <<-XML\n </testcase>\n XML\n end\n\n print <<-XML\n </testsuite>\n </testsuites>\n XML\nend\n"
|