Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
d3dd3847
R
rails
项目概览
张重言
/
rails
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rails
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d3dd3847
编写于
12月 12, 2015
作者:
M
Maxime Garcia
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Don't catch all NameError to reraise as ActionController::RoutingError #22368
上级
eb0e8e21
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
45 addition
and
2 deletion
+45
-2
actionpack/lib/action_dispatch/routing/route_set.rb
actionpack/lib/action_dispatch/routing/route_set.rb
+4
-2
actionpack/test/dispatch/routing_test.rb
actionpack/test/dispatch/routing_test.rb
+41
-0
未找到文件。
actionpack/lib/action_dispatch/routing/route_set.rb
浏览文件 @
d3dd3847
...
...
@@ -30,9 +30,9 @@ def serve(req)
controller
=
controller
req
res
=
controller
.
make_response!
req
dispatch
(
controller
,
params
[
:action
],
req
,
res
)
rescue
NameError
=>
e
rescue
ActionController
::
RoutingError
if
@raise_on_name_error
raise
ActionController
::
RoutingError
,
e
.
message
,
e
.
backtrace
raise
else
return
[
404
,
{
'X-Cascade'
=>
'pass'
},
[]]
end
...
...
@@ -42,6 +42,8 @@ def serve(req)
def
controller
(
req
)
req
.
controller_class
rescue
NameError
=>
e
raise
ActionController
::
RoutingError
,
e
.
message
,
e
.
backtrace
end
def
dispatch
(
controller
,
action
,
req
,
res
)
...
...
actionpack/test/dispatch/routing_test.rb
浏览文件 @
d3dd3847
...
...
@@ -4592,3 +4592,44 @@ def test_positional_args_with_format_false
assert_equal
'/en/posts/2014/12/13'
,
archived_posts_path
(
2014
,
12
,
13
)
end
end
class
TestErrorsInController
<
ActionDispatch
::
IntegrationTest
class
::
PostsController
<
ActionController
::
Base
def
foo
nil
.
i_do_not_exist
end
def
bar
NonExistingClass
.
new
end
end
Routes
=
ActionDispatch
::
Routing
::
RouteSet
.
new
Routes
.
draw
do
get
'/:controller(/:action)'
end
APP
=
build_app
Routes
def
app
APP
end
def
test_legit_no_method_errors_are_not_caught
get
'/posts/foo'
assert_equal
500
,
response
.
status
end
def
test_legit_name_errors_are_not_caught
get
'/posts/bar'
assert_equal
500
,
response
.
status
end
def
test_legit_routing_not_found_responses
get
'/posts/baz'
assert_equal
404
,
response
.
status
get
'/i_do_not_exist'
assert_equal
404
,
response
.
status
end
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录