Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
edc5603b
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,发现更多精彩内容 >>
提交
edc5603b
编写于
7月 02, 2016
作者:
M
Matthew Draper
提交者:
GitHub
7月 02, 2016
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #25222 from vipulnsward/25219-fix-logs
Clean backtrace in IRB
上级
8fb69957
8e1714b2
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
29 addition
and
9 deletion
+29
-9
railties/lib/rails/backtrace_cleaner.rb
railties/lib/rails/backtrace_cleaner.rb
+1
-1
railties/lib/rails/commands/console.rb
railties/lib/rails/commands/console.rb
+12
-0
railties/test/backtrace_cleaner_test.rb
railties/test/backtrace_cleaner_test.rb
+16
-8
未找到文件。
railties/lib/rails/backtrace_cleaner.rb
浏览文件 @
edc5603b
...
...
@@ -2,7 +2,7 @@
module
Rails
class
BacktraceCleaner
<
ActiveSupport
::
BacktraceCleaner
APP_DIRS_PATTERN
=
/^\/?(app|config|lib|test)/
APP_DIRS_PATTERN
=
/^\/?(app|config|lib|test
|\(\w*\)
)/
RENDER_TEMPLATE_PATTERN
=
/:in `_render_template_\w*'/
EMPTY_STRING
=
''
.
freeze
SLASH
=
'/'
.
freeze
...
...
railties/lib/rails/commands/console.rb
浏览文件 @
edc5603b
...
...
@@ -7,6 +7,14 @@ module Rails
class
Console
include
ConsoleHelper
module
BacktraceCleaner
def
filter_backtrace
(
bt
)
if
result
=
super
Rails
.
backtrace_cleaner
.
filter
([
result
]).
first
end
end
end
class
<<
self
def
parse_arguments
(
arguments
)
options
=
{}
...
...
@@ -34,6 +42,10 @@ def initialize(app, options={})
app
.
load_console
@console
=
app
.
config
.
console
||
IRB
if
@console
==
IRB
IRB
::
WorkSpace
.
prepend
(
BacktraceCleaner
)
end
end
def
sandbox?
...
...
railties/test/backtrace_cleaner_test.rb
浏览文件 @
edc5603b
require
'abstract_unit'
require
'rails/backtrace_cleaner'
class
BacktraceCleaner
VendorGem
Test
<
ActiveSupport
::
TestCase
class
BacktraceCleanerTest
<
ActiveSupport
::
TestCase
def
setup
@cleaner
=
Rails
::
BacktraceCleaner
.
new
end
test
"should format installed gems correctly"
do
@
backtrace
=
[
"
#{
Gem
.
path
[
0
]
}
/gems/nosuchgem-1.2.3/lib/foo.rb"
]
@result
=
@cleaner
.
clean
(
@
backtrace
,
:all
)
assert_equal
"nosuchgem (1.2.3) lib/foo.rb"
,
@
result
[
0
]
backtrace
=
[
"
#{
Gem
.
path
[
0
]
}
/gems/nosuchgem-1.2.3/lib/foo.rb"
]
result
=
@cleaner
.
clean
(
backtrace
,
:all
)
assert_equal
"nosuchgem (1.2.3) lib/foo.rb"
,
result
[
0
]
end
test
"should format installed gems not in Gem.default_dir correctly"
do
@
target_dir
=
Gem
.
path
.
detect
{
|
p
|
p
!=
Gem
.
default_dir
}
target_dir
=
Gem
.
path
.
detect
{
|
p
|
p
!=
Gem
.
default_dir
}
# skip this test if default_dir is the only directory on Gem.path
if
@target_dir
@backtrace
=
[
"
#{
@
target_dir
}
/gems/nosuchgem-1.2.3/lib/foo.rb"
]
@result
=
@cleaner
.
clean
(
@
backtrace
,
:all
)
assert_equal
"nosuchgem (1.2.3) lib/foo.rb"
,
@
result
[
0
]
backtrace
=
[
"
#{
target_dir
}
/gems/nosuchgem-1.2.3/lib/foo.rb"
]
result
=
@cleaner
.
clean
(
backtrace
,
:all
)
assert_equal
"nosuchgem (1.2.3) lib/foo.rb"
,
result
[
0
]
end
end
test
"should consider traces from irb lines as User code"
do
backtrace
=
[
"from (irb):1"
,
"from /Path/to/rails/railties/lib/rails/commands/console.rb:77:in `start'"
,
"from bin/rails:4:in `<main>'"
]
result
=
@cleaner
.
clean
(
backtrace
,
:all
)
assert_equal
"from (irb):1"
,
result
[
0
]
end
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录