2008-01-21 17:20:51 +00:00
require " cases/helper "
2006-07-08 20:35:56 +00:00
require 'bigdecimal/util'
2008-01-18 07:31:37 +00:00
require 'models/person'
require 'models/topic'
2008-07-14 06:40:05 +00:00
require 'models/developer'
2008-01-21 17:20:51 +00:00
require MIGRATIONS_ROOT + " /valid/2_we_need_reminders "
require MIGRATIONS_ROOT + " /decimal/1_give_me_big_numbers "
2005-07-04 18:51:02 +00:00
2006-07-07 10:48:43 +00:00
if ActiveRecord :: Base . connection . supports_migrations?
2006-07-08 20:35:56 +00:00
class BigNumber < ActiveRecord :: Base ; end
2005-07-04 18:51:02 +00:00
class Reminder < ActiveRecord :: Base ; end
2006-03-04 18:46:51 +00:00
class ActiveRecord :: Migration
class << self
attr_accessor :message_count
2010-11-17 20:53:38 +00:00
end
2010-11-17 21:31:43 +00:00
2010-11-17 20:53:38 +00:00
def puts ( text = " " )
2010-12-03 19:44:11 +00:00
ActiveRecord :: Migration . message_count || = 0
ActiveRecord :: Migration . message_count += 1
2006-03-04 18:46:51 +00:00
end
end
2009-08-09 11:05:56 +00:00
class MigrationTableAndIndexTest < ActiveRecord :: TestCase
2010-12-02 01:08:01 +00:00
def test_add_schema_info_respects_prefix_and_suffix
conn = ActiveRecord :: Base . connection
2009-08-09 11:05:56 +00:00
2010-12-02 01:08:01 +00:00
conn . drop_table ( ActiveRecord :: Migrator . schema_migrations_table_name ) if conn . table_exists? ( ActiveRecord :: Migrator . schema_migrations_table_name )
2009-08-10 14:32:38 +00:00
# Use shorter prefix and suffix as in Oracle database identifier cannot be larger than 30 characters
ActiveRecord :: Base . table_name_prefix = 'p_'
ActiveRecord :: Base . table_name_suffix = '_s'
2010-12-02 01:08:01 +00:00
conn . drop_table ( ActiveRecord :: Migrator . schema_migrations_table_name ) if conn . table_exists? ( ActiveRecord :: Migrator . schema_migrations_table_name )
2009-08-09 11:05:56 +00:00
2010-12-02 01:08:01 +00:00
conn . initialize_schema_migrations_table
2009-08-09 11:05:56 +00:00
2010-12-02 01:08:01 +00:00
assert_equal " p_unique_schema_migrations_s " , conn . indexes ( ActiveRecord :: Migrator . schema_migrations_table_name ) [ 0 ] [ :name ]
2009-08-09 11:05:56 +00:00
ensure
ActiveRecord :: Base . table_name_prefix = " "
ActiveRecord :: Base . table_name_suffix = " "
end
end
2008-01-21 17:20:51 +00:00
class MigrationTest < ActiveRecord :: TestCase
2005-09-23 15:00:56 +00:00
self . use_transactional_fixtures = false
2008-01-18 07:30:42 +00:00
2007-09-22 18:23:30 +00:00
fixtures :people
2005-09-23 15:00:56 +00:00
2005-07-04 18:51:02 +00:00
def setup
2006-03-04 18:46:51 +00:00
ActiveRecord :: Migration . verbose = true
2010-12-03 19:44:11 +00:00
ActiveRecord :: Migration . message_count = 0
2005-07-04 18:51:02 +00:00
end
def teardown
2008-04-09 16:20:15 +00:00
ActiveRecord :: Base . connection . initialize_schema_migrations_table
ActiveRecord :: Base . connection . execute " DELETE FROM #{ ActiveRecord :: Migrator . schema_migrations_table_name } "
2005-07-04 18:51:02 +00:00
2006-07-08 20:35:56 +00:00
%w( reminders people_reminders prefix_reminders_suffix ) . each do | table |
Reminder . connection . drop_table ( table ) rescue nil
end
2005-07-04 18:51:02 +00:00
Reminder . reset_column_information
2006-07-10 18:24:35 +00:00
%w( last_name key bio age height wealth birthday favorite_day
2007-10-07 04:52:09 +00:00
moment_of_truth male administrator funny ) . each do | column |
2006-07-08 20:35:56 +00:00
Person . connection . remove_column ( 'people' , column ) rescue nil
end
2006-07-08 17:13:21 +00:00
Person . connection . remove_column ( " people " , " first_name " ) rescue nil
2006-08-23 05:49:40 +00:00
Person . connection . remove_column ( " people " , " middle_name " ) rescue nil
2006-07-08 17:13:21 +00:00
Person . connection . add_column ( " people " , " first_name " , :string , :limit = > 40 )
2005-07-04 18:51:02 +00:00
Person . reset_column_information
end
2005-12-20 21:43:47 +00:00
2005-07-05 07:19:20 +00:00
def test_add_index
2006-07-08 17:13:21 +00:00
# Limit size of last_name and key columns to support Firebird index limitations
Person . connection . add_column " people " , " last_name " , :string , :limit = > 100
Person . connection . add_column " people " , " key " , :string , :limit = > 100
2005-09-23 13:29:33 +00:00
Person . connection . add_column " people " , " administrator " , :boolean
2006-07-07 10:48:43 +00:00
2005-07-05 07:19:20 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , " last_name " ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , " last_name " ) }
2007-01-05 00:12:06 +00:00
# Orcl nds shrt indx nms. Sybs 2.
2007-09-13 23:21:14 +00:00
# OpenBase does not have named indexes. You must specify a single column name
2009-08-11 15:29:32 +00:00
unless current_adapter? ( :SybaseAdapter , :OpenBaseAdapter )
2006-08-15 23:51:27 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " , " first_name " ] ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , :column = > [ " last_name " , " first_name " ] ) }
2009-08-11 15:29:32 +00:00
# Oracle adapter cannot have specified index name larger than 30 characters
# Oracle adapter is shortening index name when just column list is given
unless current_adapter? ( :OracleAdapter )
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " , " first_name " ] ) }
2010-09-26 22:56:18 +00:00
assert_nothing_raised { Person . connection . remove_index ( " people " , :name = > :index_people_on_last_name_and_first_name ) }
2009-08-11 15:29:32 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " , " first_name " ] ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , " last_name_and_first_name " ) }
end
2006-08-15 23:51:27 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " , " first_name " ] ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , [ " last_name " , " first_name " ] ) }
2010-05-09 11:42:48 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " ] , :length = > 10 ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , " last_name " ) }
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " ] , :length = > { :last_name = > 10 } ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , [ " last_name " ] ) }
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " , " first_name " ] , :length = > 10 ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , [ " last_name " , " first_name " ] ) }
assert_nothing_raised { Person . connection . add_index ( " people " , [ " last_name " , " first_name " ] , :length = > { :last_name = > 10 , :first_name = > 20 } ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , [ " last_name " , " first_name " ] ) }
2006-08-15 23:51:27 +00:00
end
2006-07-07 10:48:43 +00:00
2006-04-20 02:41:05 +00:00
# quoting
2006-07-08 17:13:21 +00:00
# Note: changed index name from "key" to "key_idx" since "key" is a Firebird reserved word
2007-09-13 23:21:14 +00:00
# OpenBase does not have named indexes. You must specify a single column name
unless current_adapter? ( :OpenBaseAdapter )
2008-04-23 02:23:53 +00:00
Person . update_all " #{ Person . connection . quote_column_name 'key' } = #{ Person . connection . quote_column_name 'id' } " #some databases (including sqlite2 won't add a unique index if existing data non unique)
2007-09-13 23:21:14 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , [ " key " ] , :name = > " key_idx " , :unique = > true ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , :name = > " key_idx " , :unique = > true ) }
end
2008-01-18 07:30:42 +00:00
2006-03-18 03:02:32 +00:00
# Sybase adapter does not support indexes on :boolean columns
2007-09-13 23:21:14 +00:00
# OpenBase does not have named indexes. You must specify a single column
unless current_adapter? ( :SybaseAdapter , :OpenBaseAdapter )
2006-03-18 03:02:32 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , %w( last_name first_name administrator ) , :name = > " named_admin " ) }
assert_nothing_raised { Person . connection . remove_index ( " people " , :name = > " named_admin " ) }
end
2005-07-05 07:19:20 +00:00
end
2005-07-27 17:06:22 +00:00
2010-09-27 18:59:45 +00:00
def test_index_symbol_names
assert_nothing_raised { Person . connection . add_index :people , :primary_contact_id , :name = > :symbol_index_name }
assert Person . connection . index_exists? ( :people , :primary_contact_id , :name = > :symbol_index_name )
assert_nothing_raised { Person . connection . remove_index :people , :name = > :symbol_index_name }
assert ! Person . connection . index_exists? ( :people , :primary_contact_id , :name = > :symbol_index_name )
end
2010-05-16 16:50:25 +00:00
def test_add_index_length_limit
good_index_name = 'x' * Person . connection . index_name_length
too_long_index_name = good_index_name + 'x'
2010-09-17 04:31:25 +00:00
assert_raise ( ArgumentError ) { Person . connection . add_index ( " people " , " first_name " , :name = > too_long_index_name ) }
2010-03-18 16:49:23 +00:00
assert ! Person . connection . index_name_exists? ( " people " , too_long_index_name , false )
2010-05-16 16:50:25 +00:00
assert_nothing_raised { Person . connection . add_index ( " people " , " first_name " , :name = > good_index_name ) }
2010-03-18 16:49:23 +00:00
assert Person . connection . index_name_exists? ( " people " , good_index_name , false )
2010-09-17 04:31:25 +00:00
Person . connection . remove_index ( " people " , :name = > good_index_name )
2010-05-16 16:50:25 +00:00
end
def test_remove_nonexistent_index
# we do this by name, so OpenBase is a wash as noted above
unless current_adapter? ( :OpenBaseAdapter )
2010-09-17 04:31:25 +00:00
assert_raise ( ArgumentError ) { Person . connection . remove_index ( " people " , " no_such_index " ) }
2010-05-16 16:50:25 +00:00
end
end
def test_rename_index
unless current_adapter? ( :OpenBaseAdapter )
# keep the names short to make Oracle and similar behave
Person . connection . add_index ( 'people' , [ :first_name ] , :name = > 'old_idx' )
assert_nothing_raised { Person . connection . rename_index ( 'people' , 'old_idx' , 'new_idx' ) }
# if the adapter doesn't support the indexes call, pick defaults that let the test pass
2010-03-18 16:49:23 +00:00
assert ! Person . connection . index_name_exists? ( 'people' , 'old_idx' , false )
assert Person . connection . index_name_exists? ( 'people' , 'new_idx' , true )
2010-05-16 16:50:25 +00:00
end
end
def test_double_add_index
unless current_adapter? ( :OpenBaseAdapter )
Person . connection . add_index ( 'people' , [ :first_name ] , :name = > 'some_idx' )
2010-09-17 04:31:25 +00:00
assert_raise ( ArgumentError ) { Person . connection . add_index ( 'people' , [ :first_name ] , :name = > 'some_idx' ) }
2010-05-16 16:50:25 +00:00
end
end
2010-03-18 16:49:23 +00:00
def test_index_exists
Person . connection . create_table :testings do | t |
t . column :foo , :string , :limit = > 100
t . column :bar , :string , :limit = > 100
end
Person . connection . add_index :testings , :foo
assert Person . connection . index_exists? ( :testings , :foo )
assert ! Person . connection . index_exists? ( :testings , :bar )
ensure
Person . connection . drop_table :testings rescue nil
end
def test_index_exists_on_multiple_columns
Person . connection . create_table :testings do | t |
t . column :foo , :string , :limit = > 100
t . column :bar , :string , :limit = > 100
end
Person . connection . add_index :testings , [ :foo , :bar ]
assert Person . connection . index_exists? ( :testings , [ :foo , :bar ] )
ensure
Person . connection . drop_table :testings rescue nil
end
def test_unique_index_exists
Person . connection . create_table :testings do | t |
t . column :foo , :string , :limit = > 100
end
Person . connection . add_index :testings , :foo , :unique = > true
assert Person . connection . index_exists? ( :testings , :foo , :unique = > true )
ensure
Person . connection . drop_table :testings rescue nil
end
def test_named_index_exists
Person . connection . create_table :testings do | t |
t . column :foo , :string , :limit = > 100
end
Person . connection . add_index :testings , :foo , :name = > " custom_index_name "
assert Person . connection . index_exists? ( :testings , :foo , :name = > " custom_index_name " )
ensure
Person . connection . drop_table :testings rescue nil
end
2009-03-14 12:58:42 +00:00
def testing_table_with_only_foo_attribute
Person . connection . create_table :testings , :id = > false do | t |
t . column :foo , :string
end
yield Person . connection
ensure
Person . connection . drop_table :testings rescue nil
end
protected :testing_table_with_only_foo_attribute
def test_create_table_without_id
testing_table_with_only_foo_attribute do | connection |
assert_equal connection . columns ( :testings ) . size , 1
end
end
def test_add_column_with_primary_key_attribute
testing_table_with_only_foo_attribute do | connection |
assert_nothing_raised { connection . add_column :testings , :id , :primary_key }
assert_equal connection . columns ( :testings ) . size , 2
end
end
2005-07-27 17:06:22 +00:00
def test_create_table_adds_id
Person . connection . create_table :testings do | t |
t . column :foo , :string
end
assert_equal %w( foo id ) ,
Person . connection . columns ( :testings ) . map { | c | c . name } . sort
ensure
Person . connection . drop_table :testings rescue nil
end
2005-07-30 10:16:21 +00:00
def test_create_table_with_not_null_column
2007-01-15 02:22:53 +00:00
assert_nothing_raised do
Person . connection . create_table :testings do | t |
t . column :foo , :string , :null = > false
end
2005-07-30 10:16:21 +00:00
end
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) do
2005-07-30 10:16:21 +00:00
Person . connection . execute " insert into testings (foo) values (NULL) "
end
ensure
Person . connection . drop_table :testings rescue nil
end
2005-09-25 15:49:35 +00:00
def test_create_table_with_defaults
2007-02-11 09:17:10 +00:00
# MySQL doesn't allow defaults on TEXT or BLOB columns.
2010-08-02 08:37:57 +00:00
mysql = current_adapter? ( :MysqlAdapter ) || current_adapter? ( :Mysql2Adapter )
2007-02-11 09:17:10 +00:00
2005-09-25 15:49:35 +00:00
Person . connection . create_table :testings do | t |
t . column :one , :string , :default = > " hello "
t . column :two , :boolean , :default = > true
t . column :three , :boolean , :default = > false
t . column :four , :integer , :default = > 1
2007-02-11 09:17:10 +00:00
t . column :five , :text , :default = > " hello " unless mysql
2005-09-25 15:49:35 +00:00
end
columns = Person . connection . columns ( :testings )
one = columns . detect { | c | c . name == " one " }
two = columns . detect { | c | c . name == " two " }
three = columns . detect { | c | c . name == " three " }
four = columns . detect { | c | c . name == " four " }
2007-02-11 09:17:10 +00:00
five = columns . detect { | c | c . name == " five " } unless mysql
2005-09-25 15:49:35 +00:00
assert_equal " hello " , one . default
2006-05-21 15:13:28 +00:00
assert_equal true , two . default
assert_equal false , three . default
2005-09-25 15:49:35 +00:00
assert_equal 1 , four . default
2007-02-11 09:17:10 +00:00
assert_equal " hello " , five . default unless mysql
2005-09-25 15:49:35 +00:00
ensure
Person . connection . drop_table :testings rescue nil
end
2006-05-12 03:59:43 +00:00
def test_create_table_with_limits
2006-05-12 05:15:17 +00:00
assert_nothing_raised do
Person . connection . create_table :testings do | t |
t . column :foo , :string , :limit = > 255
2006-05-12 03:59:43 +00:00
2006-05-12 05:15:17 +00:00
t . column :default_int , :integer
2006-05-12 03:59:43 +00:00
2008-06-27 08:06:33 +00:00
t . column :one_int , :integer , :limit = > 1
t . column :four_int , :integer , :limit = > 4
t . column :eight_int , :integer , :limit = > 8
t . column :eleven_int , :integer , :limit = > 11
2006-05-12 05:15:17 +00:00
end
2006-05-12 03:59:43 +00:00
end
columns = Person . connection . columns ( :testings )
foo = columns . detect { | c | c . name == " foo " }
assert_equal 255 , foo . limit
default = columns . detect { | c | c . name == " default_int " }
one = columns . detect { | c | c . name == " one_int " }
four = columns . detect { | c | c . name == " four_int " }
eight = columns . detect { | c | c . name == " eight_int " }
2008-06-27 08:06:33 +00:00
eleven = columns . detect { | c | c . name == " eleven_int " }
2006-05-12 03:59:43 +00:00
if current_adapter? ( :PostgreSQLAdapter )
assert_equal 'integer' , default . sql_type
assert_equal 'smallint' , one . sql_type
assert_equal 'integer' , four . sql_type
assert_equal 'bigint' , eight . sql_type
2008-06-27 08:06:33 +00:00
assert_equal 'integer' , eleven . sql_type
2010-08-02 08:37:57 +00:00
elsif current_adapter? ( :MysqlAdapter ) or current_adapter? ( :Mysql2Adapter )
2008-06-27 08:06:33 +00:00
assert_match 'int(11)' , default . sql_type
assert_match 'tinyint' , one . sql_type
assert_match 'int' , four . sql_type
assert_match 'bigint' , eight . sql_type
assert_match 'int(11)' , eleven . sql_type
2006-05-21 15:13:28 +00:00
elsif current_adapter? ( :OracleAdapter )
assert_equal 'NUMBER(38)' , default . sql_type
assert_equal 'NUMBER(1)' , one . sql_type
assert_equal 'NUMBER(4)' , four . sql_type
assert_equal 'NUMBER(8)' , eight . sql_type
2006-05-12 03:59:43 +00:00
end
ensure
Person . connection . drop_table :testings rescue nil
end
2006-07-07 10:48:43 +00:00
2008-03-18 18:23:14 +00:00
def test_create_table_with_primary_key_prefix_as_table_name_with_underscore
ActiveRecord :: Base . primary_key_prefix_type = :table_name_with_underscore
Person . connection . create_table :testings do | t |
t . column :foo , :string
end
2008-08-20 18:32:20 +00:00
assert_equal %w( foo testing_id ) , Person . connection . columns ( :testings ) . map { | c | c . name } . sort
2008-03-18 18:23:14 +00:00
ensure
Person . connection . drop_table :testings rescue nil
ActiveRecord :: Base . primary_key_prefix_type = nil
end
def test_create_table_with_primary_key_prefix_as_table_name
ActiveRecord :: Base . primary_key_prefix_type = :table_name
Person . connection . create_table :testings do | t |
t . column :foo , :string
end
2008-08-20 18:32:20 +00:00
assert_equal %w( foo testingid ) , Person . connection . columns ( :testings ) . map { | c | c . name } . sort
2008-03-18 18:23:14 +00:00
ensure
Person . connection . drop_table :testings rescue nil
ActiveRecord :: Base . primary_key_prefix_type = nil
end
2009-02-04 02:25:37 +00:00
def test_create_table_with_force_true_does_not_drop_nonexisting_table
if Person . connection . table_exists? ( :testings2 )
Person . connection . drop_table :testings2
end
2008-05-06 23:08:57 +00:00
2009-02-04 02:25:37 +00:00
# using a copy as we need the drop_table method to
# continue to work for the ensure block of the test
temp_conn = Person . connection . dup
temp_conn . expects ( :drop_table ) . never
temp_conn . create_table :testings2 , :force = > true do | t |
t . column :foo , :string
2008-05-06 23:08:57 +00:00
end
2009-02-04 02:25:37 +00:00
ensure
Person . connection . drop_table :testings2 rescue nil
2008-05-06 23:08:57 +00:00
end
2008-08-22 11:48:00 +00:00
def test_create_table_with_timestamps_should_create_datetime_columns
table_name = :testings
Person . connection . create_table table_name do | t |
t . timestamps
end
created_columns = Person . connection . columns ( table_name )
created_at_column = created_columns . detect { | c | c . name == 'created_at' }
updated_at_column = created_columns . detect { | c | c . name == 'updated_at' }
assert created_at_column . null
assert updated_at_column . null
ensure
Person . connection . drop_table table_name rescue nil
end
def test_create_table_with_timestamps_should_create_datetime_columns_with_options
table_name = :testings
Person . connection . create_table table_name do | t |
t . timestamps :null = > false
end
created_columns = Person . connection . columns ( table_name )
created_at_column = created_columns . detect { | c | c . name == 'created_at' }
updated_at_column = created_columns . detect { | c | c . name == 'updated_at' }
assert ! created_at_column . null
assert ! updated_at_column . null
ensure
Person . connection . drop_table table_name rescue nil
end
2008-03-18 18:23:14 +00:00
2009-03-12 13:21:22 +00:00
def test_create_table_without_a_block
table_name = :testings
Person . connection . create_table table_name
ensure
Person . connection . drop_table table_name rescue nil
end
2008-11-19 16:09:44 +00:00
# Sybase, and SQLite3 will not allow you to add a NOT NULL
2006-11-05 02:01:31 +00:00
# column to a table without a default value.
2010-10-19 17:18:54 +00:00
unless current_adapter? ( :SybaseAdapter , :SQLite3Adapter )
2005-10-28 07:40:28 +00:00
def test_add_column_not_null_without_default
Person . connection . create_table :testings do | t |
t . column :foo , :string
end
Person . connection . add_column :testings , :bar , :string , :null = > false
2006-07-07 10:48:43 +00:00
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) do
2005-10-28 07:40:28 +00:00
Person . connection . execute " insert into testings (foo, bar) values ('hello', NULL) "
end
ensure
Person . connection . drop_table :testings rescue nil
end
end
2006-07-07 10:48:43 +00:00
2005-10-28 07:40:28 +00:00
def test_add_column_not_null_with_default
2006-07-08 17:13:21 +00:00
Person . connection . create_table :testings do | t |
2005-07-30 10:16:21 +00:00
t . column :foo , :string
end
2008-01-18 07:30:42 +00:00
con = Person . connection
2007-01-05 00:12:06 +00:00
Person . connection . enable_identity_insert ( " testings " , true ) if current_adapter? ( :SybaseAdapter )
2006-07-10 18:24:35 +00:00
Person . connection . execute " insert into testings ( #{ con . quote_column_name ( 'id' ) } , #{ con . quote_column_name ( 'foo' ) } ) values (1, 'hello') "
2007-01-05 00:12:06 +00:00
Person . connection . enable_identity_insert ( " testings " , false ) if current_adapter? ( :SybaseAdapter )
2006-06-03 21:41:40 +00:00
assert_nothing_raised { Person . connection . add_column :testings , :bar , :string , :null = > false , :default = > " default " }
2005-07-30 10:16:21 +00:00
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) do
2007-09-13 23:21:14 +00:00
unless current_adapter? ( :OpenBaseAdapter )
Person . connection . execute " insert into testings ( #{ con . quote_column_name ( 'id' ) } , #{ con . quote_column_name ( 'foo' ) } , #{ con . quote_column_name ( 'bar' ) } ) values (2, 'hello', NULL) "
else
Person . connection . insert ( " INSERT INTO testings ( #{ con . quote_column_name ( 'id' ) } , #{ con . quote_column_name ( 'foo' ) } , #{ con . quote_column_name ( 'bar' ) } ) VALUES (2, 'hello', NULL) " ,
" Testing Insert " , " id " , 2 )
end
2005-07-30 10:16:21 +00:00
end
ensure
Person . connection . drop_table :testings rescue nil
end
2006-07-07 10:48:43 +00:00
2006-07-08 20:35:56 +00:00
# We specifically do a manual INSERT here, and then test only the SELECT
# functionality. This allows us to more easily catch INSERT being broken,
# but SELECT actually working fine.
def test_native_decimal_insert_manual_vs_automatic
2007-03-16 21:41:09 +00:00
correct_value = '0012345678901234567890.0123456789' . to_d
2006-07-08 20:35:56 +00:00
Person . delete_all
Person . connection . add_column " people " , " wealth " , :decimal , :precision = > '30' , :scale = > '10'
Person . reset_column_information
# Do a manual insertion
2006-07-10 18:10:50 +00:00
if current_adapter? ( :OracleAdapter )
Person . connection . execute " insert into people (id, wealth) values (people_seq.nextval, 12345678901234567890.0123456789) "
2008-05-22 10:19:10 +00:00
elsif current_adapter? ( :OpenBaseAdapter ) || ( current_adapter? ( :MysqlAdapter ) && Mysql . client_version < 50003 ) #before mysql 5.0.3 decimals stored as strings
2007-09-13 23:21:14 +00:00
Person . connection . execute " insert into people (wealth) values ('12345678901234567890.0123456789') "
2006-07-10 18:10:50 +00:00
else
Person . connection . execute " insert into people (wealth) values (12345678901234567890.0123456789) "
end
2006-07-08 20:35:56 +00:00
# SELECT
row = Person . find ( :first )
assert_kind_of BigDecimal , row . wealth
# If this assert fails, that means the SELECT is broken!
2007-05-18 01:14:18 +00:00
unless current_adapter? ( :SQLite3Adapter )
assert_equal correct_value , row . wealth
end
2006-07-08 20:35:56 +00:00
# Reset to old state
Person . delete_all
# Now use the Rails insertion
assert_nothing_raised { Person . create :wealth = > BigDecimal . new ( " 12345678901234567890.0123456789 " ) }
# SELECT
row = Person . find ( :first )
assert_kind_of BigDecimal , row . wealth
# If these asserts fail, that means the INSERT (create function, or cast to SQL) is broken!
2007-05-18 01:14:18 +00:00
unless current_adapter? ( :SQLite3Adapter )
assert_equal correct_value , row . wealth
end
2006-07-08 20:35:56 +00:00
# Reset to old state
Person . connection . del_column " people " , " wealth " rescue nil
Person . reset_column_information
end
2008-01-16 03:54:15 +00:00
def test_add_column_with_precision_and_scale
Person . connection . add_column 'people' , 'wealth' , :decimal , :precision = > 9 , :scale = > 7
Person . reset_column_information
wealth_column = Person . columns_hash [ 'wealth' ]
assert_equal 9 , wealth_column . precision
assert_equal 7 , wealth_column . scale
end
2009-08-09 08:56:25 +00:00
2005-07-04 18:51:02 +00:00
def test_native_types
Person . delete_all
Person . connection . add_column " people " , " last_name " , :string
Person . connection . add_column " people " , " bio " , :text
Person . connection . add_column " people " , " age " , :integer
Person . connection . add_column " people " , " height " , :float
2006-07-08 20:35:56 +00:00
Person . connection . add_column " people " , " wealth " , :decimal , :precision = > '30' , :scale = > '10'
2005-07-04 18:51:02 +00:00
Person . connection . add_column " people " , " birthday " , :datetime
Person . connection . add_column " people " , " favorite_day " , :date
2007-03-04 04:33:55 +00:00
Person . connection . add_column " people " , " moment_of_truth " , :datetime
2005-07-04 18:51:02 +00:00
Person . connection . add_column " people " , " male " , :boolean
2007-09-22 18:23:30 +00:00
Person . reset_column_information
2006-07-07 10:48:43 +00:00
2007-03-06 00:49:11 +00:00
assert_nothing_raised do
Person . create :first_name = > 'bob' , :last_name = > 'bobsen' ,
:bio = > " I was born .... " , :age = > 18 , :height = > 1 . 78 ,
:wealth = > BigDecimal . new ( " 12345678901234567890.0123456789 " ) ,
:birthday = > 18 . years . ago , :favorite_day = > 10 . days . ago ,
2007-11-24 04:59:21 +00:00
:moment_of_truth = > " 1782-10-10 21:40:18 " , :male = > true
2007-03-06 00:49:11 +00:00
end
bob = Person . find ( :first )
2006-07-08 20:35:56 +00:00
assert_equal 'bob' , bob . first_name
assert_equal 'bobsen' , bob . last_name
assert_equal " I was born .... " , bob . bio
assert_equal 18 , bob . age
# Test for 30 significent digits (beyond the 16 of float), 10 of them
# after the decimal place.
2008-01-18 07:30:42 +00:00
2007-05-18 01:14:18 +00:00
unless current_adapter? ( :SQLite3Adapter )
assert_equal BigDecimal . new ( " 0012345678901234567890.0123456789 " ) , bob . wealth
end
2008-01-18 07:30:42 +00:00
2006-07-08 20:35:56 +00:00
assert_equal true , bob . male?
2006-07-07 10:48:43 +00:00
2005-07-04 18:51:02 +00:00
assert_equal String , bob . first_name . class
assert_equal String , bob . last_name . class
assert_equal String , bob . bio . class
assert_equal Fixnum , bob . age . class
assert_equal Time , bob . birthday . class
2005-10-28 07:40:28 +00:00
2008-11-19 16:09:44 +00:00
if current_adapter? ( :OracleAdapter , :SybaseAdapter )
2006-07-10 18:24:35 +00:00
# Sybase, and Oracle don't differentiate between date/time
2005-10-28 07:40:28 +00:00
assert_equal Time , bob . favorite_day . class
else
assert_equal Date , bob . favorite_day . class
end
2009-03-22 22:18:21 +00:00
# Oracle adapter stores Time or DateTime with timezone value already in _before_type_cast column
# therefore no timezone change is done afterwards when default timezone is changed
unless current_adapter? ( :OracleAdapter )
# Test DateTime column and defaults, including timezone.
# FIXME: moment of truth may be Time on 64-bit platforms.
if bob . moment_of_truth . is_a? ( DateTime )
with_env_tz 'US/Eastern' do
2010-08-21 02:46:30 +00:00
bob . reload
2009-03-22 22:18:21 +00:00
assert_equal DateTime . local_offset , bob . moment_of_truth . offset
assert_not_equal 0 , bob . moment_of_truth . offset
assert_not_equal " Z " , bob . moment_of_truth . zone
# US/Eastern is -5 hours from GMT
assert_equal Rational ( - 5 , 24 ) , bob . moment_of_truth . offset
2010-03-16 01:09:33 +00:00
assert_match ( / \ A-05:?00 \ Z / , bob . moment_of_truth . zone ) #ruby 1.8.6 uses HH:MM, prior versions use HHMM
2009-03-22 22:18:21 +00:00
assert_equal DateTime :: ITALY , bob . moment_of_truth . start
end
2008-04-01 00:28:40 +00:00
end
2007-03-16 08:25:37 +00:00
end
2007-03-09 00:34:17 +00:00
2010-05-19 19:14:51 +00:00
assert_instance_of TrueClass , bob . male?
2006-07-08 20:35:56 +00:00
assert_kind_of BigDecimal , bob . wealth
2005-07-04 18:51:02 +00:00
end
2010-08-02 08:37:57 +00:00
if current_adapter? ( :MysqlAdapter ) or current_adapter? ( :Mysql2Adapter )
2007-05-25 21:21:41 +00:00
def test_unabstracted_database_dependent_types
Person . delete_all
ActiveRecord :: Migration . add_column :people , :intelligence_quotient , :tinyint
2007-09-22 22:33:51 +00:00
Person . reset_column_information
2010-03-16 01:09:33 +00:00
assert_match ( / tinyint / , Person . columns_hash [ 'intelligence_quotient' ] . sql_type )
2007-05-25 21:21:41 +00:00
ensure
2007-09-28 14:18:47 +00:00
ActiveRecord :: Migration . remove_column :people , :intelligence_quotient rescue nil
2007-05-25 21:21:41 +00:00
end
end
2005-09-28 17:50:28 +00:00
def test_add_remove_single_field_using_string_arguments
2005-07-04 18:51:02 +00:00
assert ! Person . column_methods_hash . include? ( :last_name )
2005-09-28 17:50:28 +00:00
ActiveRecord :: Migration . add_column 'people' , 'last_name' , :string
2005-07-04 18:51:02 +00:00
Person . reset_column_information
assert Person . column_methods_hash . include? ( :last_name )
2006-07-07 10:48:43 +00:00
2005-09-28 17:50:28 +00:00
ActiveRecord :: Migration . remove_column 'people' , 'last_name'
Person . reset_column_information
assert ! Person . column_methods_hash . include? ( :last_name )
end
def test_add_remove_single_field_using_symbol_arguments
assert ! Person . column_methods_hash . include? ( :last_name )
ActiveRecord :: Migration . add_column :people , :last_name , :string
Person . reset_column_information
assert Person . column_methods_hash . include? ( :last_name )
ActiveRecord :: Migration . remove_column :people , :last_name
2005-07-04 18:51:02 +00:00
Person . reset_column_information
assert ! Person . column_methods_hash . include? ( :last_name )
end
2006-07-07 10:48:43 +00:00
2010-08-02 08:37:57 +00:00
if current_adapter? ( :MysqlAdapter ) or current_adapter? ( :Mysql2Adapter )
2009-09-27 23:25:18 +00:00
def testing_table_for_positioning
Person . connection . create_table :testings , :id = > false do | t |
t . column :first , :integer
t . column :second , :integer
t . column :third , :integer
end
yield Person . connection
ensure
Person . connection . drop_table :testings rescue nil
end
protected :testing_table_for_positioning
def test_column_positioning
testing_table_for_positioning do | conn |
assert_equal %w( first second third ) , conn . columns ( :testings ) . map { | c | c . name }
end
end
def test_add_column_with_positioning
testing_table_for_positioning do | conn |
conn . add_column :testings , :new_col , :integer
assert_equal %w( first second third new_col ) , conn . columns ( :testings ) . map { | c | c . name }
end
testing_table_for_positioning do | conn |
conn . add_column :testings , :new_col , :integer , :first = > true
assert_equal %w( new_col first second third ) , conn . columns ( :testings ) . map { | c | c . name }
end
testing_table_for_positioning do | conn |
conn . add_column :testings , :new_col , :integer , :after = > :first
assert_equal %w( first new_col second third ) , conn . columns ( :testings ) . map { | c | c . name }
end
end
def test_change_column_with_positioning
testing_table_for_positioning do | conn |
conn . change_column :testings , :second , :integer , :first = > true
assert_equal %w( second first third ) , conn . columns ( :testings ) . map { | c | c . name }
end
testing_table_for_positioning do | conn |
conn . change_column :testings , :second , :integer , :after = > :third
assert_equal %w( first third second ) , conn . columns ( :testings ) . map { | c | c . name }
end
end
end
2005-07-05 07:19:20 +00:00
def test_add_rename
Person . delete_all
2006-07-07 10:48:43 +00:00
2005-07-05 07:19:20 +00:00
begin
2006-07-07 10:48:43 +00:00
Person . connection . add_column " people " , " girlfriend " , :string
2007-09-22 18:23:30 +00:00
Person . reset_column_information
2006-07-07 10:48:43 +00:00
Person . create :girlfriend = > 'bobette'
2005-07-05 07:19:20 +00:00
Person . connection . rename_column " people " , " girlfriend " , " exgirlfriend "
2006-07-07 10:48:43 +00:00
Person . reset_column_information
2005-07-05 07:19:20 +00:00
bob = Person . find ( :first )
2006-07-07 10:48:43 +00:00
2005-07-05 07:19:20 +00:00
assert_equal " bobette " , bob . exgirlfriend
ensure
Person . connection . remove_column ( " people " , " girlfriend " ) rescue nil
Person . connection . remove_column ( " people " , " exgirlfriend " ) rescue nil
end
2006-07-07 10:48:43 +00:00
2005-07-05 07:19:20 +00:00
end
2006-07-07 10:48:43 +00:00
2005-10-25 19:28:53 +00:00
def test_rename_column_using_symbol_arguments
begin
2007-09-22 18:23:30 +00:00
names_before = Person . find ( :all ) . map ( & :first_name )
2005-10-25 19:28:53 +00:00
Person . connection . rename_column :people , :first_name , :nick_name
Person . reset_column_information
assert Person . column_names . include? ( " nick_name " )
2007-09-22 18:23:30 +00:00
assert_equal names_before , Person . find ( :all ) . map ( & :nick_name )
2005-10-25 19:28:53 +00:00
ensure
Person . connection . remove_column ( " people " , " nick_name " )
Person . connection . add_column ( " people " , " first_name " , :string )
end
end
2006-07-07 10:48:43 +00:00
2005-10-25 19:28:53 +00:00
def test_rename_column
begin
2007-09-22 18:23:30 +00:00
names_before = Person . find ( :all ) . map ( & :first_name )
2005-10-25 19:28:53 +00:00
Person . connection . rename_column " people " , " first_name " , " nick_name "
Person . reset_column_information
assert Person . column_names . include? ( " nick_name " )
2007-09-22 18:23:30 +00:00
assert_equal names_before , Person . find ( :all ) . map ( & :nick_name )
2005-10-25 19:28:53 +00:00
ensure
Person . connection . remove_column ( " people " , " nick_name " )
Person . connection . add_column ( " people " , " first_name " , :string )
end
end
2008-06-21 23:18:30 +00:00
def test_rename_column_preserves_default_value_not_null
begin
default_before = Developer . connection . columns ( " developers " ) . find { | c | c . name == " salary " } . default
assert_equal 70000 , default_before
Developer . connection . rename_column " developers " , " salary " , " anual_salary "
Developer . reset_column_information
assert Developer . column_names . include? ( " anual_salary " )
default_after = Developer . connection . columns ( " developers " ) . find { | c | c . name == " anual_salary " } . default
assert_equal 70000 , default_after
ensure
Developer . connection . rename_column " developers " , " anual_salary " , " salary "
Developer . reset_column_information
end
end
def test_rename_nonexistent_column
ActiveRecord :: Base . connection . create_table ( :hats ) do | table |
table . column :hat_name , :string , :default = > nil
end
2009-03-22 22:18:21 +00:00
exception = if current_adapter? ( :PostgreSQLAdapter , :OracleAdapter )
2008-07-14 06:40:05 +00:00
ActiveRecord :: StatementInvalid
else
ActiveRecord :: ActiveRecordError
end
2009-03-08 20:11:58 +00:00
assert_raise ( exception ) do
2008-06-21 23:18:30 +00:00
Person . connection . rename_column " hats " , " nonexistent " , " should_fail "
end
ensure
ActiveRecord :: Base . connection . drop_table ( :hats )
end
2006-07-07 10:48:43 +00:00
2007-05-29 07:21:41 +00:00
def test_rename_column_with_sql_reserved_word
begin
assert_nothing_raised { Person . connection . rename_column " people " , " first_name " , " group " }
Person . reset_column_information
assert Person . column_names . include? ( " group " )
ensure
Person . connection . remove_column ( " people " , " group " ) rescue nil
Person . connection . add_column ( " people " , " first_name " , :string ) rescue nil
end
end
2008-01-18 07:30:42 +00:00
2007-12-20 22:28:12 +00:00
def test_rename_column_with_an_index
ActiveRecord :: Base . connection . create_table ( :hats ) do | table |
table . column :hat_name , :string , :limit = > 100
table . column :hat_size , :integer
end
2008-02-15 20:12:45 +00:00
Person . connection . add_index :hats , :hat_name
2007-12-20 22:28:12 +00:00
assert_nothing_raised do
Person . connection . rename_column " hats " , " hat_name " , " name "
end
ensure
ActiveRecord :: Base . connection . drop_table ( :hats )
end
def test_remove_column_with_index
ActiveRecord :: Base . connection . create_table ( :hats ) do | table |
table . column :hat_name , :string , :limit = > 100
table . column :hat_size , :integer
end
ActiveRecord :: Base . connection . add_index " hats " , " hat_size "
assert_nothing_raised { Person . connection . remove_column ( " hats " , " hat_size " ) }
ensure
ActiveRecord :: Base . connection . drop_table ( :hats )
end
def test_remove_column_with_multi_column_index
ActiveRecord :: Base . connection . create_table ( :hats ) do | table |
table . column :hat_name , :string , :limit = > 100
table . column :hat_size , :integer
table . column :hat_style , :string , :limit = > 100
end
2009-08-11 15:29:32 +00:00
ActiveRecord :: Base . connection . add_index " hats " , [ " hat_style " , " hat_size " ] , :unique = > true
2007-12-20 22:28:12 +00:00
assert_nothing_raised { Person . connection . remove_column ( " hats " , " hat_size " ) }
ensure
ActiveRecord :: Base . connection . drop_table ( :hats )
end
2010-06-09 04:13:24 +00:00
def test_remove_column_no_second_parameter_raises_exception
assert_raise ( ArgumentError ) { Person . connection . remove_column ( " funny " ) }
end
2007-10-08 03:28:28 +00:00
def test_change_type_of_not_null_column
assert_nothing_raised do
Topic . connection . change_column " topics " , " written_on " , :datetime , :null = > false
Topic . reset_column_information
2008-01-18 07:30:42 +00:00
2007-10-08 03:28:28 +00:00
Topic . connection . change_column " topics " , " written_on " , :datetime , :null = > false
Topic . reset_column_information
2010-08-15 10:19:06 +00:00
Topic . connection . change_column " topics " , " written_on " , :datetime , :null = > true
Topic . reset_column_information
2007-10-08 03:28:28 +00:00
end
end
2007-05-29 07:21:41 +00:00
2010-10-19 17:18:54 +00:00
if current_adapter? ( :SQLite3Adapter )
2009-03-20 02:24:18 +00:00
def test_rename_table_for_sqlite_should_work_with_reserved_words
begin
assert_nothing_raised do
ActiveRecord :: Base . connection . rename_table :references , :old_references
ActiveRecord :: Base . connection . create_table :octopuses do | t |
t . column :url , :string
end
end
assert_nothing_raised { ActiveRecord :: Base . connection . rename_table :octopuses , :references }
# Using explicit id in insert for compatibility across all databases
con = ActiveRecord :: Base . connection
assert_nothing_raised do
con . execute " INSERT INTO 'references' ( #{ con . quote_column_name ( 'id' ) } , #{ con . quote_column_name ( 'url' ) } ) VALUES (1, 'http://rubyonrails.com') "
end
assert_equal 'http://rubyonrails.com' , ActiveRecord :: Base . connection . select_value ( " SELECT url FROM 'references' WHERE id=1 " )
ensure
ActiveRecord :: Base . connection . drop_table :references
ActiveRecord :: Base . connection . rename_table :old_references , :references
end
end
end
2005-10-06 14:10:45 +00:00
def test_rename_table
begin
ActiveRecord :: Base . connection . create_table :octopuses do | t |
t . column :url , :string
2005-10-29 18:40:49 +00:00
end
2005-10-06 14:10:45 +00:00
ActiveRecord :: Base . connection . rename_table :octopuses , :octopi
2005-10-29 18:40:49 +00:00
2006-07-08 17:13:21 +00:00
# Using explicit id in insert for compatibility across all databases
2008-01-18 07:30:42 +00:00
con = ActiveRecord :: Base . connection
2007-01-05 00:12:06 +00:00
con . enable_identity_insert ( " octopi " , true ) if current_adapter? ( :SybaseAdapter )
2006-07-10 18:24:35 +00:00
assert_nothing_raised { con . execute " INSERT INTO octopi ( #{ con . quote_column_name ( 'id' ) } , #{ con . quote_column_name ( 'url' ) } ) VALUES (1, 'http://www.foreverflying.com/octopus-black7.jpg') " }
2007-01-05 00:12:06 +00:00
con . enable_identity_insert ( " octopi " , false ) if current_adapter? ( :SybaseAdapter )
2005-10-06 14:10:45 +00:00
assert_equal 'http://www.foreverflying.com/octopus-black7.jpg' , ActiveRecord :: Base . connection . select_value ( " SELECT url FROM octopi WHERE id=1 " )
2005-10-29 18:40:49 +00:00
2005-10-06 14:10:45 +00:00
ensure
ActiveRecord :: Base . connection . drop_table :octopuses rescue nil
ActiveRecord :: Base . connection . drop_table :octopi rescue nil
end
end
2008-01-18 07:30:42 +00:00
2007-10-07 04:52:09 +00:00
def test_change_column_nullability
2008-01-18 07:30:42 +00:00
Person . delete_all
2007-10-07 04:52:09 +00:00
Person . connection . add_column " people " , " funny " , :boolean
Person . reset_column_information
assert Person . columns_hash [ " funny " ] . null , " Column 'funny' must initially allow nulls "
Person . connection . change_column " people " , " funny " , :boolean , :null = > false , :default = > true
Person . reset_column_information
assert ! Person . columns_hash [ " funny " ] . null , " Column 'funny' must *not* allow nulls at this point "
Person . connection . change_column " people " , " funny " , :boolean , :null = > true
Person . reset_column_information
assert Person . columns_hash [ " funny " ] . null , " Column 'funny' must allow nulls again at this point "
end
2005-10-29 18:40:49 +00:00
2006-10-09 02:14:36 +00:00
def test_rename_table_with_an_index
begin
ActiveRecord :: Base . connection . create_table :octopuses do | t |
t . column :url , :string
end
ActiveRecord :: Base . connection . add_index :octopuses , :url
2008-01-18 07:30:42 +00:00
2006-10-09 02:14:36 +00:00
ActiveRecord :: Base . connection . rename_table :octopuses , :octopi
# Using explicit id in insert for compatibility across all databases
2008-01-18 07:30:42 +00:00
con = ActiveRecord :: Base . connection
2007-01-05 00:12:06 +00:00
con . enable_identity_insert ( " octopi " , true ) if current_adapter? ( :SybaseAdapter )
2006-10-09 02:14:36 +00:00
assert_nothing_raised { con . execute " INSERT INTO octopi ( #{ con . quote_column_name ( 'id' ) } , #{ con . quote_column_name ( 'url' ) } ) VALUES (1, 'http://www.foreverflying.com/octopus-black7.jpg') " }
2007-01-05 00:12:06 +00:00
con . enable_identity_insert ( " octopi " , false ) if current_adapter? ( :SybaseAdapter )
2006-10-09 02:14:36 +00:00
assert_equal 'http://www.foreverflying.com/octopus-black7.jpg' , ActiveRecord :: Base . connection . select_value ( " SELECT url FROM octopi WHERE id=1 " )
assert ActiveRecord :: Base . connection . indexes ( :octopi ) . first . columns . include? ( " url " )
ensure
ActiveRecord :: Base . connection . drop_table :octopuses rescue nil
ActiveRecord :: Base . connection . drop_table :octopi rescue nil
end
end
2005-07-05 07:19:20 +00:00
def test_change_column
2005-12-20 21:43:47 +00:00
Person . connection . add_column 'people' , 'age' , :integer
2009-08-08 00:04:19 +00:00
label = " test_change_column Columns "
old_columns = Person . connection . columns ( Person . table_name , label )
2005-12-20 21:43:47 +00:00
assert old_columns . find { | c | c . name == 'age' and c . type == :integer }
assert_nothing_raised { Person . connection . change_column " people " , " age " , :string }
2006-07-07 10:48:43 +00:00
2009-08-08 00:04:19 +00:00
new_columns = Person . connection . columns ( Person . table_name , label )
2005-12-20 21:43:47 +00:00
assert_nil new_columns . find { | c | c . name == 'age' and c . type == :integer }
assert new_columns . find { | c | c . name == 'age' and c . type == :string }
2006-05-14 18:37:22 +00:00
2009-08-08 00:04:19 +00:00
old_columns = Topic . connection . columns ( Topic . table_name , label )
2006-05-14 18:37:22 +00:00
assert old_columns . find { | c | c . name == 'approved' and c . type == :boolean and c . default == true }
assert_nothing_raised { Topic . connection . change_column :topics , :approved , :boolean , :default = > false }
2009-08-08 00:04:19 +00:00
new_columns = Topic . connection . columns ( Topic . table_name , label )
2006-05-14 18:37:22 +00:00
assert_nil new_columns . find { | c | c . name == 'approved' and c . type == :boolean and c . default == true }
assert new_columns . find { | c | c . name == 'approved' and c . type == :boolean and c . default == false }
2006-05-21 15:13:28 +00:00
assert_nothing_raised { Topic . connection . change_column :topics , :approved , :boolean , :default = > true }
2006-07-07 10:48:43 +00:00
end
2008-01-18 07:30:42 +00:00
2007-01-15 02:22:53 +00:00
def test_change_column_with_nil_default
Person . connection . add_column " people " , " contributor " , :boolean , :default = > true
Person . reset_column_information
assert Person . new . contributor?
2008-01-18 07:30:42 +00:00
2007-01-15 02:22:53 +00:00
assert_nothing_raised { Person . connection . change_column " people " , " contributor " , :boolean , :default = > nil }
Person . reset_column_information
assert ! Person . new . contributor?
assert_nil Person . new . contributor
2007-01-29 22:06:08 +00:00
ensure
Person . connection . remove_column ( " people " , " contributor " ) rescue nil
2007-01-15 02:22:53 +00:00
end
2005-07-05 07:19:20 +00:00
def test_change_column_with_new_default
2007-01-15 01:24:23 +00:00
Person . connection . add_column " people " , " administrator " , :boolean , :default = > true
2006-07-07 10:48:43 +00:00
Person . reset_column_information
2005-07-05 07:19:20 +00:00
assert Person . new . administrator?
2006-07-07 10:48:43 +00:00
2007-01-15 01:24:23 +00:00
assert_nothing_raised { Person . connection . change_column " people " , " administrator " , :boolean , :default = > false }
2006-07-07 10:48:43 +00:00
Person . reset_column_information
2005-07-05 07:19:20 +00:00
assert ! Person . new . administrator?
2007-01-29 22:06:08 +00:00
ensure
Person . connection . remove_column ( " people " , " administrator " ) rescue nil
2006-07-07 10:48:43 +00:00
end
2008-01-18 07:30:42 +00:00
2007-01-15 01:24:23 +00:00
def test_change_column_default
Person . connection . change_column_default " people " , " first_name " , " Tester "
Person . reset_column_information
assert_equal " Tester " , Person . new . first_name
end
2007-10-15 07:33:53 +00:00
def test_change_column_quotes_column_names
Person . connection . create_table :testings do | t |
t . column :select , :string
end
assert_nothing_raised { Person . connection . change_column :testings , :select , :string , :limit = > 10 }
2009-03-22 22:18:21 +00:00
# Oracle needs primary key value from sequence
if current_adapter? ( :OracleAdapter )
assert_nothing_raised { Person . connection . execute " insert into testings (id, #{ Person . connection . quote_column_name ( 'select' ) } ) values (testings_seq.nextval, '7 chars') " }
else
assert_nothing_raised { Person . connection . execute " insert into testings ( #{ Person . connection . quote_column_name ( 'select' ) } ) values ('7 chars') " }
end
2007-10-15 07:33:53 +00:00
ensure
Person . connection . drop_table :testings rescue nil
end
2008-07-14 06:42:20 +00:00
def test_keeping_default_and_notnull_constaint_on_change
Person . connection . create_table :testings do | t |
t . column :title , :string
end
person_klass = Class . new ( Person )
person_klass . set_table_name 'testings'
person_klass . connection . add_column " testings " , " wealth " , :integer , :null = > false , :default = > 99
person_klass . reset_column_information
assert_equal 99 , person_klass . columns_hash [ " wealth " ] . default
assert_equal false , person_klass . columns_hash [ " wealth " ] . null
2009-03-22 22:18:21 +00:00
# Oracle needs primary key value from sequence
if current_adapter? ( :OracleAdapter )
assert_nothing_raised { person_klass . connection . execute ( " insert into testings (id, title) values (testings_seq.nextval, 'tester') " ) }
else
assert_nothing_raised { person_klass . connection . execute ( " insert into testings (title) values ('tester') " ) }
end
2008-07-14 06:42:20 +00:00
# change column default to see that column doesn't lose its not null definition
person_klass . connection . change_column_default " testings " , " wealth " , 100
person_klass . reset_column_information
assert_equal 100 , person_klass . columns_hash [ " wealth " ] . default
assert_equal false , person_klass . columns_hash [ " wealth " ] . null
# rename column to see that column doesn't lose its not null and/or default definition
person_klass . connection . rename_column " testings " , " wealth " , " money "
person_klass . reset_column_information
assert_nil person_klass . columns_hash [ " wealth " ]
assert_equal 100 , person_klass . columns_hash [ " money " ] . default
assert_equal false , person_klass . columns_hash [ " money " ] . null
# change column
person_klass . connection . change_column " testings " , " money " , :integer , :null = > false , :default = > 1000
person_klass . reset_column_information
assert_equal 1000 , person_klass . columns_hash [ " money " ] . default
assert_equal false , person_klass . columns_hash [ " money " ] . null
# change column, make it nullable and clear default
person_klass . connection . change_column " testings " , " money " , :integer , :null = > true , :default = > nil
person_klass . reset_column_information
assert_nil person_klass . columns_hash [ " money " ] . default
assert_equal true , person_klass . columns_hash [ " money " ] . null
# change_column_null, make it not nullable and set null values to a default value
person_klass . connection . execute ( 'UPDATE testings SET money = NULL' )
person_klass . connection . change_column_null " testings " , " money " , false , 2000
person_klass . reset_column_information
assert_nil person_klass . columns_hash [ " money " ] . default
assert_equal false , person_klass . columns_hash [ " money " ] . null
assert_equal [ 2000 ] , Person . connection . select_values ( " SELECT money FROM testings " ) . map { | s | s . to_i } . sort
ensure
Person . connection . drop_table :testings rescue nil
end
2007-01-15 01:24:23 +00:00
def test_change_column_default_to_null
Person . connection . change_column_default " people " , " first_name " , nil
Person . reset_column_information
assert_nil Person . new . first_name
end
2005-07-04 18:51:02 +00:00
2010-03-18 16:49:23 +00:00
def test_column_exists
Person . connection . create_table :testings do | t |
t . column :foo , :string
end
assert Person . connection . column_exists? ( :testings , :foo )
assert ! Person . connection . column_exists? ( :testings , :bar )
ensure
Person . connection . drop_table :testings rescue nil
end
def test_column_exists_with_type
Person . connection . create_table :testings do | t |
t . column :foo , :string
t . column :bar , :decimal , :precision = > 8 , :scale = > 2
end
assert Person . connection . column_exists? ( :testings , :foo , :string )
assert ! Person . connection . column_exists? ( :testings , :foo , :integer )
assert Person . connection . column_exists? ( :testings , :bar , :decimal )
assert ! Person . connection . column_exists? ( :testings , :bar , :integer )
ensure
Person . connection . drop_table :testings rescue nil
end
def test_column_exists_with_definition
Person . connection . create_table :testings do | t |
t . column :foo , :string , :limit = > 100
t . column :bar , :decimal , :precision = > 8 , :scale = > 2
end
assert Person . connection . column_exists? ( :testings , :foo , :string , :limit = > 100 )
assert ! Person . connection . column_exists? ( :testings , :foo , :string , :limit = > 50 )
assert Person . connection . column_exists? ( :testings , :bar , :decimal , :precision = > 8 , :scale = > 2 )
assert ! Person . connection . column_exists? ( :testings , :bar , :decimal , :precision = > 10 , :scale = > 2 )
ensure
Person . connection . drop_table :testings rescue nil
end
2005-07-04 18:51:02 +00:00
def test_add_table
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2006-07-07 10:48:43 +00:00
2005-07-04 18:51:02 +00:00
WeNeedReminders . up
2008-01-18 07:30:42 +00:00
assert Reminder . create ( " content " = > " hello world " , " remind_at " = > Time . now )
2005-07-04 18:51:02 +00:00
assert_equal " hello world " , Reminder . find ( :first ) . content
2006-07-07 10:48:43 +00:00
2005-07-04 18:51:02 +00:00
WeNeedReminders . down
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) { Reminder . find ( :first ) }
2005-07-04 18:51:02 +00:00
end
2006-07-08 20:35:56 +00:00
def test_add_table_with_decimals
Person . connection . drop_table :big_numbers rescue nil
assert ! BigNumber . table_exists?
GiveMeBigNumbers . up
assert BigNumber . create (
:bank_balance = > 1586 . 43 ,
:big_bank_balance = > BigDecimal ( " 1000234000567.95 " ) ,
:world_population = > 6000000000 ,
:my_house_population = > 3 ,
:value_of_e = > BigDecimal ( " 2.7182818284590452353602875 " )
)
b = BigNumber . find ( :first )
assert_not_nil b
assert_not_nil b . bank_balance
assert_not_nil b . big_bank_balance
assert_not_nil b . world_population
assert_not_nil b . my_house_population
assert_not_nil b . value_of_e
# TODO: set world_population >= 2**62 to cover 64-bit platforms and test
# is_a?(Bignum)
assert_kind_of Integer , b . world_population
assert_equal 6000000000 , b . world_population
assert_kind_of Fixnum , b . my_house_population
assert_equal 3 , b . my_house_population
assert_kind_of BigDecimal , b . bank_balance
assert_equal BigDecimal ( " 1586.43 " ) , b . bank_balance
assert_kind_of BigDecimal , b . big_bank_balance
assert_equal BigDecimal ( " 1000234000567.95 " ) , b . big_bank_balance
# This one is fun. The 'value_of_e' field is defined as 'DECIMAL' with
2007-09-28 14:18:47 +00:00
# precision/scale explicitly left out. By the SQL standard, numbers
2006-07-08 20:35:56 +00:00
# assigned to this field should be truncated but that's seldom respected.
2010-06-09 06:03:45 +00:00
if current_adapter? ( :PostgreSQLAdapter )
2006-07-08 20:35:56 +00:00
# - PostgreSQL changes the SQL spec on columns declared simply as
# "decimal" to something more useful: instead of being given a scale
# of 0, they take on the compile-time limit for precision and scale,
# so the following should succeed unless you have used really wacky
# compilation options
# - SQLite2 has the default behavior of preserving all data sent in,
# so this happens there too
assert_kind_of BigDecimal , b . value_of_e
assert_equal BigDecimal ( " 2.7182818284590452353602875 " ) , b . value_of_e
2010-10-19 17:18:54 +00:00
elsif current_adapter? ( :SQLite3Adapter )
2006-07-08 20:35:56 +00:00
# - SQLite3 stores a float, in violation of SQL
assert_kind_of BigDecimal , b . value_of_e
2010-06-16 16:59:59 +00:00
assert_in_delta BigDecimal ( " 2.71828182845905 " ) , b . value_of_e , 0 . 00000000000001
2006-07-08 20:35:56 +00:00
else
# - SQL standard is an integer
assert_kind_of Fixnum , b . value_of_e
assert_equal 2 , b . value_of_e
end
GiveMeBigNumbers . down
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) { BigNumber . find ( :first ) }
2006-07-08 20:35:56 +00:00
end
2005-07-04 18:51:02 +00:00
def test_migrator
assert ! Person . column_methods_hash . include? ( :last_name )
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2005-07-04 18:51:02 +00:00
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " )
2005-07-04 18:51:02 +00:00
2005-07-05 07:19:20 +00:00
assert_equal 3 , ActiveRecord :: Migrator . current_version
2005-07-04 18:51:02 +00:00
Person . reset_column_information
assert Person . column_methods_hash . include? ( :last_name )
assert Reminder . create ( " content " = > " hello world " , " remind_at " = > Time . now )
assert_equal " hello world " , Reminder . find ( :first ) . content
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . down ( MIGRATIONS_ROOT + " /valid " )
2005-07-04 18:51:02 +00:00
assert_equal 0 , ActiveRecord :: Migrator . current_version
Person . reset_column_information
assert ! Person . column_methods_hash . include? ( :last_name )
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) { Reminder . find ( :first ) }
2005-07-04 18:51:02 +00:00
end
2010-11-17 21:55:03 +00:00
class MockMigration < ActiveRecord :: Migration
attr_reader :went_up , :went_down
def initialize
@went_up = false
@went_down = false
end
def up
@went_up = true
super
end
def down
@went_down = true
super
end
end
def test_instance_based_migration_up
migration = MockMigration . new
assert ! migration . went_up , 'have not gone up'
assert ! migration . went_down , 'have not gone down'
migration . migrate :up
assert migration . went_up , 'have gone up'
assert ! migration . went_down , 'have not gone down'
end
def test_instance_based_migration_down
migration = MockMigration . new
assert ! migration . went_up , 'have not gone up'
assert ! migration . went_down , 'have not gone down'
migration . migrate :down
assert ! migration . went_up , 'have gone up'
assert migration . went_down , 'have not gone down'
end
2005-07-04 18:51:02 +00:00
def test_migrator_one_up
assert ! Person . column_methods_hash . include? ( :last_name )
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2006-07-07 10:48:43 +00:00
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " , 1 )
2005-07-04 18:51:02 +00:00
Person . reset_column_information
assert Person . column_methods_hash . include? ( :last_name )
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2005-07-04 18:51:02 +00:00
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " , 2 )
2005-07-04 18:51:02 +00:00
assert Reminder . create ( " content " = > " hello world " , " remind_at " = > Time . now )
assert_equal " hello world " , Reminder . find ( :first ) . content
end
2006-07-07 10:48:43 +00:00
2005-07-04 18:51:02 +00:00
def test_migrator_one_down
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " )
2009-08-09 08:56:25 +00:00
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . down ( MIGRATIONS_ROOT + " /valid " , 1 )
2009-08-09 08:56:25 +00:00
2005-07-04 18:51:02 +00:00
Person . reset_column_information
assert Person . column_methods_hash . include? ( :last_name )
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2005-07-04 18:51:02 +00:00
end
2006-07-07 10:48:43 +00:00
2005-07-04 18:51:02 +00:00
def test_migrator_one_up_one_down
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " , 1 )
ActiveRecord :: Migrator . down ( MIGRATIONS_ROOT + " /valid " , 0 )
2005-07-04 18:51:02 +00:00
assert ! Person . column_methods_hash . include? ( :last_name )
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2005-07-04 18:51:02 +00:00
end
2006-07-07 10:48:43 +00:00
2008-06-13 14:14:07 +00:00
def test_migrator_double_up
assert_equal ( 0 , ActiveRecord :: Migrator . current_version )
ActiveRecord :: Migrator . run ( :up , MIGRATIONS_ROOT + " /valid " , 1 )
assert_nothing_raised { ActiveRecord :: Migrator . run ( :up , MIGRATIONS_ROOT + " /valid " , 1 ) }
assert_equal ( 1 , ActiveRecord :: Migrator . current_version )
end
def test_migrator_double_down
assert_equal ( 0 , ActiveRecord :: Migrator . current_version )
ActiveRecord :: Migrator . run ( :up , MIGRATIONS_ROOT + " /valid " , 1 )
ActiveRecord :: Migrator . run ( :down , MIGRATIONS_ROOT + " /valid " , 1 )
assert_nothing_raised { ActiveRecord :: Migrator . run ( :down , MIGRATIONS_ROOT + " /valid " , 1 ) }
assert_equal ( 0 , ActiveRecord :: Migrator . current_version )
end
2009-03-14 12:58:42 +00:00
if ActiveRecord :: Base . connection . supports_ddl_transactions?
2008-08-22 20:53:31 +00:00
def test_migrator_one_up_with_exception_and_rollback
assert ! Person . column_methods_hash . include? ( :last_name )
2009-03-08 20:11:58 +00:00
e = assert_raise ( StandardError ) do
2008-08-22 20:53:31 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /broken " , 100 )
end
assert_equal " An error has occurred, this and all later migrations canceled: \n \n Something broke " , e . message
Person . reset_column_information
assert ! Person . column_methods_hash . include? ( :last_name )
end
end
2008-04-09 16:20:15 +00:00
def test_finds_migrations
migrations = ActiveRecord :: Migrator . new ( :up , MIGRATIONS_ROOT + " /valid " ) . migrations
2009-01-07 00:37:56 +00:00
2010-12-03 19:44:11 +00:00
[ [ 1 , 'ValidPeopleHaveLastNames' ] , [ 2 , 'WeNeedReminders' ] , [ 3 , 'InnocentJointable' ] ] . each_with_index do | pair , i |
2009-01-07 00:37:56 +00:00
assert_equal migrations [ i ] . version , pair . first
assert_equal migrations [ i ] . name , pair . last
2008-04-09 16:20:15 +00:00
end
end
2010-12-03 12:12:59 +00:00
def test_finds_migrations_from_two_directories
directories = [ MIGRATIONS_ROOT + '/valid_with_timestamps' , MIGRATIONS_ROOT + '/to_copy_with_timestamps' ]
migrations = ActiveRecord :: Migrator . new ( :up , directories ) . migrations
2010-12-09 17:02:09 +00:00
[ [ 20090101010101 , " PeopleHaveHobbies " ] ,
[ 20090101010202 , " PeopleHaveDescriptions " ] ,
[ 20100101010101 , " ValidWithTimestampsPeopleHaveLastNames " ] ,
[ 20100201010101 , " ValidWithTimestampsWeNeedReminders " ] ,
[ 20100301010101 , " ValidWithTimestampsInnocentJointable " ] ] . each_with_index do | pair , i |
assert_equal pair . first , migrations [ i ] . version
assert_equal pair . last , migrations [ i ] . name
2010-12-03 12:12:59 +00:00
end
end
2008-04-09 16:20:15 +00:00
def test_finds_pending_migrations
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /interleaved/pass_2 " , 1 )
migrations = ActiveRecord :: Migrator . new ( :up , MIGRATIONS_ROOT + " /interleaved/pass_2 " ) . pending_migrations
2009-01-07 00:37:56 +00:00
2008-04-09 16:20:15 +00:00
assert_equal 1 , migrations . size
2009-01-07 00:37:56 +00:00
assert_equal migrations [ 0 ] . version , 3
2010-12-03 19:44:11 +00:00
assert_equal migrations [ 0 ] . name , 'InterleavedInnocentJointable'
2008-04-09 16:20:15 +00:00
end
2010-03-24 01:20:28 +00:00
def test_relative_migrations
2010-12-03 19:44:11 +00:00
list = Dir . chdir ( MIGRATIONS_ROOT ) do
2010-03-24 01:20:28 +00:00
ActiveRecord :: Migrator . up ( " valid/ " , 1 )
end
2010-12-03 19:44:11 +00:00
migration_proxy = list . find { | item |
item . name == 'ValidPeopleHaveLastNames'
}
assert migration_proxy , 'should find pending migration'
2010-03-24 01:20:28 +00:00
end
2008-08-02 05:44:02 +00:00
def test_only_loads_pending_migrations
# migrate up to 1
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " , 1 )
2010-12-03 19:44:11 +00:00
proxies = ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " , nil )
2008-08-02 05:44:02 +00:00
2010-12-03 19:44:11 +00:00
names = proxies . map ( & :name )
assert ! names . include? ( 'ValidPeopleHaveLastNames' )
assert names . include? ( 'WeNeedReminders' )
assert names . include? ( 'InnocentJointable' )
2008-08-02 05:44:02 +00:00
end
2010-04-20 15:14:00 +00:00
def test_target_version_zero_should_run_only_once
# migrate up to 1
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " , 1 )
# migrate down to 0
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " , 0 )
# migrate down to 0 again
2010-12-03 19:44:11 +00:00
proxies = ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " , 0 )
assert_equal [ ] , proxies
2010-04-20 15:14:00 +00:00
end
2008-04-17 18:43:47 +00:00
def test_migrator_db_has_no_schema_migrations_table
2009-03-22 22:18:21 +00:00
# Oracle adapter raises error if semicolon is present as last character
if current_adapter? ( :OracleAdapter )
ActiveRecord :: Base . connection . execute ( " DROP TABLE schema_migrations " )
else
ActiveRecord :: Base . connection . execute ( " DROP TABLE schema_migrations; " )
end
2008-04-17 18:43:47 +00:00
assert_nothing_raised do
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " , 1 )
end
end
2006-03-04 18:46:51 +00:00
def test_migrator_verbosity
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " , 1 )
2010-12-03 19:44:11 +00:00
assert_not_equal 0 , ActiveRecord :: Migration . message_count
ActiveRecord :: Migration . message_count = 0
2006-03-04 18:46:51 +00:00
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . down ( MIGRATIONS_ROOT + " /valid " , 0 )
2010-12-03 19:44:11 +00:00
assert_not_equal 0 , ActiveRecord :: Migration . message_count
ActiveRecord :: Migration . message_count = 0
2006-03-04 18:46:51 +00:00
end
2006-07-07 10:48:43 +00:00
2006-03-04 18:46:51 +00:00
def test_migrator_verbosity_off
2010-12-03 19:44:11 +00:00
ActiveRecord :: Migration . verbose = false
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " , 1 )
2010-12-03 19:44:11 +00:00
assert_equal 0 , ActiveRecord :: Migration . message_count
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . down ( MIGRATIONS_ROOT + " /valid " , 0 )
2010-12-03 19:44:11 +00:00
assert_equal 0 , ActiveRecord :: Migration . message_count
2006-03-04 18:46:51 +00:00
end
2006-07-07 10:48:43 +00:00
2005-07-09 15:46:29 +00:00
def test_migrator_going_down_due_to_version_target
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /valid " , 1 )
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " , 0 )
2005-07-09 15:46:29 +00:00
assert ! Person . column_methods_hash . include? ( :last_name )
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2005-07-09 15:46:29 +00:00
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " )
2005-07-09 15:46:29 +00:00
Person . reset_column_information
assert Person . column_methods_hash . include? ( :last_name )
assert Reminder . create ( " content " = > " hello world " , " remind_at " = > Time . now )
assert_equal " hello world " , Reminder . find ( :first ) . content
end
2009-08-09 08:56:25 +00:00
2008-03-28 21:21:01 +00:00
def test_migrator_rollback
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " )
assert_equal ( 3 , ActiveRecord :: Migrator . current_version )
2009-08-09 08:56:25 +00:00
2008-03-28 21:21:01 +00:00
ActiveRecord :: Migrator . rollback ( MIGRATIONS_ROOT + " /valid " )
2008-04-09 16:20:15 +00:00
assert_equal ( 2 , ActiveRecord :: Migrator . current_version )
2009-08-09 08:56:25 +00:00
2008-03-28 21:21:01 +00:00
ActiveRecord :: Migrator . rollback ( MIGRATIONS_ROOT + " /valid " )
2008-04-09 16:20:15 +00:00
assert_equal ( 1 , ActiveRecord :: Migrator . current_version )
2009-08-09 08:56:25 +00:00
2008-03-28 21:21:01 +00:00
ActiveRecord :: Migrator . rollback ( MIGRATIONS_ROOT + " /valid " )
2008-04-09 16:20:15 +00:00
assert_equal ( 0 , ActiveRecord :: Migrator . current_version )
2009-08-09 08:56:25 +00:00
2008-03-28 21:21:01 +00:00
ActiveRecord :: Migrator . rollback ( MIGRATIONS_ROOT + " /valid " )
2008-04-09 16:20:15 +00:00
assert_equal ( 0 , ActiveRecord :: Migrator . current_version )
2008-03-28 21:21:01 +00:00
end
2005-09-26 21:30:12 +00:00
2009-08-08 16:39:31 +00:00
def test_migrator_forward
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " , 1 )
assert_equal ( 1 , ActiveRecord :: Migrator . current_version )
ActiveRecord :: Migrator . forward ( MIGRATIONS_ROOT + " /valid " , 2 )
assert_equal ( 3 , ActiveRecord :: Migrator . current_version )
ActiveRecord :: Migrator . forward ( MIGRATIONS_ROOT + " /valid " )
assert_equal ( 3 , ActiveRecord :: Migrator . current_version )
end
2010-08-14 05:13:00 +00:00
2010-07-08 06:26:37 +00:00
def test_get_all_versions
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " )
2010-08-14 05:13:00 +00:00
assert_equal ( [ 1 , 2 , 3 ] , ActiveRecord :: Migrator . get_all_versions )
2010-07-08 06:26:37 +00:00
ActiveRecord :: Migrator . rollback ( MIGRATIONS_ROOT + " /valid " )
assert_equal ( [ 1 , 2 ] , ActiveRecord :: Migrator . get_all_versions )
ActiveRecord :: Migrator . rollback ( MIGRATIONS_ROOT + " /valid " )
assert_equal ( [ 1 ] , ActiveRecord :: Migrator . get_all_versions )
ActiveRecord :: Migrator . rollback ( MIGRATIONS_ROOT + " /valid " )
assert_equal ( [ ] , ActiveRecord :: Migrator . get_all_versions )
end
2009-08-08 16:39:31 +00:00
2008-04-09 16:20:15 +00:00
def test_schema_migrations_table_name
2005-09-26 21:30:12 +00:00
ActiveRecord :: Base . table_name_prefix = " prefix_ "
ActiveRecord :: Base . table_name_suffix = " _suffix "
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2008-04-09 16:20:15 +00:00
assert_equal " prefix_schema_migrations_suffix " , ActiveRecord :: Migrator . schema_migrations_table_name
2005-09-26 21:30:12 +00:00
ActiveRecord :: Base . table_name_prefix = " "
ActiveRecord :: Base . table_name_suffix = " "
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2008-04-09 16:20:15 +00:00
assert_equal " schema_migrations " , ActiveRecord :: Migrator . schema_migrations_table_name
2005-11-12 11:59:54 +00:00
ensure
ActiveRecord :: Base . table_name_prefix = " "
ActiveRecord :: Base . table_name_suffix = " "
2005-09-26 21:30:12 +00:00
end
2006-07-07 10:48:43 +00:00
2005-09-26 21:30:12 +00:00
def test_proper_table_name
assert_equal " table " , ActiveRecord :: Migrator . proper_table_name ( 'table' )
assert_equal " table " , ActiveRecord :: Migrator . proper_table_name ( :table )
assert_equal " reminders " , ActiveRecord :: Migrator . proper_table_name ( Reminder )
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2005-09-26 21:30:12 +00:00
assert_equal Reminder . table_name , ActiveRecord :: Migrator . proper_table_name ( Reminder )
2006-07-07 10:48:43 +00:00
2005-09-26 21:30:12 +00:00
# Use the model's own prefix/suffix if a model is given
ActiveRecord :: Base . table_name_prefix = " ARprefix_ "
ActiveRecord :: Base . table_name_suffix = " _ARsuffix "
Reminder . table_name_prefix = 'prefix_'
Reminder . table_name_suffix = '_suffix'
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2005-09-26 21:30:12 +00:00
assert_equal " prefix_reminders_suffix " , ActiveRecord :: Migrator . proper_table_name ( Reminder )
Reminder . table_name_prefix = ''
Reminder . table_name_suffix = ''
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2006-07-07 10:48:43 +00:00
# Use AR::Base's prefix/suffix if string or symbol is given
2005-09-26 21:30:12 +00:00
ActiveRecord :: Base . table_name_prefix = " prefix_ "
ActiveRecord :: Base . table_name_suffix = " _suffix "
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2005-09-26 21:30:12 +00:00
assert_equal " prefix_table_suffix " , ActiveRecord :: Migrator . proper_table_name ( 'table' )
assert_equal " prefix_table_suffix " , ActiveRecord :: Migrator . proper_table_name ( :table )
ActiveRecord :: Base . table_name_prefix = " "
ActiveRecord :: Base . table_name_suffix = " "
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2006-07-07 10:48:43 +00:00
end
2005-09-26 21:30:12 +00:00
def test_add_drop_table_with_prefix_and_suffix
2005-10-28 07:40:28 +00:00
assert ! Reminder . table_exists?
2005-09-26 21:30:12 +00:00
ActiveRecord :: Base . table_name_prefix = 'prefix_'
ActiveRecord :: Base . table_name_suffix = '_suffix'
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2005-11-12 11:59:54 +00:00
Reminder . reset_sequence_name
2005-09-26 21:30:12 +00:00
WeNeedReminders . up
assert Reminder . create ( " content " = > " hello world " , " remind_at " = > Time . now )
assert_equal " hello world " , Reminder . find ( :first ) . content
WeNeedReminders . down
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) { Reminder . find ( :first ) }
2005-11-12 11:59:54 +00:00
ensure
2005-09-26 21:30:12 +00:00
ActiveRecord :: Base . table_name_prefix = ''
ActiveRecord :: Base . table_name_suffix = ''
2005-10-10 18:59:56 +00:00
Reminder . reset_table_name
2005-11-12 11:59:54 +00:00
Reminder . reset_sequence_name
2005-09-26 21:30:12 +00:00
end
2005-11-12 11:59:54 +00:00
2007-01-29 22:06:08 +00:00
def test_create_table_with_binary_column
Person . connection . drop_table :binary_testings rescue nil
2006-07-07 10:48:43 +00:00
2007-01-29 22:06:08 +00:00
assert_nothing_raised {
Person . connection . create_table :binary_testings do | t |
t . column " data " , :binary , :null = > false
end
}
2006-07-07 10:48:43 +00:00
2007-01-29 22:06:08 +00:00
columns = Person . connection . columns ( :binary_testings )
data_column = columns . detect { | c | c . name == " data " }
2006-04-04 16:33:31 +00:00
2010-08-02 08:37:57 +00:00
if current_adapter? ( :MysqlAdapter ) or current_adapter? ( :Mysql2Adapter )
2008-09-14 11:06:10 +00:00
assert_equal '' , data_column . default
else
assert_nil data_column . default
end
2006-04-04 16:33:31 +00:00
2007-01-29 22:06:08 +00:00
Person . connection . drop_table :binary_testings rescue nil
2006-03-25 23:09:52 +00:00
end
2007-01-29 22:06:08 +00:00
2005-10-31 15:43:02 +00:00
def test_migrator_with_duplicates
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: DuplicateMigrationVersionError ) do
2008-01-21 17:20:51 +00:00
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /duplicate " , nil )
2005-10-31 15:43:02 +00:00
end
end
2006-08-23 05:49:40 +00:00
2008-05-07 05:59:34 +00:00
def test_migrator_with_duplicate_names
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: DuplicateMigrationNameError , " Multiple migrations have the name Chunky " ) do
2008-05-07 05:59:34 +00:00
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /duplicate_names " , nil )
end
end
2006-08-23 05:49:40 +00:00
def test_migrator_with_missing_version_numbers
2008-03-28 21:21:01 +00:00
assert_raise ( ActiveRecord :: UnknownMigrationVersionError ) do
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /missing " , 500 )
end
2006-08-23 05:49:40 +00:00
end
2007-09-13 23:21:14 +00:00
2007-01-15 00:34:43 +00:00
def test_create_table_with_custom_sequence_name
return unless current_adapter? :OracleAdapter
# table name is 29 chars, the standard sequence name will
2009-10-23 15:20:03 +00:00
# be 33 chars and should be shortened
assert_nothing_raised do
2007-01-15 00:34:43 +00:00
begin
Person . connection . create_table :table_with_name_thats_just_ok do | t |
t . column :foo , :string , :null = > false
end
ensure
Person . connection . drop_table :table_with_name_thats_just_ok rescue nil
end
end
# should be all good w/ a custom sequence name
assert_nothing_raised do
begin
Person . connection . create_table :table_with_name_thats_just_ok ,
:sequence_name = > 'suitably_short_seq' do | t |
t . column :foo , :string , :null = > false
end
Person . connection . execute ( " select suitably_short_seq.nextval from dual " )
ensure
Person . connection . drop_table :table_with_name_thats_just_ok ,
:sequence_name = > 'suitably_short_seq' rescue nil
end
end
# confirm the custom sequence got dropped
2009-03-08 20:11:58 +00:00
assert_raise ( ActiveRecord :: StatementInvalid ) do
2007-01-15 00:34:43 +00:00
Person . connection . execute ( " select suitably_short_seq.nextval from dual " )
end
end
2008-04-01 00:28:40 +00:00
protected
def with_env_tz ( new_tz = 'US/Eastern' )
old_tz , ENV [ 'TZ' ] = ENV [ 'TZ' ] , new_tz
yield
ensure
old_tz ? ENV [ 'TZ' ] = old_tz : ENV . delete ( 'TZ' )
end
2005-10-28 07:40:28 +00:00
end
2009-08-09 08:56:25 +00:00
2009-02-04 02:25:37 +00:00
class SexyMigrationsTest < ActiveRecord :: TestCase
def test_references_column_type_adds_id
with_new_table do | t |
t . expects ( :column ) . with ( 'customer_id' , :integer , { } )
t . references :customer
2007-10-19 02:09:06 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-01-18 07:30:42 +00:00
2009-02-04 02:25:37 +00:00
def test_references_column_type_with_polymorphic_adds_type
with_new_table do | t |
t . expects ( :column ) . with ( 'taggable_type' , :string , { } )
t . expects ( :column ) . with ( 'taggable_id' , :integer , { } )
t . references :taggable , :polymorphic = > true
2007-10-19 02:09:06 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-01-18 07:30:42 +00:00
2009-02-04 02:25:37 +00:00
def test_references_column_type_with_polymorphic_and_options_null_is_false_adds_table_flag
with_new_table do | t |
t . expects ( :column ) . with ( 'taggable_type' , :string , { :null = > false } )
t . expects ( :column ) . with ( 'taggable_id' , :integer , { :null = > false } )
t . references :taggable , :polymorphic = > true , :null = > false
2008-01-11 19:54:19 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-01-18 07:30:42 +00:00
2009-02-04 02:25:37 +00:00
def test_belongs_to_works_like_references
with_new_table do | t |
t . expects ( :column ) . with ( 'customer_id' , :integer , { } )
t . belongs_to :customer
2007-10-19 02:09:06 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-01-18 07:30:42 +00:00
2009-02-04 02:25:37 +00:00
def test_timestamps_creates_updated_at_and_created_at
with_new_table do | t |
t . expects ( :column ) . with ( :created_at , :datetime , kind_of ( Hash ) )
t . expects ( :column ) . with ( :updated_at , :datetime , kind_of ( Hash ) )
t . timestamps
2007-10-19 02:25:23 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-01-18 07:30:42 +00:00
2009-02-04 02:25:37 +00:00
def test_integer_creates_integer_column
with_new_table do | t |
t . expects ( :column ) . with ( :foo , 'integer' , { } )
t . expects ( :column ) . with ( :bar , 'integer' , { } )
t . integer :foo , :bar
2007-10-19 02:25:23 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-01-18 07:30:42 +00:00
2009-02-04 02:25:37 +00:00
def test_string_creates_string_column
with_new_table do | t |
t . expects ( :column ) . with ( :foo , 'string' , { } )
t . expects ( :column ) . with ( :bar , 'string' , { } )
t . string :foo , :bar
2007-10-19 02:25:23 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-01-18 07:30:42 +00:00
2010-10-19 17:18:54 +00:00
if current_adapter? ( :PostgreSQLAdapter ) || current_adapter? ( :SQLite3Adapter ) || current_adapter? ( :MysqlAdapter ) || current_adapter? ( :Mysql2Adapter )
2009-08-09 08:56:25 +00:00
def test_xml_creates_xml_column
2010-09-29 18:18:43 +00:00
type = current_adapter? ( :PostgreSQLAdapter ) ? 'xml' : :text
2009-08-09 08:56:25 +00:00
with_new_table do | t |
2010-09-29 18:18:43 +00:00
t . expects ( :column ) . with ( :data , type , { } )
2009-08-09 08:56:25 +00:00
t . xml :data
end
end
2010-09-29 18:18:43 +00:00
else
def test_xml_creates_xml_column
with_new_table do | t |
assert_raises ( NotImplementedError ) do
t . xml :data
end
end
end
2009-08-09 08:56:25 +00:00
end
2009-02-04 02:25:37 +00:00
protected
def with_new_table
Person . connection . create_table :delete_me , :force = > true do | t |
yield t
2007-10-19 02:09:06 +00:00
end
2009-02-04 02:25:37 +00:00
ensure
Person . connection . drop_table :delete_me rescue nil
end
2008-01-18 07:30:42 +00:00
2009-02-04 02:25:37 +00:00
end # SexyMigrationsTest
2008-05-03 16:29:47 +00:00
2010-04-06 07:18:22 +00:00
class MigrationLoggerTest < ActiveRecord :: TestCase
def test_migration_should_be_run_without_logger
previous_logger = ActiveRecord :: Base . logger
ActiveRecord :: Base . logger = nil
assert_nothing_raised do
ActiveRecord :: Migrator . migrate ( MIGRATIONS_ROOT + " /valid " )
end
ensure
ActiveRecord :: Base . logger = previous_logger
end
end
class InterleavedMigrationsTest < ActiveRecord :: TestCase
def test_migrator_interleaved_migrations
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /interleaved/pass_1 " )
assert_nothing_raised do
ActiveRecord :: Migrator . up ( MIGRATIONS_ROOT + " /interleaved/pass_2 " )
end
Person . reset_column_information
assert Person . column_methods_hash . include? ( :last_name )
assert_nothing_raised do
2010-12-03 19:44:11 +00:00
proxies = ActiveRecord :: Migrator . down (
MIGRATIONS_ROOT + " /interleaved/pass_3 " )
names = proxies . map ( & :name )
assert names . include? ( 'InterleavedPeopleHaveLastNames' )
assert names . include? ( 'InterleavedInnocentJointable' )
2010-04-06 07:18:22 +00:00
end
end
end
2010-06-12 01:25:18 +00:00
class ReservedWordsMigrationTest < ActiveRecord :: TestCase
def test_drop_index_from_table_named_values
connection = Person . connection
connection . create_table :values , :force = > true do | t |
t . integer :value
end
2010-06-12 03:03:47 +00:00
assert_nothing_raised do
2010-06-15 09:03:30 +00:00
connection . add_index :values , :value
2010-06-12 03:03:47 +00:00
connection . remove_index :values , :column = > :value
end
2010-06-12 01:25:18 +00:00
connection . drop_table :values rescue nil
end
end
2009-02-04 02:25:37 +00:00
class ChangeTableMigrationsTest < ActiveRecord :: TestCase
def setup
@connection = Person . connection
@connection . create_table :delete_me , :force = > true do | t |
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def teardown
Person . connection . drop_table :delete_me rescue nil
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_references_column_type_adds_id
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , 'customer_id' , :integer , { } )
t . references :customer
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_references_column_type_removes_id
with_change_table do | t |
@connection . expects ( :remove_column ) . with ( :delete_me , 'customer_id' )
t . remove_references :customer
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_add_belongs_to_works_like_add_references
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , 'customer_id' , :integer , { } )
t . belongs_to :customer
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_belongs_to_works_like_remove_references
with_change_table do | t |
@connection . expects ( :remove_column ) . with ( :delete_me , 'customer_id' )
t . remove_belongs_to :customer
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_references_column_type_with_polymorphic_adds_type
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , 'taggable_type' , :string , { } )
@connection . expects ( :add_column ) . with ( :delete_me , 'taggable_id' , :integer , { } )
t . references :taggable , :polymorphic = > true
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_references_column_type_with_polymorphic_removes_type
with_change_table do | t |
@connection . expects ( :remove_column ) . with ( :delete_me , 'taggable_type' )
@connection . expects ( :remove_column ) . with ( :delete_me , 'taggable_id' )
t . remove_references :taggable , :polymorphic = > true
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_references_column_type_with_polymorphic_and_options_null_is_false_adds_table_flag
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , 'taggable_type' , :string , { :null = > false } )
@connection . expects ( :add_column ) . with ( :delete_me , 'taggable_id' , :integer , { :null = > false } )
t . references :taggable , :polymorphic = > true , :null = > false
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_references_column_type_with_polymorphic_and_options_null_is_false_removes_table_flag
with_change_table do | t |
@connection . expects ( :remove_column ) . with ( :delete_me , 'taggable_type' )
@connection . expects ( :remove_column ) . with ( :delete_me , 'taggable_id' )
t . remove_references :taggable , :polymorphic = > true , :null = > false
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_timestamps_creates_updated_at_and_created_at
with_change_table do | t |
@connection . expects ( :add_timestamps ) . with ( :delete_me )
t . timestamps
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_timestamps_creates_updated_at_and_created_at
with_change_table do | t |
@connection . expects ( :remove_timestamps ) . with ( :delete_me )
t . remove_timestamps
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def string_column
if current_adapter? ( :PostgreSQLAdapter )
" character varying(255) "
2009-03-22 22:18:21 +00:00
elsif current_adapter? ( :OracleAdapter )
'VARCHAR2(255)'
2009-02-04 02:25:37 +00:00
else
'varchar(255)'
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def integer_column
2010-08-02 08:37:57 +00:00
if current_adapter? ( :MysqlAdapter ) or current_adapter? ( :Mysql2Adapter )
2009-02-04 02:25:37 +00:00
'int(11)'
2009-03-22 22:18:21 +00:00
elsif current_adapter? ( :OracleAdapter )
'NUMBER(38)'
2009-02-04 02:25:37 +00:00
else
'integer'
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_integer_creates_integer_column
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , :foo , integer_column , { } )
@connection . expects ( :add_column ) . with ( :delete_me , :bar , integer_column , { } )
t . integer :foo , :bar
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_string_creates_string_column
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , :foo , string_column , { } )
@connection . expects ( :add_column ) . with ( :delete_me , :bar , string_column , { } )
t . string :foo , :bar
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_column_creates_column
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , :bar , :integer , { } )
t . column :bar , :integer
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_column_creates_column_with_options
with_change_table do | t |
@connection . expects ( :add_column ) . with ( :delete_me , :bar , :integer , { :null = > false } )
t . column :bar , :integer , :null = > false
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_index_creates_index
with_change_table do | t |
@connection . expects ( :add_index ) . with ( :delete_me , :bar , { } )
t . index :bar
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_index_creates_index_with_options
with_change_table do | t |
@connection . expects ( :add_index ) . with ( :delete_me , :bar , { :unique = > true } )
t . index :bar , :unique = > true
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2010-03-18 16:49:23 +00:00
def test_index_exists
with_change_table do | t |
@connection . expects ( :index_exists? ) . with ( :delete_me , :bar , { } )
t . index_exists? ( :bar )
end
end
def test_index_exists_with_options
with_change_table do | t |
@connection . expects ( :index_exists? ) . with ( :delete_me , :bar , { :unique = > true } )
t . index_exists? ( :bar , :unique = > true )
end
end
2009-02-04 02:25:37 +00:00
def test_change_changes_column
with_change_table do | t |
@connection . expects ( :change_column ) . with ( :delete_me , :bar , :string , { } )
t . change :bar , :string
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_change_changes_column_with_options
with_change_table do | t |
@connection . expects ( :change_column ) . with ( :delete_me , :bar , :string , { :null = > true } )
t . change :bar , :string , :null = > true
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_change_default_changes_column
with_change_table do | t |
@connection . expects ( :change_column_default ) . with ( :delete_me , :bar , :string )
t . change_default :bar , :string
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_drops_single_column
with_change_table do | t |
@connection . expects ( :remove_column ) . with ( :delete_me , [ :bar ] )
t . remove :bar
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_drops_multiple_columns
with_change_table do | t |
@connection . expects ( :remove_column ) . with ( :delete_me , [ :bar , :baz ] )
t . remove :bar , :baz
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_remove_index_removes_index_with_options
with_change_table do | t |
@connection . expects ( :remove_index ) . with ( :delete_me , { :unique = > true } )
t . remove_index :unique = > true
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
def test_rename_renames_column
with_change_table do | t |
@connection . expects ( :rename_column ) . with ( :delete_me , :bar , :baz )
t . rename :bar , :baz
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
2008-05-03 16:29:47 +00:00
2009-02-04 02:25:37 +00:00
protected
def with_change_table
Person . connection . change_table :delete_me do | t |
yield t
2008-05-03 16:29:47 +00:00
end
2009-02-04 02:25:37 +00:00
end
end
2010-07-26 12:06:14 +00:00
class CopyMigrationsTest < ActiveRecord :: TestCase
def setup
end
def clear
ActiveRecord :: Base . timestamped_migrations = true
to_delete = Dir [ @migrations_path + " /*.rb " ] - @existing_migrations
File . delete ( * to_delete )
end
def test_copying_migrations_without_timestamps
ActiveRecord :: Base . timestamped_migrations = false
@migrations_path = MIGRATIONS_ROOT + " /valid "
@existing_migrations = Dir [ @migrations_path + " /*.rb " ]
copied = ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy " } )
2010-10-08 19:17:14 +00:00
assert File . exists? ( @migrations_path + " /4_people_have_hobbies.rb " )
assert File . exists? ( @migrations_path + " /5_people_have_descriptions.rb " )
2010-10-09 08:28:46 +00:00
assert_equal [ @migrations_path + " /4_people_have_hobbies.rb " , @migrations_path + " /5_people_have_descriptions.rb " ] , copied . map ( & :filename )
2010-07-26 12:06:14 +00:00
files_count = Dir [ @migrations_path + " /*.rb " ] . length
copied = ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy " } )
assert_equal files_count , Dir [ @migrations_path + " /*.rb " ] . length
assert copied . empty?
ensure
clear
end
def test_copying_migrations_without_timestamps_from_2_sources
ActiveRecord :: Base . timestamped_migrations = false
@migrations_path = MIGRATIONS_ROOT + " /valid "
@existing_migrations = Dir [ @migrations_path + " /*.rb " ]
sources = ActiveSupport :: OrderedHash . new
2010-10-08 19:17:14 +00:00
sources [ :bukkits ] = MIGRATIONS_ROOT + " /to_copy "
sources [ :omg ] = MIGRATIONS_ROOT + " /to_copy2 "
2010-07-26 12:06:14 +00:00
ActiveRecord :: Migration . copy ( @migrations_path , sources )
2010-10-08 19:17:14 +00:00
assert File . exists? ( @migrations_path + " /4_people_have_hobbies.rb " )
assert File . exists? ( @migrations_path + " /5_people_have_descriptions.rb " )
assert File . exists? ( @migrations_path + " /6_create_articles.rb " )
assert File . exists? ( @migrations_path + " /7_create_comments.rb " )
2010-07-26 12:06:14 +00:00
files_count = Dir [ @migrations_path + " /*.rb " ] . length
ActiveRecord :: Migration . copy ( @migrations_path , sources )
assert_equal files_count , Dir [ @migrations_path + " /*.rb " ] . length
ensure
clear
end
def test_copying_migrations_with_timestamps
@migrations_path = MIGRATIONS_ROOT + " /valid_with_timestamps "
@existing_migrations = Dir [ @migrations_path + " /*.rb " ]
2010-11-17 01:06:50 +00:00
Time . travel_to ( Time . utc ( 2010 , 7 , 26 , 10 , 10 , 10 ) ) do
2010-07-26 12:06:14 +00:00
copied = ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy_with_timestamps " } )
2010-10-08 19:17:14 +00:00
assert File . exists? ( @migrations_path + " /20100726101010_people_have_hobbies.rb " )
assert File . exists? ( @migrations_path + " /20100726101011_people_have_descriptions.rb " )
expected = [ @migrations_path + " /20100726101010_people_have_hobbies.rb " ,
@migrations_path + " /20100726101011_people_have_descriptions.rb " ]
2010-10-09 08:28:46 +00:00
assert_equal expected , copied . map ( & :filename )
2010-07-26 12:06:14 +00:00
files_count = Dir [ @migrations_path + " /*.rb " ] . length
copied = ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy_with_timestamps " } )
assert_equal files_count , Dir [ @migrations_path + " /*.rb " ] . length
assert copied . empty?
end
ensure
clear
end
def test_copying_migrations_with_timestamps_from_2_sources
@migrations_path = MIGRATIONS_ROOT + " /valid_with_timestamps "
@existing_migrations = Dir [ @migrations_path + " /*.rb " ]
sources = ActiveSupport :: OrderedHash . new
2010-10-08 19:17:14 +00:00
sources [ :bukkits ] = MIGRATIONS_ROOT + " /to_copy_with_timestamps "
sources [ :omg ] = MIGRATIONS_ROOT + " /to_copy_with_timestamps2 "
2010-07-26 12:06:14 +00:00
2010-11-17 01:06:50 +00:00
Time . travel_to ( Time . utc ( 2010 , 7 , 26 , 10 , 10 , 10 ) ) do
2010-07-26 12:06:14 +00:00
copied = ActiveRecord :: Migration . copy ( @migrations_path , sources )
2010-10-08 19:17:14 +00:00
assert File . exists? ( @migrations_path + " /20100726101010_people_have_hobbies.rb " )
assert File . exists? ( @migrations_path + " /20100726101011_people_have_descriptions.rb " )
assert File . exists? ( @migrations_path + " /20100726101012_create_articles.rb " )
assert File . exists? ( @migrations_path + " /20100726101013_create_comments.rb " )
2010-07-26 12:06:14 +00:00
assert_equal 4 , copied . length
files_count = Dir [ @migrations_path + " /*.rb " ] . length
ActiveRecord :: Migration . copy ( @migrations_path , sources )
assert_equal files_count , Dir [ @migrations_path + " /*.rb " ] . length
end
ensure
clear
end
def test_copying_migrations_with_timestamps_to_destination_with_timestamps_in_future
@migrations_path = MIGRATIONS_ROOT + " /valid_with_timestamps "
@existing_migrations = Dir [ @migrations_path + " /*.rb " ]
2010-11-17 01:06:50 +00:00
Time . travel_to ( Time . utc ( 2010 , 2 , 20 , 10 , 10 , 10 ) ) do
2010-07-26 12:06:14 +00:00
ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy_with_timestamps " } )
2010-10-08 19:17:14 +00:00
assert File . exists? ( @migrations_path + " /20100301010102_people_have_hobbies.rb " )
assert File . exists? ( @migrations_path + " /20100301010103_people_have_descriptions.rb " )
2010-07-26 12:06:14 +00:00
files_count = Dir [ @migrations_path + " /*.rb " ] . length
copied = ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy_with_timestamps " } )
assert_equal files_count , Dir [ @migrations_path + " /*.rb " ] . length
assert copied . empty?
end
ensure
clear
end
2010-07-31 12:43:41 +00:00
2010-10-09 08:28:46 +00:00
def test_skipping_migrations
@migrations_path = MIGRATIONS_ROOT + " /valid_with_timestamps "
@existing_migrations = Dir [ @migrations_path + " /*.rb " ]
sources = ActiveSupport :: OrderedHash . new
sources [ :bukkits ] = sources [ :omg ] = MIGRATIONS_ROOT + " /to_copy_with_timestamps "
skipped = [ ]
on_skip = Proc . new { | name , migration | skipped << " #{ name } #{ migration . name } " }
copied = ActiveRecord :: Migration . copy ( @migrations_path , sources , :on_skip = > on_skip )
assert_equal 2 , copied . length
assert_equal 2 , skipped . length
assert_equal [ " bukkits PeopleHaveHobbies " , " bukkits PeopleHaveDescriptions " ] , skipped
ensure
clear
end
2010-11-16 16:00:01 +00:00
def test_copying_migrations_to_non_existing_directory
@migrations_path = MIGRATIONS_ROOT + " /non_existing "
@existing_migrations = [ ]
2010-11-17 01:06:50 +00:00
Time . travel_to ( Time . utc ( 2010 , 7 , 26 , 10 , 10 , 10 ) ) do
2010-11-16 16:00:01 +00:00
copied = ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy_with_timestamps " } )
assert File . exists? ( @migrations_path + " /20100726101010_people_have_hobbies.rb " )
assert File . exists? ( @migrations_path + " /20100726101011_people_have_descriptions.rb " )
assert_equal 2 , copied . length
end
ensure
clear
Dir . delete ( @migrations_path )
end
2010-07-31 12:43:41 +00:00
def test_copying_migrations_to_empty_directory
@migrations_path = MIGRATIONS_ROOT + " /empty "
@existing_migrations = [ ]
2010-11-17 01:06:50 +00:00
Time . travel_to ( Time . utc ( 2010 , 7 , 26 , 10 , 10 , 10 ) ) do
2010-07-31 12:43:41 +00:00
copied = ActiveRecord :: Migration . copy ( @migrations_path , { :bukkits = > MIGRATIONS_ROOT + " /to_copy_with_timestamps " } )
2010-10-08 19:17:14 +00:00
assert File . exists? ( @migrations_path + " /20100726101010_people_have_hobbies.rb " )
assert File . exists? ( @migrations_path + " /20100726101011_people_have_descriptions.rb " )
2010-07-31 12:43:41 +00:00
assert_equal 2 , copied . length
end
ensure
clear
end
2010-07-26 12:06:14 +00:00
end
2005-10-29 18:40:49 +00:00
end
2010-12-02 01:08:01 +00:00