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
80
|
# frozen_string_literal: true
require "abstract_unit"
class ActionableExceptionsTest < ActionDispatch::IntegrationTest
Actions = []
class ActionError < StandardError
include ActiveSupport::ActionableError
action "Successful action" do
Actions << "Action!"
end
action "Failed action" do
raise "Inaction!"
end
end
Noop = -> env { [200, {}, [""]] }
setup do
@app = ActionDispatch::ActionableExceptions.new(Noop)
Actions.clear
end
test "dispatches an actionable error" do
post ActionDispatch::ActionableExceptions.endpoint, params: {
error: ActionError.name,
action: "Successful action",
location: "/",
}
assert_equal ["Action!"], Actions
assert_equal 302, response.status
assert_equal "/", response.headers["Location"]
end
test "cannot dispatch errors if not allowed" do
post ActionDispatch::ActionableExceptions.endpoint, params: {
error: ActionError.name,
action: "Successful action",
location: "/",
}, headers: { "action_dispatch.show_exceptions" => false }
assert_empty Actions
end
test "dispatched action can fail" do
assert_raise RuntimeError do
post ActionDispatch::ActionableExceptions.endpoint, params: {
error: ActionError.name,
action: "Failed action",
location: "/",
}
end
end
test "cannot dispatch non-actionable errors" do
assert_raise ActiveSupport::ActionableError::NonActionable do
post ActionDispatch::ActionableExceptions.endpoint, params: {
error: RuntimeError.name,
action: "Inexistent action",
location: "/",
}
end
end
test "cannot dispatch Inexistent errors" do
assert_raise ActiveSupport::ActionableError::NonActionable do
post ActionDispatch::ActionableExceptions.endpoint, params: {
error: "",
action: "Inexistent action",
location: "/",
}
end
end
end
|