diff options
author | Michael Koziarski <michael@koziarski.com> | 2007-09-04 02:44:10 +0000 |
---|---|---|
committer | Michael Koziarski <michael@koziarski.com> | 2007-09-04 02:44:10 +0000 |
commit | 3bbef581afc4bbe1f6280b56a1b6a6a12133c9d9 (patch) | |
tree | f83a3c17f3d8b80b5d228d153d0b5fece21f8d47 /activerecord | |
parent | 109bf67f3fa998b661e46785ee4a2b8fec1479df (diff) | |
download | rails-3bbef581afc4bbe1f6280b56a1b6a6a12133c9d9.tar.gz rails-3bbef581afc4bbe1f6280b56a1b6a6a12133c9d9.tar.bz2 rails-3bbef581afc4bbe1f6280b56a1b6a6a12133c9d9.zip |
Work around mysql limitations for defaults on text columns with not null. Closes #9324 [caio]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7405 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord')
-rwxr-xr-x | activerecord/lib/active_record/connection_adapters/mysql_adapter.rb | 1 | ||||
-rw-r--r-- | activerecord/test/migration_test.rb | 2 | ||||
-rw-r--r-- | activerecord/test/schema_dumper_test.rb | 2 |
3 files changed, 3 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb b/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb index 7edf5b0f2d..47a1b355f8 100755 --- a/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb @@ -92,6 +92,7 @@ module ActiveRecord @original_default = default super @default = nil if no_default_allowed? || missing_default_forged_as_empty_string? + @default = '' if @original_default == '' && no_default_allowed? end private diff --git a/activerecord/test/migration_test.rb b/activerecord/test/migration_test.rb index d1e2059c9a..727ce86d30 100644 --- a/activerecord/test/migration_test.rb +++ b/activerecord/test/migration_test.rb @@ -748,7 +748,7 @@ if ActiveRecord::Base.connection.supports_migrations? columns = Person.connection.columns(:binary_testings) data_column = columns.detect { |c| c.name == "data" } - assert_nil data_column.default + assert_equal '', data_column.default Person.connection.drop_table :binary_testings rescue nil end diff --git a/activerecord/test/schema_dumper_test.rb b/activerecord/test/schema_dumper_test.rb index d18b99d561..fa2b8bdf24 100644 --- a/activerecord/test/schema_dumper_test.rb +++ b/activerecord/test/schema_dumper_test.rb @@ -108,7 +108,7 @@ if ActiveRecord::Base.connection.respond_to?(:tables) if current_adapter?(:MysqlAdapter) def test_schema_dump_should_not_add_default_value_for_mysql_text_field output = standard_dump - assert_match %r{t.text\s+"body",\s+:null => false$}, output + assert_match %r{t.text\s+"body",\s+:default => "",\s+:null => false$}, output end end |