Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
754173c5
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,发现更多精彩内容 >>
提交
754173c5
编写于
8月 28, 2012
作者:
P
Pratik Naik
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add a test to make sure preloading properly merges association and default scope conditions
上级
810a50da
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
23 addition
and
0 deletion
+23
-0
activerecord/test/cases/associations/eager_test.rb
activerecord/test/cases/associations/eager_test.rb
+12
-0
activerecord/test/models/post.rb
activerecord/test/models/post.rb
+3
-0
activerecord/test/models/reader.rb
activerecord/test/models/reader.rb
+8
-0
未找到文件。
activerecord/test/cases/associations/eager_test.rb
浏览文件 @
754173c5
...
...
@@ -980,6 +980,18 @@ def test_eager_loading_with_conditions_on_joined_table_preloads
assert_equal
posts
(
:welcome
,
:thinking
),
posts
end
def
test_preload_has_many_with_association_condition_and_default_scope
post
=
Post
.
create!
(
:title
=>
'Beaches'
,
:body
=>
"I like beaches!"
)
Reader
.
create!
:person
=>
people
(
:david
),
:post
=>
post
LazyReader
.
create!
:person
=>
people
(
:susan
),
:post
=>
post
assert_equal
1
,
post
.
lazy_readers
.
to_a
.
size
assert_equal
2
,
post
.
lazy_readers_skimmers_or_not
.
to_a
.
size
post_with_readers
=
Post
.
includes
(
:lazy_readers_skimmers_or_not
).
find
(
post
.
id
)
assert_equal
2
,
post_with_readers
.
lazy_readers_skimmers_or_not
.
to_a
.
size
end
def
test_eager_loading_with_conditions_on_string_joined_table_preloads
posts
=
assert_queries
(
2
)
do
Post
.
all
.
merge!
(
:select
=>
'distinct posts.*'
,
:includes
=>
:author
,
:joins
=>
"INNER JOIN comments on comments.post_id = posts.id"
,
:where
=>
"comments.body like 'Thank you%'"
,
:order
=>
'posts.id'
).
to_a
...
...
activerecord/test/models/post.rb
浏览文件 @
754173c5
...
...
@@ -119,6 +119,9 @@ def add_joins_and_select
has_many
:skimmers
,
->
{
where
:skimmer
=>
true
},
:class_name
=>
'Reader'
has_many
:impatient_people
,
:through
=>
:skimmers
,
:source
=>
:person
has_many
:lazy_readers
has_many
:lazy_readers_skimmers_or_not
,
->
{
where
(
skimmer:
[
true
,
false
])
},
:class_name
=>
'LazyReader'
def
self
.
top
(
limit
)
ranked_by_comments
.
limit_by
(
limit
)
end
...
...
activerecord/test/models/reader.rb
浏览文件 @
754173c5
...
...
@@ -12,3 +12,11 @@ class SecureReader < ActiveRecord::Base
attr_accessible
nil
end
class
LazyReader
<
ActiveRecord
::
Base
self
.
table_name
=
"readers"
default_scope
->
{
where
(
skimmer:
true
)
}
belongs_to
:post
belongs_to
:person
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录