Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
5e41cb4a
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(gitcode.net)2024年7月9日维护升级公告
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
5e41cb4a
编写于
9月 03, 2013
作者:
B
Ben Woosley
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Pull the RelationMutationTests from cases/relation_test to cases/relation/mutation_test.
上级
489a0890
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
139 addition
and
135 deletion
+139
-135
activerecord/test/cases/relation/mutation_test.rb
activerecord/test/cases/relation/mutation_test.rb
+139
-0
activerecord/test/cases/relation_test.rb
activerecord/test/cases/relation_test.rb
+0
-135
未找到文件。
activerecord/test/cases/relation/mutation_test.rb
0 → 100644
浏览文件 @
5e41cb4a
require
"cases/helper"
require
'models/post'
module
ActiveRecord
class
RelationMutationTest
<
ActiveSupport
::
TestCase
class
FakeKlass
<
Struct
.
new
(
:table_name
,
:name
)
extend
ActiveRecord
::
Delegation
::
DelegateCache
inherited
self
def
arel_table
Post
.
arel_table
end
def
connection
Post
.
connection
end
def
relation_delegate_class
(
klass
)
self
.
class
.
relation_delegate_class
(
klass
)
end
end
def
relation
@relation
||=
Relation
.
new
FakeKlass
.
new
(
'posts'
),
:b
end
(
Relation
::
MULTI_VALUE_METHODS
-
[
:references
,
:extending
,
:order
]).
each
do
|
method
|
test
"#
#{
method
}
!"
do
assert
relation
.
public_send
(
"
#{
method
}
!"
,
:foo
).
equal?
(
relation
)
assert_equal
[
:foo
],
relation
.
public_send
(
"
#{
method
}
_values"
)
end
end
test
"#order!"
do
assert
relation
.
order!
(
'name ASC'
).
equal?
(
relation
)
assert_equal
[
'name ASC'
],
relation
.
order_values
end
test
"#order! with symbol prepends the table name"
do
assert
relation
.
order!
(
:name
).
equal?
(
relation
)
node
=
relation
.
order_values
.
first
assert
node
.
ascending?
assert_equal
:name
,
node
.
expr
.
name
assert_equal
"posts"
,
node
.
expr
.
relation
.
name
end
test
"#order! on non-string does not attempt regexp match for references"
do
obj
=
Object
.
new
obj
.
expects
(:
=~
).
never
assert
relation
.
order!
(
obj
)
assert_equal
[
obj
],
relation
.
order_values
end
test
'#references!'
do
assert
relation
.
references!
(
:foo
).
equal?
(
relation
)
assert
relation
.
references_values
.
include?
(
'foo'
)
end
test
'extending!'
do
mod
,
mod2
=
Module
.
new
,
Module
.
new
assert
relation
.
extending!
(
mod
).
equal?
(
relation
)
assert_equal
[
mod
],
relation
.
extending_values
assert
relation
.
is_a?
(
mod
)
relation
.
extending!
(
mod2
)
assert_equal
[
mod
,
mod2
],
relation
.
extending_values
end
test
'extending! with empty args'
do
relation
.
extending!
assert_equal
[],
relation
.
extending_values
end
(
Relation
::
SINGLE_VALUE_METHODS
-
[
:from
,
:lock
,
:reordering
,
:reverse_order
,
:create_with
]).
each
do
|
method
|
test
"#
#{
method
}
!"
do
assert
relation
.
public_send
(
"
#{
method
}
!"
,
:foo
).
equal?
(
relation
)
assert_equal
:foo
,
relation
.
public_send
(
"
#{
method
}
_value"
)
end
end
test
'#from!'
do
assert
relation
.
from!
(
'foo'
).
equal?
(
relation
)
assert_equal
[
'foo'
,
nil
],
relation
.
from_value
end
test
'#lock!'
do
assert
relation
.
lock!
(
'foo'
).
equal?
(
relation
)
assert_equal
'foo'
,
relation
.
lock_value
end
test
'#reorder!'
do
relation
=
self
.
relation
.
order
(
'foo'
)
assert
relation
.
reorder!
(
'bar'
).
equal?
(
relation
)
assert_equal
[
'bar'
],
relation
.
order_values
assert
relation
.
reordering_value
end
test
'reverse_order!'
do
assert
relation
.
reverse_order!
.
equal?
(
relation
)
assert
relation
.
reverse_order_value
relation
.
reverse_order!
assert
!
relation
.
reverse_order_value
end
test
'create_with!'
do
assert
relation
.
create_with!
(
foo:
'bar'
).
equal?
(
relation
)
assert_equal
({
foo:
'bar'
},
relation
.
create_with_value
)
end
def
test_merge!
assert
relation
.
merge!
(
where: :foo
).
equal?
(
relation
)
assert_equal
[
:foo
],
relation
.
where_values
end
test
'merge with a proc'
do
assert_equal
[
:foo
],
relation
.
merge
(
->
{
where
(
:foo
)
}).
where_values
end
test
'none!'
do
assert
relation
.
none!
.
equal?
(
relation
)
assert_equal
[
NullRelation
],
relation
.
extending_values
assert
relation
.
is_a?
(
NullRelation
)
end
test
"distinct!"
do
relation
.
distinct!
:foo
assert_equal
:foo
,
relation
.
distinct_value
assert_equal
:foo
,
relation
.
uniq_value
# deprecated access
end
test
"uniq! was replaced by distinct!"
do
relation
.
uniq!
:foo
assert_equal
:foo
,
relation
.
distinct_value
assert_equal
:foo
,
relation
.
uniq_value
# deprecated access
end
end
end
activerecord/test/cases/relation_test.rb
浏览文件 @
5e41cb4a
...
...
@@ -215,139 +215,4 @@ def test_relation_merging_with_merged_joins_as_strings
end
end
class
RelationMutationTest
<
ActiveSupport
::
TestCase
class
FakeKlass
<
Struct
.
new
(
:table_name
,
:name
)
extend
ActiveRecord
::
Delegation
::
DelegateCache
inherited
self
def
arel_table
Post
.
arel_table
end
def
connection
Post
.
connection
end
def
relation_delegate_class
(
klass
)
self
.
class
.
relation_delegate_class
(
klass
)
end
end
def
relation
@relation
||=
Relation
.
new
FakeKlass
.
new
(
'posts'
),
:b
end
(
Relation
::
MULTI_VALUE_METHODS
-
[
:references
,
:extending
,
:order
]).
each
do
|
method
|
test
"#
#{
method
}
!"
do
assert
relation
.
public_send
(
"
#{
method
}
!"
,
:foo
).
equal?
(
relation
)
assert_equal
[
:foo
],
relation
.
public_send
(
"
#{
method
}
_values"
)
end
end
test
"#order!"
do
assert
relation
.
order!
(
'name ASC'
).
equal?
(
relation
)
assert_equal
[
'name ASC'
],
relation
.
order_values
end
test
"#order! with symbol prepends the table name"
do
assert
relation
.
order!
(
:name
).
equal?
(
relation
)
node
=
relation
.
order_values
.
first
assert
node
.
ascending?
assert_equal
:name
,
node
.
expr
.
name
assert_equal
"posts"
,
node
.
expr
.
relation
.
name
end
test
"#order! on non-string does not attempt regexp match for references"
do
obj
=
Object
.
new
obj
.
expects
(:
=~
).
never
assert
relation
.
order!
(
obj
)
assert_equal
[
obj
],
relation
.
order_values
end
test
'#references!'
do
assert
relation
.
references!
(
:foo
).
equal?
(
relation
)
assert
relation
.
references_values
.
include?
(
'foo'
)
end
test
'extending!'
do
mod
,
mod2
=
Module
.
new
,
Module
.
new
assert
relation
.
extending!
(
mod
).
equal?
(
relation
)
assert_equal
[
mod
],
relation
.
extending_values
assert
relation
.
is_a?
(
mod
)
relation
.
extending!
(
mod2
)
assert_equal
[
mod
,
mod2
],
relation
.
extending_values
end
test
'extending! with empty args'
do
relation
.
extending!
assert_equal
[],
relation
.
extending_values
end
(
Relation
::
SINGLE_VALUE_METHODS
-
[
:from
,
:lock
,
:reordering
,
:reverse_order
,
:create_with
]).
each
do
|
method
|
test
"#
#{
method
}
!"
do
assert
relation
.
public_send
(
"
#{
method
}
!"
,
:foo
).
equal?
(
relation
)
assert_equal
:foo
,
relation
.
public_send
(
"
#{
method
}
_value"
)
end
end
test
'#from!'
do
assert
relation
.
from!
(
'foo'
).
equal?
(
relation
)
assert_equal
[
'foo'
,
nil
],
relation
.
from_value
end
test
'#lock!'
do
assert
relation
.
lock!
(
'foo'
).
equal?
(
relation
)
assert_equal
'foo'
,
relation
.
lock_value
end
test
'#reorder!'
do
relation
=
self
.
relation
.
order
(
'foo'
)
assert
relation
.
reorder!
(
'bar'
).
equal?
(
relation
)
assert_equal
[
'bar'
],
relation
.
order_values
assert
relation
.
reordering_value
end
test
'reverse_order!'
do
assert
relation
.
reverse_order!
.
equal?
(
relation
)
assert
relation
.
reverse_order_value
relation
.
reverse_order!
assert
!
relation
.
reverse_order_value
end
test
'create_with!'
do
assert
relation
.
create_with!
(
foo:
'bar'
).
equal?
(
relation
)
assert_equal
({
foo:
'bar'
},
relation
.
create_with_value
)
end
def
test_merge!
assert
relation
.
merge!
(
where: :foo
).
equal?
(
relation
)
assert_equal
[
:foo
],
relation
.
where_values
end
test
'merge with a proc'
do
assert_equal
[
:foo
],
relation
.
merge
(
->
{
where
(
:foo
)
}).
where_values
end
test
'none!'
do
assert
relation
.
none!
.
equal?
(
relation
)
assert_equal
[
NullRelation
],
relation
.
extending_values
assert
relation
.
is_a?
(
NullRelation
)
end
test
"distinct!"
do
relation
.
distinct!
:foo
assert_equal
:foo
,
relation
.
distinct_value
assert_equal
:foo
,
relation
.
uniq_value
# deprecated access
end
test
"uniq! was replaced by distinct!"
do
relation
.
uniq!
:foo
assert_equal
:foo
,
relation
.
distinct_value
assert_equal
:foo
,
relation
.
uniq_value
# deprecated access
end
end
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录