Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
f22a0e2f
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,发现更多精彩内容 >>
提交
f22a0e2f
编写于
1月 27, 2012
作者:
J
Jon Leighton
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #4715 from pwim/find-create-multi-args
Fix regression from Rails 3.1
上级
faaf694e
7b9baeed
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
12 addition
and
1 deletion
+12
-1
activerecord/lib/active_record/dynamic_matchers.rb
activerecord/lib/active_record/dynamic_matchers.rb
+1
-1
activerecord/test/cases/finder_test.rb
activerecord/test/cases/finder_test.rb
+11
-0
未找到文件。
activerecord/lib/active_record/dynamic_matchers.rb
浏览文件 @
f22a0e2f
...
...
@@ -25,7 +25,7 @@ def method_missing(method_id, *arguments, &block)
if
match
=
(
DynamicFinderMatch
.
match
(
method_id
)
||
DynamicScopeMatch
.
match
(
method_id
))
attribute_names
=
match
.
attribute_names
super
unless
all_attributes_exists?
(
attribute_names
)
if
arguments
.
size
<
attribute_names
.
size
if
!
(
match
.
is_a?
(
DynamicFinderMatch
)
&&
match
.
instantiator?
&&
arguments
.
first
.
is_a?
(
Hash
))
&&
arguments
.
size
<
attribute_names
.
size
method_trace
=
"
#{
__FILE__
}
:
#{
__LINE__
}
:in `
#{
method_id
}
'"
backtrace
=
[
method_trace
]
+
caller
raise
ArgumentError
,
"wrong number of arguments (
#{
arguments
.
size
}
for
#{
attribute_names
.
size
}
)"
,
backtrace
...
...
activerecord/test/cases/finder_test.rb
浏览文件 @
f22a0e2f
...
...
@@ -881,6 +881,17 @@ def test_find_or_create_from_one_attribute_and_hash
assert_equal
23
,
sig38
.
client_of
end
def
test_find_or_create_from_two_attributes_and_hash
number_of_companies
=
Company
.
count
sig38
=
Company
.
find_or_create_by_name_and_firm_id
({
:name
=>
"38signals"
,
:firm_id
=>
17
,
:client_of
=>
23
})
assert_equal
number_of_companies
+
1
,
Company
.
count
assert_equal
sig38
,
Company
.
find_or_create_by_name_and_firm_id
({
:name
=>
"38signals"
,
:firm_id
=>
17
,
:client_of
=>
23
})
assert
sig38
.
persisted?
assert_equal
"38signals"
,
sig38
.
name
assert_equal
17
,
sig38
.
firm_id
assert_equal
23
,
sig38
.
client_of
end
def
test_find_or_create_from_one_aggregate_attribute
number_of_customers
=
Customer
.
count
created_customer
=
Customer
.
find_or_create_by_balance
(
Money
.
new
(
123
))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录