diff options
Diffstat (limited to 'activerecord/test')
| -rw-r--r-- | activerecord/test/cases/adapters/sqlite3/quoting_test.rb | 4 | ||||
| -rw-r--r-- | activerecord/test/cases/base_test.rb | 4 | ||||
| -rw-r--r-- | activerecord/test/cases/quoting_test.rb | 28 | ||||
| -rw-r--r-- | activerecord/test/cases/relations_test.rb | 7 | 
4 files changed, 23 insertions, 20 deletions
| diff --git a/activerecord/test/cases/adapters/sqlite3/quoting_test.rb b/activerecord/test/cases/adapters/sqlite3/quoting_test.rb index 0c4f06d6a9..209b7f70c9 100644 --- a/activerecord/test/cases/adapters/sqlite3/quoting_test.rb +++ b/activerecord/test/cases/adapters/sqlite3/quoting_test.rb @@ -15,10 +15,10 @@ module ActiveRecord          def test_type_cast_binary_encoding_without_logger            @conn.extend(Module.new { def logger; end }) -          column = Struct.new(:type, :name).new(:string, "foo") +          cast_type = Type::String.new            binary = SecureRandom.hex            expected = binary.dup.encode!(Encoding::UTF_8) -          assert_equal expected, @conn.type_cast(binary, column) +          assert_equal expected, @conn.type_cast(binary, cast_type)          end          def test_type_cast_symbol diff --git a/activerecord/test/cases/base_test.rb b/activerecord/test/cases/base_test.rb index c565daba65..1b3aa84a06 100644 --- a/activerecord/test/cases/base_test.rb +++ b/activerecord/test/cases/base_test.rb @@ -518,6 +518,10 @@ class BasicsTest < ActiveRecord::TestCase      assert_equal Topic.find('1-meowmeow'), Topic.find(1)    end +  def test_find_by_slug_with_array +    assert_equal Topic.find(['1-meowmeow', '2-hello']), Topic.find([1, 2]) +  end +    def test_equality_of_new_records      assert_not_equal Topic.new, Topic.new      assert_equal false, Topic.new == Topic.new diff --git a/activerecord/test/cases/quoting_test.rb b/activerecord/test/cases/quoting_test.rb index e2439b9a24..bbd5298da1 100644 --- a/activerecord/test/cases/quoting_test.rb +++ b/activerecord/test/cases/quoting_test.rb @@ -3,14 +3,6 @@ require "cases/helper"  module ActiveRecord    module ConnectionAdapters      class QuotingTest < ActiveRecord::TestCase -      class FakeColumn < ActiveRecord::ConnectionAdapters::Column -        attr_accessor :type - -        def initialize type -          @type = type -        end -      end -        def setup          @quoter = Class.new { include Quoting }.new        end @@ -101,12 +93,12 @@ module ActiveRecord        def test_quote_true          assert_equal @quoter.quoted_true, @quoter.quote(true, nil) -        assert_equal '1', @quoter.quote(true, Struct.new(:type).new(:integer)) +        assert_equal '1', @quoter.quote(true, Type::Integer.new)        end        def test_quote_false          assert_equal @quoter.quoted_false, @quoter.quote(false, nil) -        assert_equal '0', @quoter.quote(false, Struct.new(:type).new(:integer)) +        assert_equal '0', @quoter.quote(false, Type::Integer.new)        end        def test_quote_float @@ -166,26 +158,26 @@ module ActiveRecord        end        def test_quote_string_int_column -        assert_equal "1", @quoter.quote('1', FakeColumn.new(:integer)) -        assert_equal "1", @quoter.quote('1.2', FakeColumn.new(:integer)) +        assert_equal "1", @quoter.quote('1', Type::Integer.new) +        assert_equal "1", @quoter.quote('1.2', Type::Integer.new)        end        def test_quote_string_float_column -        assert_equal "1.0", @quoter.quote('1', FakeColumn.new(:float)) -        assert_equal "1.2", @quoter.quote('1.2', FakeColumn.new(:float)) +        assert_equal "1.0", @quoter.quote('1', Type::Float.new) +        assert_equal "1.2", @quoter.quote('1.2', Type::Float.new)        end        def test_quote_as_mb_chars_binary_column          string = ActiveSupport::Multibyte::Chars.new('lo\l') -        assert_equal "'lo\\\\l'", @quoter.quote(string, FakeColumn.new(:binary)) +        assert_equal "'lo\\\\l'", @quoter.quote(string, Type::Binary.new)        end        def test_quote_binary_without_string_to_binary -        assert_equal "'lo\\\\l'", @quoter.quote('lo\l', FakeColumn.new(:binary)) +        assert_equal "'lo\\\\l'", @quoter.quote('lo\l', Type::Binary.new)        end        def test_string_with_crazy_column -        assert_equal "'lo\\\\l'", @quoter.quote('lo\l', FakeColumn.new(:foo)) +        assert_equal "'lo\\\\l'", @quoter.quote('lo\l')        end        def test_quote_duration @@ -193,7 +185,7 @@ module ActiveRecord        end        def test_quote_duration_int_column -        assert_equal "7200", @quoter.quote(2.hours, FakeColumn.new(:integer)) +        assert_equal "7200", @quoter.quote(2.hours, Type::Integer.new)        end      end    end diff --git a/activerecord/test/cases/relations_test.rb b/activerecord/test/cases/relations_test.rb index 4b146c11bc..61111b254a 100644 --- a/activerecord/test/cases/relations_test.rb +++ b/activerecord/test/cases/relations_test.rb @@ -750,6 +750,13 @@ class RelationTest < ActiveRecord::TestCase      assert_equal [], relation.to_a    end +  def test_typecasting_where_with_array +    ids = Author.pluck(:id) +    slugs = ids.map { |id| "#{id}-as-a-slug" } + +    assert_equal Author.all.to_a, Author.where(id: slugs).to_a +  end +    def test_find_all_using_where_with_relation      david = authors(:david)      # switching the lines below would succeed in current rails | 
