diff options
-rw-r--r-- | activerecord/CHANGELOG | 2 | ||||
-rw-r--r-- | activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb | 28 | ||||
-rw-r--r-- | activerecord/test/defaults_test.rb | 6 | ||||
-rw-r--r-- | activerecord/test/fixtures/db_definitions/postgresql.sql | 3 |
4 files changed, 24 insertions, 15 deletions
diff --git a/activerecord/CHANGELOG b/activerecord/CHANGELOG index 2c1f8d7bd9..fd5bf2f174 100644 --- a/activerecord/CHANGELOG +++ b/activerecord/CHANGELOG @@ -1,5 +1,7 @@ *SVN* +* PostgreSQL: support multiline default values. #7533 [Carl Lerche, aguynamedryan, Rein Henrichs, Tarmo Tänav] + * MySQL: fix change_column on not-null columns that don't accept dfeault values of ''. #6663 [Jonathan Viney, Tarmo Tänav] * validates_uniqueness_of behaves well with single-table inheritance. #3833 [Gabriel Gironda, rramdas, François Beausoleil, Josh Peek, Tarmo Tänav] diff --git a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb index 331f331de7..a5d550c84b 100644 --- a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb @@ -160,45 +160,45 @@ module ActiveRecord def self.extract_value_from_default(default) case default # Numeric types - when /^-?\d+(\.\d*)?$/ + when /\A-?\d+(\.\d*)?\z/ default # Character types - when /^'(.*)'::(?:character varying|bpchar|text)$/ + when /\A'(.*)'::(?:character varying|bpchar|text)\z/m $1 # Binary data types - when /^'(.*)'::bytea$/ + when /\A'(.*)'::bytea\z/m $1 # Date/time types - when /^'(.+)'::(?:time(?:stamp)? with(?:out)? time zone|date)$/ + when /\A'(.+)'::(?:time(?:stamp)? with(?:out)? time zone|date)\z/ $1 - when /^'(.*)'::interval$/ + when /\A'(.*)'::interval\z/ $1 # Boolean type - when /^true$/ + when 'true' true - when /^false$/ + when 'false' false # Geometric types - when /^'(.*)'::(?:point|line|lseg|box|"?path"?|polygon|circle)$/ + when /\A'(.*)'::(?:point|line|lseg|box|"?path"?|polygon|circle)\z/ $1 # Network address types - when /^'(.*)'::(?:cidr|inet|macaddr)$/ + when /\A'(.*)'::(?:cidr|inet|macaddr)\z/ $1 # Bit string types - when /^B'(.*)'::"?bit(?: varying)?"?$/ + when /\AB'(.*)'::"?bit(?: varying)?"?\z/ $1 # XML type - when /^'(.*)'::xml$/ + when /\A'(.*)'::xml\z/m $1 # Arrays - when /^'(.*)'::"?\D+"?\[\]$/ + when /\A'(.*)'::"?\D+"?\[\]\z/ $1 # Object identifier types - when /^-?\d+$/ + when /\A-?\d+\z/ $1 else # Anything else is blank, some user type, or some function - # and we can't know the value of that, so return nil. + # and we can't know the value of that, so return nil. nil end end diff --git a/activerecord/test/defaults_test.rb b/activerecord/test/defaults_test.rb index 39dcc82b49..965dd956b0 100644 --- a/activerecord/test/defaults_test.rb +++ b/activerecord/test/defaults_test.rb @@ -57,4 +57,10 @@ class DefaultTest < Test::Unit::TestCase assert_equal BigDecimal.new("2.78"), default.decimal_number end end + + if current_adapter?(:PostgreSQLAdapter) + def test_multiline_default_text + assert_equal "--- []\n\n", Default.columns_hash['multiline_default'].default + end + end end diff --git a/activerecord/test/fixtures/db_definitions/postgresql.sql b/activerecord/test/fixtures/db_definitions/postgresql.sql index 3b929e338c..5e38978e21 100644 --- a/activerecord/test/fixtures/db_definitions/postgresql.sql +++ b/activerecord/test/fixtures/db_definitions/postgresql.sql @@ -109,7 +109,8 @@ CREATE TABLE defaults ( char3 text default 'a text field', positive_integer integer default 1, negative_integer integer default -1, - decimal_number decimal(3,2) default 2.78 + decimal_number decimal(3,2) default 2.78, + multiline_default text DEFAULT E'--- []\n\n'::text ); CREATE TABLE auto_id_tests ( |