blob: a5d6e01ec9bf44278db881f2a8fde21012b94a6c (
plain)
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
75
76
77
78
79
|
require 'mspec/utils/deprecate'
class RaiseErrorMatcher
def initialize(exception, message, &block)
@exception = exception
@message = message
@block = block
end
def matches?(proc)
@result = proc.call
return false
rescue Exception => @actual
if matching_exception?(@actual)
return true
else
raise @actual
end
end
def matching_exception?(exc)
return false unless @exception === exc
if @message then
case @message
when String
return false if @message != exc.message
when Regexp
return false if @message !~ exc.message
end
end
# The block has its own expectations and will throw an exception if it fails
@block[exc] if @block
return true
end
def exception_class_and_message(exception_class, message)
if message
"#{exception_class} (#{message})"
else
"#{exception_class}"
end
end
def format_expected_exception
exception_class_and_message(@exception, @message)
end
def format_exception(exception)
exception_class_and_message(exception.class, exception.message)
end
def failure_message
message = ["Expected #{format_expected_exception}"]
if @actual then
message << "but got #{format_exception(@actual)}"
else
message << "but no exception was raised (#{@result.pretty_inspect.chomp} was returned)"
end
message
end
def negative_failure_message
message = ["Expected to not get #{format_expected_exception}", ""]
unless @actual.class == @exception
message[1] = "but got #{format_exception(@actual)}"
end
message
end
end
class Object
def raise_error(exception=Exception, message=nil, &block)
RaiseErrorMatcher.new(exception, message, &block)
end
end
|