Ruby on Rails Wednesday, February 27, 2013

Hey everyone! I am pumped to announce that Rails 3.2.13.rc1 has been released!
If no regressions are found I will release 3.2.13 final in two weeks, on March
13, 2013. If you find one, please [Open an Issue on
GitHub](https://github.com/rails/rails/issues/new) so that I can fix it before
the final release.

This is a bugfix release, with 287 commits. There is one big thing that is
technically a fix but is sort of a feature: Ruby 2.0 support. Big thanks to
Prem Sichanugrist for putting that together! Please give your applications a
try on Ruby 2.0 and let me know how that goes.

## CHANGES since 3.2.12

*Action Mailer*

No changes.

*Action Pack*

* Determine the controller#action from only the matched path when using the
shorthand syntax. Previously the complete path was used, which led
to problems with nesting (scopes and namespaces).
Fixes #7554.
Backport #9361.

Example:

# this will route to questions#new
scope ':locale' do
get 'questions/new'
end

*Yves Senn*

* Fix `assert_template` with `render :stream => true`.
Fix #1743.
Backport #5288.

*Sergey Nartimov*

* Eagerly populate the http method loookup cache so local project
inflections do
not interfere with use of underscore method ( and we don't need locks )

*Aditya Sanghi*

* `BestStandardsSupport` no longer duplicates `X-UA-Compatible` values on
each request to prevent header size from blowing up.

*Edward Anderson*

* Fixed JSON params parsing regression for non-object JSON content.

*Dylan Smith*

* Prevent unnecessary asset compilation when using `javascript_include_tag` on
files with non-standard extensions.

*Noah Silas*

* Fixes issue where duplicate assets can be required with sprockets.

*Jeremy Jackson*

* Bump `rack` dependency to 1.4.3, eliminate `Rack::File` headers
deprecation warning.

*Sam Ruby + Carlos Antonio da Silva*

* Do not append second slash to `root_url` when using `trailing_slash: true`

Fix #8700.
Backport #8701.

Example:
# before
root_url # => http://test.host//

# after
root_url # => http://test.host/

*Yves Senn*

* Fix a bug in `content_tag_for` that prevents it for work without a block.

*Jasl*

* Clear url helper methods when routes are reloaded by removing the methods
explicitly rather than just clearing the module because it didn't work
properly and could be the source of a memory leak.

*Andrew White*

* Fix a bug in `ActionDispatch::Request#raw_post` that caused
`env['rack.input']`
to be read but not rewound.

*Matt Venables*

* More descriptive error messages when calling `render :partial` with
an invalid `:layout` argument.

Fixes #8376.

render :partial => 'partial', :layout => true
# results in ActionView::MissingTemplate: Missing partial /true

*Yves Senn*

* Accept symbols as `#send_data` :disposition value. [Backport
#8329] *Elia Schito*

* Add i18n scope to `distance_of_time_in_words`. [Backport #7997]
*Steve Klabnik*

* Fix side effect of `url_for` changing the `:controller` string
option. [Backport #6003]
Before:

controller = '/projects'
url_for :controller => controller, :action => 'status'

puts controller #=> 'projects'

After

puts controller #=> '/projects'

*Nikita Beloglazov + Andrew White*

* Introduce `ActionView::Template::Handlers::ERB.escape_whitelist`.
This is a list
of mime types where template text is not html escaped by default.
It prevents `Jack & Joe`
from rendering as `Jack & Joe` for the whitelisted mime types.
The default whitelist
contains text/plain. Fix #7976 [Backport #8235]

*Joost Baaij*

* `BestStandardsSupport` middleware now appends it's
`X-UA-Compatible` value to app's
returned value if any. Fix #8086 [Backport #8093]

*Nikita Afanasenko*

* prevent double slashes in engine urls when
`Rails.application.default_url_options[:trailing_slash] = true` is set
Fix #7842

*Yves Senn*

* Fix input name when `:multiple => true` and `:index` are set.

Before:

check_box("post", "comment_ids", { :multiple => true, :index
=> "foo" }, 1)
#=> <input name=\"post[foo][comment_ids]\" type=\"hidden\"
value=\"0\" /><input id=\"post_foo_comment_ids_1\"
name=\"post[foo][comment_ids]\" type=\"checkbox\" value=\"1\" />

After:

check_box("post", "comment_ids", { :multiple => true, :index
=> "foo" }, 1)
#=> <input name=\"post[foo][comment_ids][]\" type=\"hidden\"
value=\"0\" /><input id=\"post_foo_comment_ids_1\"
name=\"post[foo][comment_ids][]\" type=\"checkbox\" value=\"1\" />

Fix #8108

*Daniel Fox, Grant Hutchins & Trace Wax*

*Active Model*

* Specify type of singular association during serialization *Steve Klabnik*

*Active Record*

* Reverted 921a296a3390192a71abeec6d9a035cc6d1865c8, 'Quote numeric values
compared to string columns.' This caused several regressions.

*Steve Klabnik*

* Fix overriding of attributes by default_scope on `ActiveRecord::Base#dup`.

*Hiroshige UMINO*

* Fix issue with overriding Active Record reader methods with a
composed object
and using that attribute as the scope of a `uniqueness_of` validation.
Backport #7072.

*Peter Brown*

* Sqlite now preserves custom primary keys when copying or altering tables.
Fixes #9367.
Backport #2312.

*Sean Scally + Yves Senn*

* Preloading `has_many :through` associations with conditions won't
cache the `:through` association. This will prevent invalid
subsets to be cached.
Fixes #8423.
Backport #9252.

Example:

class User
has_many :posts
has_many :recent_comments, -> { where('created_at > ?',
1.week.ago) }, :through => :posts
end

a_user = User.includes(:recent_comments).first

# this is preloaded
a_user.recent_comments

# fetching the recent_comments through the posts association
won't preload it.
a_user.posts

*Yves Senn*

* Fix handling of dirty time zone aware attributes

Previously, when `time_zone_aware_attributes` were enabled, after
changing a datetime or timestamp attribute and then changing it back
to the original value, `changed_attributes` still tracked the
attribute as changed. This caused `[attribute]_changed?` and
`changed?` methods to return true incorrectly.

Example:

in_time_zone 'Paris' do
order = Order.new
original_time = Time.local(2012, 10, 10)
order.shipped_at = original_time
order.save
order.changed? # => false

# changing value
order.shipped_at = Time.local(2013, 1, 1)
order.changed? # => true

# reverting to original value
order.shipped_at = original_time
order.changed? # => false, used to return true
end

Backport of #9073
Fixes #8898

*Lilibeth De La Cruz*

* Fix counter cache columns not updated when replacing `has_many :through`
associations.
Backport #8400.
Fix #7630.

*Matthew Robertson*

* Don't update `column_defaults` when calling destructive methods on
column with default value.
Backport c517602.
Fix #6115.

*Piotr Sarnacki + Aleksey Magusev + Alan Daud*

* When `#count` is used in conjunction with `#uniq` we perform
`count(:distinct => true)`.
Fix #6865.

Example:

relation.uniq.count # => SELECT COUNT(DISTINCT *)

*Yves Senn + Kaspar Schiess*

* Fix `ActiveRecord::Relation#pluck` when columns or tables are
reserved words.
Backport #7536.
Fix #8968.

*Ian Lesperance + Yves Senn + Kaspar Schiess*

* Don't run explain on slow queries for database adapters that don't
support it.
Backport #6197.

*Blake Smith*

* Revert round usec when comparing timestamp attributes in the dirty tracking.
Fixes #8460.

*Andrew White*

* Revert creation of through association models when using `collection=[]`
on a `has_many :through` association from an unsaved model.
Fix #7661, #8269.

*Ernie Miller*

* Fix undefined method `to_i` when calling `new` on a scope that uses an
Array; Fix FloatDomainError when setting integer column to NaN.
Fixes #8718, #8734, #8757.

*Jason Stirk + Tristan Harward*

* Serialized attributes can be serialized in integer columns.
Fix #8575.

*Rafael Mendonça França*

* Keep index names when using `alter_table` with sqlite3.
Fix #3489.
Backport #8522.

*Yves Senn*

* Recognize migrations placed in directories containing numbers and 'rb'.
Fix #8492.
Backport of #8500.

*Yves Senn*

* Add `ActiveRecord::Base.cache_timestamp_format` class attribute to control
the format of the timestamp value in the cache key.
This allows users to improve the precision of the cache key.
Fixes #8195.

*Rafael Mendonça França*

* Add `:nsec` date format. This can be used to improve the precision
of cache key.
Please note that this format only works with Ruby 1.9, Ruby 1.8
will ignore it completely.

*Jamie Gaskins*

* Unscope `update_column(s)` query to ignore default scope.

When applying `default_scope` to a class with a where clause, using
`update_column(s)` could generate a query that would not properly update
the record due to the where clause from the `default_scope` being applied
to the update query.

class User < ActiveRecord::Base
default_scope where(active: true)
end

user = User.first
user.active = false
user.save!

user.update_column(:active, true) # => false

In this situation we want to skip the default_scope clause and just
update the record based on the primary key. With this change:

user.update_column(:active, true) # => true

Backport of #8436 fix.

*Carlos Antonio da Silva*

* Fix performance problem with primary_key method in PostgreSQL
adapter when having many schemas.
Uses pg_constraint table instead of pg_depend table which has many
records in general.
Fix #8414

*kennyj*

* Do not instantiate intermediate Active Record objects when eager loading.
These records caused `after_find` to run more than expected.
Fix #3313
Backport of #8403

*Yves Senn*

* Fix `pluck` to work with joins. Backport of #4942.

*Carlos Antonio da Silva*

* Fix a problem with `translate_exception` method in a non English
environment.
Backport of #6397.

*kennyj*

* Fix dirty attribute checks for TimeZoneConversion with nil and blank
datetime attributes. Setting a nil datetime to a blank string should not
result in a change being flagged.
Fixes #8310.
Backport of #8311.

*Alisdair McDiarmid*

* Prevent mass assignment to the type column of polymorphic
associations when using `build`.
Fixes #8265.
Backport of #8291.

*Yves Senn*

* When running migrations on Postgresql, the `:limit` option for
`binary` and `text` columns is
silently dropped.
Previously, these migrations caused sql exceptions, because
Postgresql doesn't support limits
on these types.

*Victor Costan*

* `#pluck` can be used on a relation with `select` clause.
Fixes #7551.
Backport of #8176.

Example:

Topic.select([:approved, :id]).order(:id).pluck(:id)

*Yves Senn*

* Use `nil?` instead of `blank?` to check whether dynamic finder with a bang
should raise RecordNotFound.
Fixes #7238.

*Nikita Afanasenko*

* Fix deleting from a HABTM join table upon destroying an object of a model
with optimistic locking enabled.
Fixes #5332.

*Nick Rogers*

* Use query cache/uncache when using ENV["DATABASE_URL"].
Fixes #6951.
Backport of #8074.

*kennyj*

* Do not create useless database transaction when building `has_one`
association.

Example:

User.has_one :profile
User.new.build_profile

Backport of #8154.

*Bogdan Gusiev*

* `AR::Base#attributes_before_type_cast` now returns unserialized
values for serialized attributes.

*Nikita Afanasenko*

* Fix issue that raises `NameError` when overriding the
`accepts_nested_attributes` in child classes.

Before:

class Shared::Person < ActiveRecord::Base
has_one :address

accepts_nested_attributes :address, :reject_if => :all_blank
end

class Person < Shared::Person
accepts_nested_attributes :address
end

Person
#=> NameError: method `address_attributes=' not defined in Person

After:

Person
#=> Person(id: integer, ...)

Fixes #8131.

*Gabriel Sobrinho, Ricardo Henrique*

*Active Resource*

No changes.

*Active Support*

* Fix DateTime comparison with DateTime::Infinity object.

*Dan Kubb*

* Remove surrogate unicode character encoding from ActiveSupport::JSON.encode
The encoding scheme was broken for unicode characters outside the basic
multilingual plane; since json is assumed to be UTF-8, and we
already force the
encoding to UTF-8 simply pass through the un-encoded characters.

*Brett Carter*

* Fix mocha v0.13.0 compatibility. *James Mead*

* `#as_json` isolates options when encoding a hash. [Backport #8185]
Fix #8182

*Yves Senn*

* Handle the possible Permission Denied errors atomic.rb might trigger due to
its chown and chmod calls. [Backport #8027]

*Daniele Sluijters*

*Railties*

No changes.

*Full listing*

To see the full list of changes, [check out all the commits on
GitHub](https://github.com/rails/rails/compare/v3.2.12...v3.2.13.rc1).

## SHA-1

If you'd like to verify that your gem is the same as the one I've uploaded,
please use these SHA-1 hashes:

* `6a33c2d10abb5512499addb675df658e179f2e79` actionmailer-3.2.13.rc1.gem
* `11d8303470698c5b0ac68f187a15093c07383c89` actionpack-3.2.13.rc1.gem
* `a72dafd8b1e3372cc4dda9015b93bf5509b25baa` activemodel-3.2.13.rc1.gem
* `3c6463ab11658b5ab0fe6a4ad06eb52968ef4492` activerecord-3.2.13.rc1.gem
* `06cec200b95dc1f64614cd03432e9ab06742a865` activeresource-3.2.13.rc1.gem
* `5ff59cacae5295baf30a6fb8fb656037f22af3c2` activesupport-3.2.13.rc1.gem
* `facf4549445922d9dc2a836283ae928fa52df4f8` rails-3.2.13.rc1.gem
* `55e44f621efbf531d9ccade6d27259f7dabae167` railties-3.2.13.rc1.gem

<3<3<3

--
You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com.
To post to this group, send email to rubyonrails-talk@googlegroups.com.
For more options, visit https://groups.google.com/groups/opt_out.

No comments:

Post a Comment