1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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
71
72
73
74
|
require File.dirname(__FILE__) + '/../../spec_helper'
require 'mspec/runner/formatters/unit'
require 'mspec/runner/example'
require 'mspec/utils/script'
describe UnitdiffFormatter, "#finish" do
before :each do
@tally = double("tally").as_null_object
TallyAction.stub(:new).and_return(@tally)
@timer = double("timer").as_null_object
TimerAction.stub(:new).and_return(@timer)
$stdout = @out = IOStub.new
context = ContextState.new "describe"
@state = ExampleState.new(context, "it")
MSpec.stub(:register)
@formatter = UnitdiffFormatter.new
@formatter.register
end
after :each do
$stdout = STDOUT
end
it "prints a failure message for an exception" do
exc = ExceptionState.new @state, nil, MSpecExampleError.new("broken")
@formatter.exception exc
@formatter.after @state
@formatter.finish
@out.should =~ /^1\)\ndescribe it ERROR$/
end
it "prints a backtrace for an exception" do
exc = ExceptionState.new @state, nil, Exception.new("broken")
exc.stub(:backtrace).and_return("path/to/some/file.rb:35:in method")
@formatter.exception exc
@formatter.finish
@out.should =~ %r[path/to/some/file.rb:35:in method$]
end
it "prints a summary of elapsed time" do
@timer.should_receive(:format).and_return("Finished in 2.0 seconds")
@formatter.finish
@out.should =~ /^Finished in 2.0 seconds$/
end
it "prints a tally of counts" do
@tally.should_receive(:format).and_return("1 example, 0 failures")
@formatter.finish
@out.should =~ /^1 example, 0 failures$/
end
it "prints errors, backtraces, elapsed time, and tallies" do
exc = ExceptionState.new @state, nil, Exception.new("broken")
exc.stub(:backtrace).and_return("path/to/some/file.rb:35:in method")
@formatter.exception exc
@formatter.after @state
@timer.should_receive(:format).and_return("Finished in 2.0 seconds")
@tally.should_receive(:format).and_return("1 example, 0 failures")
@formatter.finish
@out.should ==
%[E
Finished in 2.0 seconds
1)
describe it ERROR
Exception: broken:
path/to/some/file.rb:35:in method
1 example, 0 failures
]
end
end
|