arel 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitmodules +3 -0
- data/README.markdown +26 -26
- data/Rakefile +34 -46
- data/Thorfile +122 -0
- data/arel.gemspec +205 -201
- data/lib/arel.rb +11 -7
- data/lib/arel/algebra.rb +7 -2
- data/lib/arel/algebra/{primitives/attribute.rb → attribute.rb} +7 -7
- data/lib/arel/algebra/core_extensions.rb +4 -0
- data/lib/arel/algebra/{extensions → core_extensions}/class.rb +2 -2
- data/lib/arel/algebra/{extensions → core_extensions}/hash.rb +1 -1
- data/lib/arel/algebra/{extensions → core_extensions}/object.rb +1 -1
- data/lib/arel/algebra/{extensions → core_extensions}/symbol.rb +1 -1
- data/lib/arel/algebra/{primitives/expression.rb → expression.rb} +0 -0
- data/lib/arel/algebra/{primitives/ordering.rb → ordering.rb} +1 -1
- data/lib/arel/algebra/predicates.rb +32 -30
- data/lib/arel/algebra/relations/relation.rb +1 -1
- data/lib/arel/algebra/{primitives/value.rb → value.rb} +0 -0
- data/lib/arel/engines/memory/predicates.rb +26 -24
- data/lib/arel/engines/sql.rb +1 -1
- data/lib/arel/engines/sql/core_extensions.rb +4 -0
- data/lib/arel/engines/sql/{extensions → core_extensions}/array.rb +1 -1
- data/lib/arel/engines/sql/{extensions → core_extensions}/nil_class.rb +1 -1
- data/lib/arel/engines/sql/{extensions → core_extensions}/object.rb +1 -1
- data/lib/arel/engines/sql/{extensions → core_extensions}/range.rb +1 -1
- data/lib/arel/engines/sql/formatters.rb +6 -3
- data/lib/arel/engines/sql/predicates.rb +37 -35
- data/lib/arel/engines/sql/primitives.rb +10 -2
- data/lib/arel/engines/sql/relations/operations/join.rb +2 -2
- data/lib/arel/engines/sql/relations/relation.rb +33 -9
- data/lib/arel/engines/sql/relations/writes.rb +41 -10
- data/lib/arel/session.rb +9 -6
- data/spec/arel/algebra/unit/predicates/binary_spec.rb +23 -21
- data/spec/arel/algebra/unit/predicates/equality_spec.rb +20 -18
- data/spec/arel/algebra/unit/predicates/in_spec.rb +7 -5
- data/spec/arel/algebra/unit/primitives/attribute_spec.rb +10 -12
- data/spec/arel/algebra/unit/primitives/expression_spec.rb +1 -1
- data/spec/arel/algebra/unit/primitives/value_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/alias_spec.rb +2 -2
- data/spec/arel/algebra/unit/relations/delete_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/group_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/insert_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/join_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/order_spec.rb +2 -2
- data/spec/arel/algebra/unit/relations/project_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/relation_spec.rb +5 -5
- data/spec/arel/algebra/unit/relations/skip_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/table_spec.rb +2 -2
- data/spec/arel/algebra/unit/relations/take_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/update_spec.rb +1 -1
- data/spec/arel/algebra/unit/relations/where_spec.rb +1 -1
- data/spec/arel/algebra/unit/session/session_spec.rb +1 -1
- data/spec/arel/engines/memory/integration/joins/cross_engine_spec.rb +3 -4
- data/spec/arel/engines/memory/unit/relations/array_spec.rb +1 -1
- data/spec/arel/engines/memory/unit/relations/insert_spec.rb +8 -8
- data/spec/arel/engines/memory/unit/relations/join_spec.rb +1 -1
- data/spec/arel/engines/memory/unit/relations/order_spec.rb +1 -1
- data/spec/arel/engines/memory/unit/relations/project_spec.rb +1 -1
- data/spec/arel/engines/memory/unit/relations/skip_spec.rb +1 -1
- data/spec/arel/engines/memory/unit/relations/take_spec.rb +1 -1
- data/spec/arel/engines/memory/unit/relations/where_spec.rb +1 -1
- data/spec/arel/engines/sql/integration/joins/with_adjacency_spec.rb +1 -1
- data/spec/arel/engines/sql/integration/joins/with_aggregations_spec.rb +1 -1
- data/spec/arel/engines/sql/integration/joins/with_compounds_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/engine_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/predicates/binary_spec.rb +73 -70
- data/spec/arel/engines/sql/unit/predicates/equality_spec.rb +45 -28
- data/spec/arel/engines/sql/unit/predicates/in_spec.rb +57 -55
- data/spec/arel/engines/sql/unit/predicates/predicates_spec.rb +48 -46
- data/spec/arel/engines/sql/unit/primitives/attribute_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/primitives/expression_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/primitives/literal_spec.rb +13 -1
- data/spec/arel/engines/sql/unit/primitives/value_spec.rb +3 -3
- data/spec/arel/engines/sql/unit/relations/alias_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/delete_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/group_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/insert_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/join_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/order_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/project_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/skip_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/table_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/take_spec.rb +1 -1
- data/spec/arel/engines/sql/unit/relations/update_spec.rb +13 -7
- data/spec/arel/engines/sql/unit/relations/where_spec.rb +1 -1
- data/spec/connections/mysql_connection.rb +3 -3
- data/spec/connections/postgresql_connection.rb +2 -2
- data/spec/connections/sqlite3_connection.rb +3 -2
- data/spec/doubles/hash.rb +4 -0
- data/spec/spec.opts +3 -0
- data/spec/spec_helper.rb +8 -0
- metadata +39 -25
- data/VERSION +0 -1
- data/lib/arel/algebra/extensions.rb +0 -4
- data/lib/arel/algebra/primitives.rb +0 -5
- data/lib/arel/engines/sql/extensions.rb +0 -4
@@ -1,83 +1,85 @@
|
|
1
|
-
require
|
1
|
+
require 'spec_helper'
|
2
2
|
|
3
3
|
module Arel
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
4
|
+
module Predicates
|
5
|
+
describe In do
|
6
|
+
before do
|
7
|
+
@relation = Table.new(:users)
|
8
|
+
@attribute = @relation[:id]
|
9
|
+
end
|
9
10
|
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
11
|
+
describe '#to_sql' do
|
12
|
+
describe 'when relating to an array' do
|
13
|
+
describe 'when the array\'s elements are the same type as the attribute' do
|
14
|
+
before do
|
15
|
+
@array = [1, 2, 3]
|
16
|
+
end
|
16
17
|
|
17
|
-
|
18
|
-
|
18
|
+
it 'manufactures sql with a comma separated list' do
|
19
|
+
sql = In.new(@attribute, @array).to_sql
|
19
20
|
|
20
|
-
|
21
|
-
|
21
|
+
adapter_is :mysql do
|
22
|
+
sql.should be_like(%Q{`users`.`id` IN (1, 2, 3)})
|
23
|
+
end
|
24
|
+
|
25
|
+
adapter_is_not :mysql do
|
26
|
+
sql.should be_like(%Q{"users"."id" IN (1, 2, 3)})
|
27
|
+
end
|
22
28
|
end
|
29
|
+
end
|
23
30
|
|
24
|
-
|
25
|
-
|
31
|
+
describe 'when the array\'s elements are not same type as the attribute' do
|
32
|
+
before do
|
33
|
+
@array = ['1-asdf', 2, 3]
|
34
|
+
end
|
35
|
+
|
36
|
+
it 'formats values in the array as the type of the attribute' do
|
37
|
+
sql = In.new(@attribute, @array).to_sql
|
38
|
+
|
39
|
+
adapter_is :mysql do
|
40
|
+
sql.should be_like(%Q{`users`.`id` IN (1, 2, 3)})
|
41
|
+
end
|
42
|
+
|
43
|
+
adapter_is_not :mysql do
|
44
|
+
sql.should be_like(%Q{"users"."id" IN (1, 2, 3)})
|
45
|
+
end
|
26
46
|
end
|
27
47
|
end
|
28
48
|
end
|
29
49
|
|
30
|
-
describe 'when
|
50
|
+
describe 'when relating to a range' do
|
31
51
|
before do
|
32
|
-
@
|
52
|
+
@range = 1..2
|
33
53
|
end
|
34
54
|
|
35
|
-
it '
|
36
|
-
sql = In.new(@attribute, @
|
55
|
+
it 'manufactures sql with a between' do
|
56
|
+
sql = In.new(@attribute, @range).to_sql
|
37
57
|
|
38
58
|
adapter_is :mysql do
|
39
|
-
sql.should be_like(%Q{`users`.`id`
|
59
|
+
sql.should be_like(%Q{`users`.`id` BETWEEN 1 AND 2})
|
40
60
|
end
|
41
61
|
|
42
62
|
adapter_is_not :mysql do
|
43
|
-
sql.should be_like(%Q{"users"."id"
|
63
|
+
sql.should be_like(%Q{"users"."id" BETWEEN 1 AND 2})
|
44
64
|
end
|
45
65
|
end
|
46
66
|
end
|
47
|
-
end
|
48
|
-
|
49
|
-
describe 'when relating to a range' do
|
50
|
-
before do
|
51
|
-
@range = 1..2
|
52
|
-
end
|
53
|
-
|
54
|
-
it 'manufactures sql with a between' do
|
55
|
-
sql = In.new(@attribute, @range).to_sql
|
56
|
-
|
57
|
-
adapter_is :mysql do
|
58
|
-
sql.should be_like(%Q{`users`.`id` BETWEEN 1 AND 2})
|
59
|
-
end
|
60
|
-
|
61
|
-
adapter_is_not :mysql do
|
62
|
-
sql.should be_like(%Q{"users"."id" BETWEEN 1 AND 2})
|
63
|
-
end
|
64
|
-
end
|
65
|
-
end
|
66
67
|
|
67
|
-
|
68
|
-
|
69
|
-
|
68
|
+
describe 'when relating to a relation' do
|
69
|
+
it 'manufactures sql with a subselect' do
|
70
|
+
sql = In.new(@attribute, @relation).to_sql
|
70
71
|
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
72
|
+
adapter_is :mysql do
|
73
|
+
sql.should be_like(%Q{
|
74
|
+
`users`.`id` IN (SELECT `users`.`id`, `users`.`name` FROM `users`)
|
75
|
+
})
|
76
|
+
end
|
76
77
|
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
78
|
+
adapter_is_not :mysql do
|
79
|
+
sql.should be_like(%Q{
|
80
|
+
"users"."id" IN (SELECT "users"."id", "users"."name" FROM "users")
|
81
|
+
})
|
82
|
+
end
|
81
83
|
end
|
82
84
|
end
|
83
85
|
end
|
@@ -1,62 +1,64 @@
|
|
1
|
-
require
|
1
|
+
require 'spec_helper'
|
2
2
|
|
3
3
|
module Arel
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
4
|
+
module Predicates
|
5
|
+
describe Predicate do
|
6
|
+
before do
|
7
|
+
@relation = Table.new(:users)
|
8
|
+
@attribute1 = @relation[:id]
|
9
|
+
@attribute2 = @relation[:name]
|
10
|
+
@operand1 = Equality.new(@attribute1, 1)
|
11
|
+
@operand2 = Equality.new(@attribute2, "name")
|
12
|
+
end
|
12
13
|
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
14
|
+
describe "when being combined with another predicate with AND logic" do
|
15
|
+
describe "#to_sql" do
|
16
|
+
it "manufactures sql with an AND operation" do
|
17
|
+
sql = @operand1.and(@operand2).to_sql
|
17
18
|
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
19
|
+
adapter_is :mysql do
|
20
|
+
sql.should be_like(%Q{
|
21
|
+
(`users`.`id` = 1 AND `users`.`name` = 'name')
|
22
|
+
})
|
23
|
+
end
|
23
24
|
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
25
|
+
adapter_is :sqlite3 do
|
26
|
+
sql.should be_like(%Q{
|
27
|
+
("users"."id" = 1 AND "users"."name" = 'name')
|
28
|
+
})
|
29
|
+
end
|
29
30
|
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
31
|
+
adapter_is :postgresql do
|
32
|
+
sql.should be_like(%Q{
|
33
|
+
("users"."id" = 1 AND "users"."name" = E'name')
|
34
|
+
})
|
35
|
+
end
|
34
36
|
end
|
35
37
|
end
|
36
38
|
end
|
37
|
-
end
|
38
39
|
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
40
|
+
describe "when being combined with another predicate with OR logic" do
|
41
|
+
describe "#to_sql" do
|
42
|
+
it "manufactures sql with an OR operation" do
|
43
|
+
sql = @operand1.or(@operand2).to_sql
|
43
44
|
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
45
|
+
adapter_is :mysql do
|
46
|
+
sql.should be_like(%Q{
|
47
|
+
(`users`.`id` = 1 OR `users`.`name` = 'name')
|
48
|
+
})
|
49
|
+
end
|
49
50
|
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
51
|
+
adapter_is :sqlite3 do
|
52
|
+
sql.should be_like(%Q{
|
53
|
+
("users"."id" = 1 OR "users"."name" = 'name')
|
54
|
+
})
|
55
|
+
end
|
55
56
|
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
57
|
+
adapter_is :postgresql do
|
58
|
+
sql.should be_like(%Q{
|
59
|
+
("users"."id" = 1 OR "users"."name" = E'name')
|
60
|
+
})
|
61
|
+
end
|
60
62
|
end
|
61
63
|
end
|
62
64
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require
|
1
|
+
require 'spec_helper'
|
2
2
|
|
3
3
|
module Arel
|
4
4
|
describe SqlLiteral do
|
@@ -18,6 +18,18 @@ module Arel
|
|
18
18
|
sql.should be_like(%Q{SELECT COUNT(*) AS count_id FROM "users"})
|
19
19
|
end
|
20
20
|
end
|
21
|
+
|
22
|
+
it "manufactures expressions on literal SQL fragment" do
|
23
|
+
sql = @relation.project(SqlLiteral.new("2 * credit_limit").sum).to_sql
|
24
|
+
|
25
|
+
adapter_is :mysql do
|
26
|
+
sql.should be_like(%Q{SELECT SUM(2 * credit_limit) AS sum_id FROM `users`})
|
27
|
+
end
|
28
|
+
|
29
|
+
adapter_is_not :mysql do
|
30
|
+
sql.should be_like(%Q{SELECT SUM(2 * credit_limit) AS sum_id FROM "users"})
|
31
|
+
end
|
32
|
+
end
|
21
33
|
end
|
22
34
|
end
|
23
35
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require
|
1
|
+
require 'spec_helper'
|
2
2
|
|
3
3
|
module Arel
|
4
4
|
describe Value do
|
@@ -9,11 +9,11 @@ module Arel
|
|
9
9
|
describe '#to_sql' do
|
10
10
|
it "appropriately quotes the value" do
|
11
11
|
Value.new(1, @relation).to_sql.should be_like('1')
|
12
|
-
|
12
|
+
|
13
13
|
adapter_is_not :postgresql do
|
14
14
|
Value.new('asdf', @relation).to_sql.should be_like("'asdf'")
|
15
15
|
end
|
16
|
-
|
16
|
+
|
17
17
|
adapter_is :postgresql do
|
18
18
|
Value.new('asdf', @relation).to_sql.should be_like("E'asdf'")
|
19
19
|
end
|
@@ -1,4 +1,10 @@
|
|
1
|
-
require
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
class User
|
4
|
+
def self.primary_key
|
5
|
+
"id"
|
6
|
+
end
|
7
|
+
end
|
2
8
|
|
3
9
|
module Arel
|
4
10
|
describe Update do
|
@@ -45,17 +51,17 @@ module Arel
|
|
45
51
|
|
46
52
|
adapter_is :sqlite3 do
|
47
53
|
sql.should be_like(%Q{
|
48
|
-
UPDATE "users"
|
49
|
-
|
50
|
-
LIMIT 1
|
54
|
+
UPDATE "users" SET
|
55
|
+
"name" = 'nick'
|
56
|
+
WHERE "id" IN (SELECT "id" FROM "users" LIMIT 1)
|
51
57
|
})
|
52
58
|
end
|
53
59
|
|
54
60
|
adapter_is :postgresql do
|
55
61
|
sql.should be_like(%Q{
|
56
|
-
UPDATE "users"
|
57
|
-
|
58
|
-
LIMIT 1
|
62
|
+
UPDATE "users" SET
|
63
|
+
"name" = E'nick'
|
64
|
+
WHERE "id" IN (SELECT "id" FROM "users" LIMIT 1)
|
59
65
|
})
|
60
66
|
end
|
61
67
|
end
|
@@ -1,13 +1,13 @@
|
|
1
|
-
require "rubygems"
|
2
|
-
require "activerecord"
|
3
1
|
puts "Using native MySQL"
|
2
|
+
require "active_record"
|
3
|
+
require 'logger'
|
4
4
|
|
5
5
|
ActiveRecord::Base.logger = Logger.new("debug.log")
|
6
6
|
|
7
7
|
ActiveRecord::Base.configurations = {
|
8
8
|
'unit' => {
|
9
9
|
:adapter => 'mysql',
|
10
|
-
:username => '
|
10
|
+
:username => 'root',
|
11
11
|
:encoding => 'utf8',
|
12
12
|
:database => 'arel_unit',
|
13
13
|
}
|