aboutsummaryrefslogtreecommitdiffstats
path: root/spec/engines/sql/unit/predicates/binary_spec.rb
blob: 72c8e448881f6b09c25ad96c7518828753028624 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
require 'spec_helper'

module Arel
  module Predicates
    describe Binary do
      class ConcreteBinary < Binary
        def predicate_sql
          "<=>"
        end
      end

      before do
        @relation = Arel::Table.new(:users)
        @attribute1 = @relation[:id]
        @attribute2 = @relation[:name]
      end

      describe "with compound predicates" do
        before do
          @operand1 = ConcreteBinary.new(@attribute1, 1)
          @operand2 = ConcreteBinary.new(@attribute2, "name")
        end

        describe Or do
          describe "#to_sql" do
            it "manufactures sql with an OR operation" do
              sql = Or.new(@operand1, @operand2).to_sql

              adapter_is :mysql do
                sql.should be_like(%Q{(`users`.`id` <=> 1 OR `users`.`name` <=> 'name')})
              end

              adapter_is :postgresql do
                sql.should be_like(%Q{("users"."id" <=> 1 OR "users"."name" <=> E'name')})
              end

              adapter_is :sqlite3 do
                sql.should be_like(%Q{("users"."id" <=> 1 OR "users"."name" <=> 'name')})
              end

              adapter_is :oracle do
                sql.should be_like(%Q{("USERS"."ID" <=> 1 OR "USERS"."NAME" <=> 'name')})
              end
            end
          end
        end

        describe And do
          describe "#to_sql" do
            it "manufactures sql with an AND operation" do
              sql = And.new(@operand1, @operand2).to_sql

              adapter_is :mysql do
                sql.should be_like(%Q{(`users`.`id` <=> 1 AND `users`.`name` <=> 'name')})
              end

              adapter_is :sqlite3 do
                sql.should be_like(%Q{("users"."id" <=> 1 AND "users"."name" <=> 'name')})
              end

              adapter_is :postgresql do
                sql.should be_like(%Q{("users"."id" <=> 1 AND "users"."name" <=> E'name')})
              end

              adapter_is :oracle do
                sql.should be_like(%Q{("USERS"."ID" <=> 1 AND "USERS"."NAME" <=> 'name')})
              end
            end
          end
        end
      end

      describe '#to_sql' do
        describe 'when relating two attributes' do
          it 'manufactures sql with a binary operation' do
            sql = ConcreteBinary.new(@attribute1, @attribute2).to_sql

            adapter_is :mysql do
              sql.should be_like(%Q{`users`.`id` <=> `users`.`name`})
            end

            adapter_is :oracle do
              sql.should be_like(%Q{"USERS"."ID" <=> "USERS"."NAME"})
            end

            adapter_is_not :mysql, :oracle do
              sql.should be_like(%Q{"users"."id" <=> "users"."name"})
            end
          end
        end

        describe 'when relating an attribute and a value' do
          before do
            @value = "1-asdf"
          end

          describe 'when relating to an integer attribute' do
            it 'formats values as integers' do
              sql = ConcreteBinary.new(@attribute1, @value).to_sql

              adapter_is :mysql do
                sql.should be_like(%Q{`users`.`id` <=> 1})
              end

              adapter_is :oracle do
                sql.should be_like(%Q{"USERS"."ID" <=> 1})
              end

              adapter_is_not :mysql, :oracle do
                sql.should be_like(%Q{"users"."id" <=> 1})
              end
            end
          end

          describe 'when relating to a string attribute' do
            it 'formats values as strings' do
              sql = ConcreteBinary.new(@attribute2, @value).to_sql

              adapter_is :mysql do
                sql.should be_like(%Q{`users`.`name` <=> '1-asdf'})
              end

              adapter_is :sqlite3 do
                sql.should be_like(%Q{"users"."name" <=> '1-asdf'})
              end

              adapter_is :postgresql do
                sql.should be_like(%Q{"users"."name" <=> E'1-asdf'})
              end

              adapter_is :oracle do
                sql.should be_like(%Q{"USERS"."NAME" <=> '1-asdf'})
              end
            end
          end
        end
      end
    end
  end
end