Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
474d4253
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,体验更适合开发者的 AI 搜索 >>
提交
474d4253
编写于
7月 02, 2008
作者:
P
Pratik Naik
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Ensure AssociationCollection#size considers all unsaved record. [#305 state:resolved] [sds]
Signed-off-by:
N
Pratik Naik
<
pratiknaik@gmail.com
>
上级
7378e237
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
8 addition
and
1 deletion
+8
-1
activerecord/lib/active_record/associations/association_collection.rb
.../lib/active_record/associations/association_collection.rb
+1
-1
activerecord/test/cases/associations/has_many_associations_test.rb
...ord/test/cases/associations/has_many_associations_test.rb
+7
-0
未找到文件。
activerecord/lib/active_record/associations/association_collection.rb
浏览文件 @
474d4253
...
...
@@ -187,7 +187,7 @@ def size
if
@owner
.
new_record?
||
(
loaded?
&&
!
@reflection
.
options
[
:uniq
])
@target
.
size
elsif
!
loaded?
&&
!
@reflection
.
options
[
:uniq
]
&&
@target
.
is_a?
(
Array
)
unsaved_records
=
Array
(
@target
.
detect
{
|
r
|
r
.
new_record?
})
unsaved_records
=
@target
.
select
{
|
r
|
r
.
new_record?
}
unsaved_records
.
size
+
count_records
else
count_records
...
...
activerecord/test/cases/associations/has_many_associations_test.rb
浏览文件 @
474d4253
...
...
@@ -384,6 +384,13 @@ def test_build
assert_equal
2
,
company
.
clients_of_firm
(
true
).
size
end
def
test_collection_size_after_building
company
=
companies
(
:first_firm
)
# company already has one client
company
.
clients_of_firm
.
build
(
"name"
=>
"Another Client"
)
company
.
clients_of_firm
.
build
(
"name"
=>
"Yet Another Client"
)
assert_equal
3
,
company
.
clients_of_firm
.
size
end
def
test_build_many
company
=
companies
(
:first_firm
)
new_clients
=
assert_no_queries
{
company
.
clients_of_firm
.
build
([{
"name"
=>
"Another Client"
},
{
"name"
=>
"Another Client II"
}])
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录