2005-09-23 09:29:33 -04:00
|
|
|
require 'abstract_unit'
|
|
|
|
|
|
|
|
class AdapterTest < Test::Unit::TestCase
|
|
|
|
def setup
|
|
|
|
@connection = ActiveRecord::Base.connection
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_tables
|
|
|
|
if @connection.respond_to?(:tables)
|
|
|
|
tables = @connection.tables
|
|
|
|
assert tables.include?("accounts")
|
|
|
|
assert tables.include?("authors")
|
|
|
|
assert tables.include?("tasks")
|
|
|
|
assert tables.include?("topics")
|
|
|
|
else
|
|
|
|
warn "#{@connection.class} does not respond to #tables"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_indexes
|
2006-03-17 22:54:04 -05:00
|
|
|
idx_name = "accounts_idx"
|
|
|
|
|
2005-09-23 09:29:33 -04:00
|
|
|
if @connection.respond_to?(:indexes)
|
|
|
|
indexes = @connection.indexes("accounts")
|
|
|
|
assert indexes.empty?
|
|
|
|
|
2006-01-03 23:17:23 -05:00
|
|
|
@connection.add_index :accounts, :firm_id, :name => idx_name
|
2005-09-23 09:29:33 -04:00
|
|
|
indexes = @connection.indexes("accounts")
|
|
|
|
assert_equal "accounts", indexes.first.table
|
2006-03-18 11:50:25 -05:00
|
|
|
# OpenBase does not have the concept of a named index
|
|
|
|
# Indexes are merely properties of columns.
|
|
|
|
assert_equal idx_name, indexes.first.name unless current_adapter?(:OpenBaseAdapter)
|
2005-09-23 09:29:33 -04:00
|
|
|
assert !indexes.first.unique
|
|
|
|
assert_equal ["firm_id"], indexes.first.columns
|
|
|
|
else
|
|
|
|
warn "#{@connection.class} does not respond to #indexes"
|
|
|
|
end
|
|
|
|
|
|
|
|
ensure
|
2006-03-17 22:54:04 -05:00
|
|
|
@connection.remove_index(:accounts, :name => idx_name) rescue nil
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_current_database
|
|
|
|
if @connection.respond_to?(:current_database)
|
2006-04-04 12:33:31 -04:00
|
|
|
assert_equal ENV['ARUNIT_DB_NAME'] || "activerecord_unittest", @connection.current_database
|
2006-03-17 22:54:04 -05:00
|
|
|
end
|
2005-09-23 09:29:33 -04:00
|
|
|
end
|
2005-10-16 00:05:15 -04:00
|
|
|
|
2006-03-18 00:43:35 -05:00
|
|
|
def test_table_alias
|
2006-03-18 02:31:01 -05:00
|
|
|
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
|
2006-03-18 00:43:35 -05:00
|
|
|
|
|
|
|
assert_equal 'posts', @connection.table_alias_for('posts')
|
|
|
|
assert_equal 'posts_comm', @connection.table_alias_for('posts_comments')
|
2006-03-25 23:13:25 -05:00
|
|
|
assert_equal 'dbo_posts', @connection.table_alias_for('dbo.posts')
|
2006-03-18 00:43:35 -05:00
|
|
|
|
2006-03-18 02:31:01 -05:00
|
|
|
class << @connection
|
|
|
|
alias_method :table_alias_length, :old_table_alias_length
|
|
|
|
end
|
2006-03-18 00:43:35 -05:00
|
|
|
end
|
|
|
|
|
2005-10-16 00:05:15 -04:00
|
|
|
# test resetting sequences in odd tables in postgreSQL
|
|
|
|
if ActiveRecord::Base.connection.respond_to?(:reset_pk_sequence!)
|
|
|
|
require 'fixtures/movie'
|
|
|
|
require 'fixtures/subscriber'
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2005-10-16 00:05:15 -04:00
|
|
|
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
|
|
|
|
|
2006-04-27 18:39:45 -04:00
|
|
|
if ActiveRecord::Base.connection.adapter_name != "FrontBase"
|
|
|
|
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
|
2005-10-16 00:05:15 -04:00
|
|
|
end
|
|
|
|
end
|
2006-03-18 11:50:25 -05:00
|
|
|
|
2005-09-23 09:29:33 -04:00
|
|
|
end
|