quoting_test.rb 4.6 KB
Newer Older
1
require "cases/helper"
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18

module ActiveRecord
  module ConnectionAdapters
    class QuotingTest < ActiveRecord::TestCase
      def setup
        @quoter = Class.new { include Quoting }.new
      end

      def test_quoted_true
        assert_equal "'t'", @quoter.quoted_true
      end

      def test_quoted_false
        assert_equal "'f'", @quoter.quoted_false
      end

      def test_quote_column_name
19
        assert_equal "foo", @quoter.quote_column_name("foo")
20 21
      end

22
      def test_quote_table_name
23
        assert_equal "foo", @quoter.quote_table_name("foo")
24 25 26 27 28
      end

      def test_quote_table_name_calls_quote_column_name
        @quoter.extend(Module.new {
          def quote_column_name(string)
29
            "lol"
30 31
          end
        })
32
        assert_equal "lol", @quoter.quote_table_name("foo")
33 34
      end

35 36 37 38 39 40
      def test_quote_string
        assert_equal "''", @quoter.quote_string("'")
        assert_equal "\\\\", @quoter.quote_string("\\")
        assert_equal "hi''i", @quoter.quote_string("hi'i")
        assert_equal "hi\\\\i", @quoter.quote_string("hi\\i")
      end
41 42 43 44 45 46 47

      def test_quoted_date
        t = Date.today
        assert_equal t.to_s(:db), @quoter.quoted_date(t)
      end

      def test_quoted_time_utc
48
        with_timezone_config default: :utc do
49
          t = Time.now.change(usec: 0)
50 51
          assert_equal t.getutc.to_s(:db), @quoter.quoted_date(t)
        end
52 53 54
      end

      def test_quoted_time_local
55
        with_timezone_config default: :local do
56
          t = Time.now.change(usec: 0)
57 58
          assert_equal t.getlocal.to_s(:db), @quoter.quoted_date(t)
        end
59 60 61
      end

      def test_quoted_time_crazy
62
        with_timezone_config default: :asdfasdf do
63
          t = Time.now.change(usec: 0)
64 65
          assert_equal t.getlocal.to_s(:db), @quoter.quoted_date(t)
        end
66 67 68
      end

      def test_quoted_datetime_utc
69
        with_timezone_config default: :utc do
70
          t = Time.now.change(usec: 0).to_datetime
71 72
          assert_equal t.getutc.to_s(:db), @quoter.quoted_date(t)
        end
73 74 75 76 77
      end

      ###
      # DateTime doesn't define getlocal, so make sure it does nothing
      def test_quoted_datetime_local
78
        with_timezone_config default: :local do
79
          t = Time.now.change(usec: 0).to_datetime
80 81
          assert_equal t.to_s(:db), @quoter.quoted_date(t)
        end
82
      end
83 84 85 86 87 88

      def test_quote_with_quoted_id
        assert_equal 1, @quoter.quote(Struct.new(:quoted_id).new(1), nil)
      end

      def test_quote_nil
89
        assert_equal "NULL", @quoter.quote(nil, nil)
90 91 92 93 94 95 96 97 98
      end

      def test_quote_true
        assert_equal @quoter.quoted_true, @quoter.quote(true, nil)
      end

      def test_quote_false
        assert_equal @quoter.quoted_false, @quoter.quote(false, nil)
      end
99 100 101 102 103 104

      def test_quote_float
        float = 1.2
        assert_equal float.to_s, @quoter.quote(float, nil)
      end

105 106 107
      def test_quote_integer
        integer = 1
        assert_equal integer.to_s, @quoter.quote(integer, nil)
108 109 110 111 112 113
      end

      def test_quote_bignum
        bignum = 1 << 100
        assert_equal bignum.to_s, @quoter.quote(bignum, nil)
      end
A
Aaron Patterson 已提交
114 115 116

      def test_quote_bigdecimal
        bigdec = BigDecimal.new((1 << 100).to_s)
117
        assert_equal bigdec.to_s("F"), @quoter.quote(bigdec, nil)
A
Aaron Patterson 已提交
118
      end
119 120

      def test_dates_and_times
121
        @quoter.extend(Module.new { def quoted_date(value) "lol" end })
122 123 124 125
        assert_equal "'lol'", @quoter.quote(Date.today, nil)
        assert_equal "'lol'", @quoter.quote(Time.now, nil)
        assert_equal "'lol'", @quoter.quote(DateTime.now, nil)
      end
A
Aaron Patterson 已提交
126 127

      def test_crazy_object
128 129 130 131 132
        crazy = Object.new
        e = assert_raises(TypeError) do
          @quoter.quote(crazy, nil)
        end
        assert_equal "can't quote Object", e.message
A
Aaron Patterson 已提交
133
      end
134 135

      def test_quote_string_no_column
136
        assert_equal "'lo\\\\l'", @quoter.quote('lo\l')
137 138
      end

139 140
      def test_quote_as_mb_chars_no_column
        string = ActiveSupport::Multibyte::Chars.new('lo\l')
141
        assert_equal "'lo\\\\l'", @quoter.quote(string)
142
      end
143 144 145 146

      def test_quote_duration
        assert_equal "1800", @quoter.quote(30.minutes)
      end
147
    end
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163

    class QuoteBooleanTest < ActiveRecord::TestCase
      def setup
        @connection = ActiveRecord::Base.connection
      end

      def test_quote_returns_frozen_string
        assert_predicate @connection.quote(true), :frozen?
        assert_predicate @connection.quote(false), :frozen?
      end

      def test_type_cast_returns_frozen_value
        assert_predicate @connection.type_cast(true), :frozen?
        assert_predicate @connection.type_cast(false), :frozen?
      end
    end
164 165
  end
end