Upgraded Rails and RSpec
[monkeycharger.git] / vendor / rails / activerecord / test / active_schema_test_mysql.rb
blob673c86c7ce206d26b8367a7ecf369f45d70ba894
1 require 'abstract_unit'
3 class ActiveSchemaTest < Test::Unit::TestCase
4   def setup
5     ActiveRecord::ConnectionAdapters::MysqlAdapter.class_eval do
6       alias_method :real_execute, :execute
7       def execute(sql, name = nil) return sql end
8     end
9   end
11   def teardown
12     ActiveRecord::ConnectionAdapters::MysqlAdapter.send(:alias_method, :execute, :real_execute)
13   end
15   def test_drop_table
16     assert_equal "DROP TABLE `people`", drop_table(:people)
17   end
19   if current_adapter?(:MysqlAdapter)
20     def test_create_mysql_database_with_encoding
21       assert_equal "CREATE DATABASE `matt` DEFAULT CHARACTER SET `utf8`", create_database(:matt)
22       assert_equal "CREATE DATABASE `aimonetti` DEFAULT CHARACTER SET `latin1`", create_database(:aimonetti, {:charset => 'latin1'})
23       assert_equal "CREATE DATABASE `matt_aimonetti` DEFAULT CHARACTER SET `big5` COLLATE `big5_chinese_ci`", create_database(:matt_aimonetti, {:charset => :big5, :collation => :big5_chinese_ci})
24     end
25   end
27   def test_add_column
28     assert_equal "ALTER TABLE `people` ADD `last_name` varchar(255)", add_column(:people, :last_name, :string)
29   end
31   def test_add_column_with_limit
32     assert_equal "ALTER TABLE `people` ADD `key` varchar(32)", add_column(:people, :key, :string, :limit => 32)
33   end
35   def test_drop_table_with_specific_database
36     assert_equal "DROP TABLE `otherdb`.`people`", drop_table('otherdb.people')
37   end
38   
39   private
40     def method_missing(method_symbol, *arguments)
41       ActiveRecord::Base.connection.send(method_symbol, *arguments)
42     end
43 end