Methods
S
T
Instance Public methods
setup()
# File activerecord/test/cases/adapter_test.rb, line 9
def setup
  @connection = ActiveRecord::Base.connection
end
test_charset()
# File activerecord/test/cases/adapter_test.rb, line 108
def test_charset
  assert_not_nil @connection.charset
  assert_not_equal 'character_set_database', @connection.charset
  assert_equal @connection.show_variable('character_set_database'), @connection.charset
end
test_collation()
# File activerecord/test/cases/adapter_test.rb, line 114
def test_collation
  assert_not_nil @connection.collation
  assert_not_equal 'collation_database', @connection.collation
  assert_equal @connection.show_variable('collation_database'), @connection.collation
end
test_create_record_with_pk_as_zero()
# File activerecord/test/cases/adapter_test.rb, line 27
def test_create_record_with_pk_as_zero
  Book.create(id: 0)
  assert_equal 0, Book.find(0).id
  assert_nothing_raised { Book.destroy(0) }
end
test_current_database()
# File activerecord/test/cases/adapter_test.rb, line 101
def test_current_database
  if @connection.respond_to?(:current_database)
    assert_equal ARTest.connection_config['arunit']['database'], @connection.current_database
  end
end
test_data_source_exists?()
# File activerecord/test/cases/adapter_test.rb, line 62
def test_data_source_exists?
  assert @connection.data_source_exists?("accounts")
  assert @connection.data_source_exists?(:accounts)
  assert_not @connection.data_source_exists?("nonexistingtable")
  assert_not @connection.data_source_exists?(nil)
end
test_data_sources()
# File activerecord/test/cases/adapter_test.rb, line 54
def test_data_sources
  data_sources = @connection.data_sources
  assert data_sources.include?("accounts")
  assert data_sources.include?("authors")
  assert data_sources.include?("tasks")
  assert data_sources.include?("topics")
end
test_disable_referential_integrity()
# File activerecord/test/cases/adapter_test.rb, line 225
def test_disable_referential_integrity
  assert_nothing_raised do
    @connection.disable_referential_integrity do
      # Oracle adapter uses prefetched primary key values from sequence and passes them to connection adapter insert method
      if @connection.prefetch_primary_key?
        id_value = @connection.next_sequence_value(@connection.default_sequence_name("fk_test_has_fk", "id"))
        @connection.execute "INSERT INTO fk_test_has_fk (id, fk_id) VALUES (#{id_value},0)"
      else
        @connection.execute "INSERT INTO fk_test_has_fk (fk_id) VALUES (0)"
      end
      # should delete created record as otherwise disable_referential_integrity will try to enable constraints after executed block
      # and will fail (at least on Oracle)
      @connection.execute "DELETE FROM fk_test_has_fk"
    end
  end
end
test_foreign_key_violations_are_translated_to_specific_exception()
# File activerecord/test/cases/adapter_test.rb, line 188
def test_foreign_key_violations_are_translated_to_specific_exception
  error = assert_raises(ActiveRecord::InvalidForeignKey) do
    # Oracle adapter uses prefetched primary key values from sequence and passes them to connection adapter insert method
    if @connection.prefetch_primary_key?
      id_value = @connection.next_sequence_value(@connection.default_sequence_name("fk_test_has_fk", "id"))
      @connection.execute "INSERT INTO fk_test_has_fk (id, fk_id) VALUES (#{id_value},0)"
    else
      @connection.execute "INSERT INTO fk_test_has_fk (fk_id) VALUES (0)"
    end
  end

  assert_not_nil error.cause
end
test_foreign_key_violations_are_translated_to_specific_exception_with_validate_false()
# File activerecord/test/cases/adapter_test.rb, line 202
def test_foreign_key_violations_are_translated_to_specific_exception_with_validate_false
  klass_has_fk = Class.new(ActiveRecord::Base) do
    self.table_name = 'fk_test_has_fk'
  end

  error = assert_raises(ActiveRecord::InvalidForeignKey) do
    has_fk = klass_has_fk.new
    has_fk.fk_id = 1231231231
    has_fk.save(validate: false)
  end

  assert_not_nil error.cause
end
test_indexes()
# File activerecord/test/cases/adapter_test.rb, line 69
def test_indexes
  idx_name = "accounts_idx"

  if @connection.respond_to?(:indexes)
    indexes = @connection.indexes("accounts")
    assert indexes.empty?

    @connection.add_index :accounts, :firm_id, :name => idx_name
    indexes = @connection.indexes("accounts")
    assert_equal "accounts", indexes.first.table
    assert_equal idx_name, indexes.first.name
    assert !indexes.first.unique
    assert_equal ["firm_id"], indexes.first.columns
  else
    warn "#{@connection.class} does not respond to #indexes"
  end

ensure
  @connection.remove_index(:accounts, :name => idx_name) rescue nil
end
test_log_invalid_encoding()
# File activerecord/test/cases/adapter_test.rb, line 273
def test_log_invalid_encoding
  error = assert_raise ActiveRecord::StatementInvalid do
    @connection.send :log, "SELECT 'ы' FROM DUAL" do
      raise 'ы'.force_encoding(Encoding::ASCII_8BIT)
    end
  end

  assert_not_nil error.cause
end
test_not_specifying_database_name_for_cross_database_selects()
# File activerecord/test/cases/adapter_test.rb, line 124
def test_not_specifying_database_name_for_cross_database_selects
  begin
    assert_nothing_raised do
      ActiveRecord::Base.establish_connection(ActiveRecord::Base.configurations['arunit'].except(:database))

      config = ARTest.connection_config
      ActiveRecord::Base.connection.execute(
        "SELECT #{config['arunit']['database']}.pirates.*, #{config['arunit2']['database']}.courses.* "                "FROM #{config['arunit']['database']}.pirates, #{config['arunit2']['database']}.courses"
      )
    end
  ensure
    ActiveRecord::Base.establish_connection :arunit
  end
end
test_passing_arguments_to_tables_is_deprecated()
# File activerecord/test/cases/adapter_test.rb, line 290
def test_passing_arguments_to_tables_is_deprecated
  assert_deprecated { @connection.tables(:books) }
end
test_remove_index_when_name_and_wrong_column_name_specified()
# File activerecord/test/cases/adapter_test.rb, line 90
def test_remove_index_when_name_and_wrong_column_name_specified
  index_name = "accounts_idx"

  @connection.add_index :accounts, :firm_id, :name => index_name
  assert_raises ArgumentError do
    @connection.remove_index :accounts, :name => index_name, :column => :wrong_column_name
  end
ensure
  @connection.remove_index(:accounts, :name => index_name)
end
test_reset_empty_table_with_custom_pk()
# File activerecord/test/cases/adapter_test.rb, line 163
def test_reset_empty_table_with_custom_pk
  Movie.delete_all
  Movie.connection.reset_pk_sequence! 'movies'
  assert_equal 1, Movie.create(:name => 'fight club').id
end
test_reset_table_with_non_integer_pk()
# File activerecord/test/cases/adapter_test.rb, line 169
def test_reset_table_with_non_integer_pk
  Subscriber.delete_all
  Subscriber.connection.reset_pk_sequence! 'subscribers'
  sub = Subscriber.new(:name => 'robert drake')
  sub.id = 'bob drake'
  assert_nothing_raised { sub.save! }
end
test_select_all_always_return_activerecord_result()
# File activerecord/test/cases/adapter_test.rb, line 242
def test_select_all_always_return_activerecord_result
  result = @connection.select_all "SELECT * FROM posts"
  assert result.is_a?(ActiveRecord::Result)
end
test_select_methods_passing_a_association_relation()
# File activerecord/test/cases/adapter_test.rb, line 247
def test_select_methods_passing_a_association_relation
  author = Author.create!(name: 'john')
  Post.create!(author: author, title: 'foo', body: 'bar')
  query = author.posts.where(title: 'foo').select(:title)
  assert_equal({"title" => "foo"}, @connection.select_one(query.arel, nil, query.bound_attributes))
  assert_equal({"title" => "foo"}, @connection.select_one(query))
  assert @connection.select_all(query).is_a?(ActiveRecord::Result)
  assert_equal "foo", @connection.select_value(query)
  assert_equal ["foo"], @connection.select_values(query)
end
test_select_methods_passing_a_relation()
# File activerecord/test/cases/adapter_test.rb, line 258
def test_select_methods_passing_a_relation
  Post.create!(title: 'foo', body: 'bar')
  query = Post.where(title: 'foo').select(:title)
  assert_equal({"title" => "foo"}, @connection.select_one(query.arel, nil, query.bound_attributes))
  assert_equal({"title" => "foo"}, @connection.select_one(query))
  assert @connection.select_all(query).is_a?(ActiveRecord::Result)
  assert_equal "foo", @connection.select_value(query)
  assert_equal ["foo"], @connection.select_values(query)
end
test_show_nonexistent_variable_returns_nil()
# File activerecord/test/cases/adapter_test.rb, line 120
def test_show_nonexistent_variable_returns_nil
  assert_nil @connection.show_variable('foo_bar_baz')
end
test_table_alias()
# File activerecord/test/cases/adapter_test.rb, line 141
def test_table_alias
  def @connection.test_table_alias_length() 10; end
  class << @connection
    alias_method :old_table_alias_length, :table_alias_length
    alias_method :table_alias_length,     :test_table_alias_length
  end

  assert_equal 'posts',      @connection.table_alias_for('posts')
  assert_equal 'posts_comm', @connection.table_alias_for('posts_comments')
  assert_equal 'dbo_posts',  @connection.table_alias_for('dbo.posts')

  class << @connection
    remove_method :table_alias_length
    alias_method :table_alias_length, :old_table_alias_length
  end
end
test_table_exists?()
# File activerecord/test/cases/adapter_test.rb, line 42
def test_table_exists?
  ActiveSupport::Deprecation.silence do
    assert @connection.table_exists?("accounts")
    assert !@connection.table_exists?("nonexistingtable")
    assert !@connection.table_exists?(nil)
  end
end
test_table_exists_checking_both_tables_and_views_is_deprecated()
# File activerecord/test/cases/adapter_test.rb, line 50
def test_table_exists_checking_both_tables_and_views_is_deprecated
  assert_deprecated { @connection.table_exists?("accounts") }
end
test_tables()
# File activerecord/test/cases/adapter_test.rb, line 33
def test_tables
  tables = nil
  ActiveSupport::Deprecation.silence { tables = @connection.tables }
  assert tables.include?("accounts")
  assert tables.include?("authors")
  assert tables.include?("tasks")
  assert tables.include?("topics")
end
test_tables_returning_both_tables_and_views_is_deprecated()
# File activerecord/test/cases/adapter_test.rb, line 285
def test_tables_returning_both_tables_and_views_is_deprecated
  assert_deprecated { @connection.tables }
end
test_uniqueness_violations_are_translated_to_specific_exception()
# File activerecord/test/cases/adapter_test.rb, line 178
def test_uniqueness_violations_are_translated_to_specific_exception
  @connection.execute "INSERT INTO subscribers(nick) VALUES('me')"
  error = assert_raises(ActiveRecord::RecordNotUnique) do
    @connection.execute "INSERT INTO subscribers(nick) VALUES('me')"
  end

  assert_not_nil error.cause
end
test_update_prepared_statement()
# File activerecord/test/cases/adapter_test.rb, line 17
def test_update_prepared_statement
  b = Book.create(name: "my \x00 book")
  b.reload
  assert_equal "my \x00 book", b.name
  b.update_attributes(name: "my other \x00 book")
  b.reload
  assert_equal "my other \x00 book", b.name
end
test_value_limit_violations_are_translated_to_specific_exception()
# File activerecord/test/cases/adapter_test.rb, line 216
def test_value_limit_violations_are_translated_to_specific_exception
  error = assert_raises(ActiveRecord::ValueTooLong) do
    Event.create(title: 'abcdefgh')
  end

  assert_not_nil error.cause
end