<?xml version="1.0" encoding="UTF-8"?>
<feed xmlns="http://www.w3.org/2005/Atom" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" xml:lang="en-US">
  <title>Riding Rails - home</title>
  <id>tag:weblog.rubyonrails.org,2012:mephisto/</id>
  <generator uri="http://mephistoblog.com" version="0.7.3">Mephisto Noh-Varr</generator>
  
  <link href="http://weblog.rubyonrails.org/" rel="alternate" type="text/html" />
  <updated>2012-03-07T22:04:38Z</updated>
  <atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/atom+xml" href="http://feeds.feedburner.com/RidingRails" /><feedburner:info uri="ridingrails" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>fxn</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-03-07:30674</id>
    <published>2012-03-07T19:22:00Z</published>
    <updated>2012-03-07T22:04:38Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/97SIO_evLXg/what-is-docrails" rel="alternate" type="text/html" />
    <title>What is docrails?</title>
<content type="html">
            &lt;p&gt;Over the years I have seen some confusion about what is exactly
&lt;a href="https://github.com/lifo/docrails"&gt;docrails&lt;/a&gt;
and how it relates to the documentation of Ruby on Rails.&lt;/p&gt;

&lt;p&gt;This post explains everything you want to know about this aspect of the project.&lt;/p&gt;

&lt;h2&gt;What is docrails?&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://github.com/lifo/docrails"&gt;docrails&lt;/a&gt; is a branch of Ruby on Rails with
&lt;em&gt;public write access&lt;/em&gt; where anyone can push &lt;em&gt;doc fixes&lt;/em&gt;.&lt;/p&gt;

&lt;p&gt;If you see a typo, you'd like to correct a factual error, complement some
existing documentation, add a useful example... before docrails existed you had
to open a pull request (or the equivalent in those days) and follow the ordinary
workflow to get it accepted. docrails allows you to clone the repo, edit, and
push. Done!&lt;/p&gt;

&lt;h2&gt;ZOMG, that's awesome! Tell me more!&lt;/h2&gt;

&lt;p&gt;Changes to the code base need review before they are pushed. Each individual new
feature or bug fix needs the perspective and responsability of core team
members to take a decision about it.&lt;/p&gt;

&lt;p&gt;Documentation fixes, though, are much more likely to be fine as they are. So,
docrails has a public write policy to ease the workflow for &lt;em&gt;contributors&lt;/em&gt;.&lt;/p&gt;

&lt;p&gt;All commits have to be reviewed anyway, so docrails needs the same effort from
Rails committers than going through pull requests, please everyone give big
props to &lt;a href="https://twitter.com/#!/vijay_dev"&gt;Vijay Dev&lt;/a&gt; who is nowadays in charge
of this time consuming task.&lt;/p&gt;

&lt;p&gt;The point of docrails is to provide a way to contribute to the Rails documentation
that is fast and easy for contributors.&lt;/p&gt;

&lt;h2&gt;But wait, I am editing some separate thing?&lt;/h2&gt;

&lt;p&gt;docrails is a separate branch because it has a different access policy, but
&lt;em&gt;you are editing the actual Ruby on Rails documentation&lt;/em&gt;.&lt;/p&gt;

&lt;p&gt;Every few days, once all new commits are reviewed docrails is merged into
master, and master is merged into docrails. Also, very important edits may be
cherry-picked into stable branches at the discrection of who merges.&lt;/p&gt;

&lt;h2&gt;What is allowed in docrails?&lt;/h2&gt;

&lt;p&gt;You can freely push changes to any RDoc, guides, and READMEs.&lt;/p&gt;

&lt;p&gt;No code can be touched at all. That's a hard rule. No matter how insignificant,
not even a one character typo in a string literal.&lt;/p&gt;

&lt;p&gt;CHANGELOGs cannot be edited either.&lt;/p&gt;

&lt;h2&gt;Is docrails a documentation project?&lt;/h2&gt;

&lt;p&gt;No, Ruby on Rails has no documentation project. Treating documentation as a
separate aspect of the project would be similar to treating testing as an
external part of the project.&lt;/p&gt;

&lt;p&gt;Documentation is an integral part of the development of Ruby on Rails.
Contributing a feature or bug fix means contributing its code, test coverage,
and documentation.&lt;/p&gt;

&lt;h2&gt;I am preparing a pull request, should I document later via docrails?&lt;/h2&gt;

&lt;p&gt;No, docrails is meant only for quick doc fixes.&lt;/p&gt;

&lt;p&gt;Pull requests should be complete: code, tests, and docs. If a pull request lacks
any of those in general it won't be accepted as is.&lt;/p&gt;

&lt;p&gt;Also, updating docs does not only mean that you edit the RDoc next to the code
you are touching. Often the change needs grepping the project tree to find
instances of what the pull request is about, to update examples, revise
explanations affected by your change, or writing new documentation.&lt;/p&gt;

&lt;p&gt;Tidbit: run ack -a to have guides included in the search.&lt;/p&gt;

&lt;h2&gt;I made a doc fix, when is it going to be online?&lt;/h2&gt;

&lt;p&gt;Rails releases are a complete set. The documentation itself is part of the
release. The fix is going to be online in the &lt;a href="http://api.rubyonrails.org/"&gt;stable API&lt;/a&gt; or
&lt;a href="http://guides.rubyonrails.org/"&gt;guides&lt;/a&gt; websites when
the branch that contains the fix gets released.&lt;/p&gt;

&lt;p&gt;Edits merged into master are always online in the &lt;a href="http://edgeapi.rubyonrails.org/"&gt;edge API&lt;/a&gt;
and &lt;a href="http://edgeguides.rubyonrails.org/"&gt;edge guides&lt;/a&gt;,
which are regenerated after every push to master. Thus, edits done via docrails
are online in the edge docs website after the next docrails/master cross-merge.&lt;/p&gt;

&lt;h2&gt;Can I open pull requests for documentation fixes in Ruby on Rails?&lt;/h2&gt;

&lt;p&gt;Absolutely. Specially if you are unsure about the fix. But if you feel confident
just push to docrails.&lt;/p&gt;

&lt;p&gt;Please do not open pull requests in docrails.&lt;/p&gt;

&lt;p&gt;Note that docrails has no issues tab. The reason is docrails is not a project,
as explained above, only a way to bypass pull requests. Documentation issues are
Ruby on Rails issues and belong to the Ruby on Rails project just as any other
kind of issue.&lt;/p&gt;

&lt;h2&gt;Does Ruby on Rails has documenters?&lt;/h2&gt;

&lt;p&gt;No, documentation comes with each push to master. Everyone documents Rails.&lt;/p&gt;

&lt;p&gt;The only exception is guide authors. Guide authors take the task to write an
entire new guide about a certain topic, and they are allowed to push early
drafts to docrails for convenience (only guides in the public index are
considered to be published).&lt;/p&gt;

&lt;p&gt;That's for new guides. Once published, guides maintenance happens in master as
everything else.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/3/7/what-is-docrails</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>aaronp</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-03-01:30582</id>
    <published>2012-03-01T18:12:00Z</published>
    <updated>2012-03-01T18:13:41Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/rXux5g2eKSk/ann-rails-3-2-2-has-been-released" rel="alternate" type="text/html" />
    <title>[ANN] Rails 3.2.2 has been released!</title>
<content type="html">
            &lt;p&gt;Rails 3.2.2 has been released.  This release contains various bug fixes and two important security fixes.  All users are recommended to upgrade as soon as possible.&lt;/p&gt;

&lt;h2&gt;CHANGES&lt;/h2&gt;

&lt;p&gt;For information regarding the possible vulnerabilities, please see the announcements &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/edd28f1e3d04e913"&gt;here&lt;/a&gt; and &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/9da0c515a6c4664"&gt;here&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Some highlights from this release are:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Log files are always flushed&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Failing tests will exit with nonzero status code&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Elimination of calls to deprecated methods&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Query cache instrumentation includes bindings in the payload&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Hidden checkbox values are not set if the value is nil&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Various Ruby 2.0 compatibility fixes&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;For a comprehensive list, see the &lt;a href="https://github.com/rails/rails/compare/v3.2.1...v3.2.2"&gt;commits on github&lt;/a&gt;.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/3/1/ann-rails-3-2-2-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>aaronp</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-03-01:30581</id>
    <published>2012-03-01T18:11:00Z</published>
    <updated>2012-03-01T18:12:32Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/lZYC948sCmo/ann-rails-3-1-4-has-been-released" rel="alternate" type="text/html" />
    <title>[ANN] Rails 3.1.4 has been released!</title>
<content type="html">
            &lt;p&gt;Rails 3.1.4 has been released.  This release contains various bug fixes and two important security fixes.  All users are recommended to upgrade as soon as possible.&lt;/p&gt;

&lt;h2&gt;CHANGES&lt;/h2&gt;

&lt;p&gt;For information regarding the possible vulnerabilities, please see the announcements &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/edd28f1e3d04e913"&gt;here&lt;/a&gt; and &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/9da0c515a6c4664"&gt;here&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Some highlights from this release are:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;thrrubyrhino&lt;/code&gt; is added to the Gemfile for JRuby users&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Routing cache improvements&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Assets group may be skipped with the &lt;code&gt;--skip-sprockets&lt;/code&gt; flag&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Various Ruby 2.0 compatibility fixes&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;For a comprehensive list, see the &lt;a href="https://github.com/rails/rails/compare/v3.1.3...v3.1.4"&gt;commits on github&lt;/a&gt;.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/3/1/ann-rails-3-1-4-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>aaronp</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-03-01:30580</id>
    <published>2012-03-01T18:08:00Z</published>
    <updated>2012-03-01T18:11:01Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/p3kXOhVgSPc/ann-rails-3-0-12-has-been-released" rel="alternate" type="text/html" />
    <title>[ANN] Rails 3.0.12 has been released!</title>
<content type="html">
            &lt;p&gt;Rails 3.0.12 has been released.  This release contains various bug fixes and two important security fixes.  All users are recommended to upgrade as soon as possible.&lt;/p&gt;

&lt;h2&gt;CHANGES&lt;/h2&gt;

&lt;p&gt;For information regarding the possible vulnerabilities, please see the announcements &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/edd28f1e3d04e913"&gt;here&lt;/a&gt; and &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/9da0c515a6c4664"&gt;here&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Some highlights from this release are:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;require&lt;/code&gt; and &lt;code&gt;load&lt;/code&gt; will return the value from the superclass&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;ActiveModel confirmation validation fixes&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Increasing rack dependency&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;For a comprehensive list, see the &lt;a href="https://github.com/rails/rails/compare/v3.0.11...v3.0.12"&gt;commits on github&lt;/a&gt;.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/3/1/ann-rails-3-0-12-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>fxn</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-02-26:30516</id>
    <published>2012-02-26T01:54:00Z</published>
    <updated>2012-02-28T20:46:50Z</updated>
    <category term="Edge" />
    <category term="edge" />
    <category term="http" />
    <category term="patch" />
    <category term="rest" />
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/SjuN22Fbqlg/edge-rails-patch-is-the-new-primary-http-method-for-updates" rel="alternate" type="text/html" />
    <title>Edge Rails: PATCH is the new primary HTTP method for updates</title>
<content type="html">
            &lt;h2&gt;What is PATCH?&lt;/h2&gt;

&lt;p&gt;The HTTP method PUT means resource &lt;em&gt;creation&lt;/em&gt; or &lt;em&gt;replacement&lt;/em&gt; at some given URL.&lt;/p&gt;

&lt;p&gt;Think files, for example. If you upload a file to S3 at some URL, you want
either to create the file at that URL or replace an existing file if there's
one. That is PUT.&lt;/p&gt;

&lt;p&gt;Now let's say a web application has an &lt;code&gt;Invoice&lt;/code&gt; model with a &lt;code&gt;paid&lt;/code&gt; flag that
indicates whether the invoice has been paid. How do you set that flag in a
RESTful way? Submitting &lt;code&gt;paid=1&lt;/code&gt; via PUT to &lt;code&gt;/invoices/:id&lt;/code&gt; does not conform to
HTTP semantics, because such request would not be sending a &lt;em&gt;complete representation&lt;/em&gt; of the invoice &lt;em&gt;for replacement&lt;/em&gt;.&lt;/p&gt;

&lt;p&gt;With the constraints of the methods GET, POST, PUT, DELETE, the traditional answer
is to define the paid flag of a given invoice to be a resource by itself. So,
you define a route to be able to PUT &lt;code&gt;paid=1&lt;/code&gt; to &lt;code&gt;/invoices/:id/paid&lt;/code&gt;. You have
to do that because PUT does not allow &lt;em&gt;partial updates&lt;/em&gt; to a resource.&lt;/p&gt;

&lt;p&gt;Now let's think about ordinary edit forms in typical Ruby on Rails applications.
How many times are we sending a complete representation for replacement? Not
always, perhaps we could say that it is even rare in practice that you do so.
For example, the conventional &lt;code&gt;created_at&lt;/code&gt; and &lt;code&gt;updated_at&lt;/code&gt; timestamps normally
can't be set by end-users, though they are often considered to belong to the
representation of resources that map to records.&lt;/p&gt;

&lt;p&gt;PUT in addition is an &lt;em&gt;idempotent&lt;/em&gt; method. You should be able to replay a request
as many times as you want and get the same resource, something that sometimes
is violated by conventional idioms for creating children resources using
nested attributes while updating a parent resource.&lt;/p&gt;

&lt;p&gt;There's nothing theoretical preventing PUT from doing partial updates, but when
HTTP was being standarized the replacement semantics were already deployed.&lt;/p&gt;

&lt;p&gt;Because of that, the &lt;a href="http://www.rfc-editor.org/rfc/rfc5789.txt"&gt;PATCH&lt;/a&gt; method was defined in 1995 and standarized later.
PATCH is a method that is not safe,
nor idempotent, and allows &lt;em&gt;full and partial updates&lt;/em&gt; and &lt;em&gt;side-effects on other resources&lt;/em&gt;.&lt;/p&gt;

&lt;p&gt;In practice, as you see, PATCH suits everyday web programming way better than
PUT for updating resources. In Ruby on Rails it corresponds naturally to the way
we use &lt;code&gt;update_attributes&lt;/code&gt; for updating records.&lt;/p&gt;

&lt;p&gt;Thus, PATCH is going to be the primary method for updates in Rails 4.0.&lt;/p&gt;

&lt;h2&gt;Routing&lt;/h2&gt;

&lt;p&gt;This is an important change, but we plan to do it in a way that is backwards
compatible.&lt;/p&gt;

&lt;p&gt;When a resource is declared in &lt;em&gt;config/routes.rb&lt;/em&gt;, for example,&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;resources :users
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;the action in &lt;code&gt;UsersController&lt;/code&gt; to update a user is still &lt;code&gt;update&lt;/code&gt; in Rails 4.0.&lt;/p&gt;

&lt;p&gt;PUT requests to &lt;code&gt;/users/:id&lt;/code&gt; in Rails 4.0 get routed to &lt;code&gt;update&lt;/code&gt; as they are
today. So, if you have an API that gets real PUT requests it is going to work.&lt;/p&gt;

&lt;p&gt;In Rails 4.0, though, the router also routes PATCH requests to &lt;code&gt;/users/:id&lt;/code&gt; to
the &lt;code&gt;update&lt;/code&gt; action.&lt;/p&gt;

&lt;p&gt;So, in Rails 4.0 both PUT and PATCH are routed to &lt;code&gt;update&lt;/code&gt;.&lt;/p&gt;

&lt;h2&gt;Forms&lt;/h2&gt;

&lt;p&gt;Forms of persisted resources:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;form_for @user
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;get "patch" in the hidden field "_method". The RFC is deliberately vague about
the way to represent changes in a PATCH request. Submitting a form is
perfectly valid, client and server must simply agree on the accepted ways
to update a resource.&lt;/p&gt;

&lt;p&gt;Let me emphasize that the "_method" hack is a workaround for the limitations in
web browsers. As you probably know Rails routes real HTTP methods. That is, actual
PUT, DELETE, and now, PATCH requests are routed to their respective actions.&lt;/p&gt;

&lt;h2&gt;General availability&lt;/h2&gt;

&lt;p&gt;PATCH requests are available in all places where the rest of the methods are
available today. There is a &lt;code&gt;patch&lt;/code&gt; macro for the routes DSL, &lt;code&gt;:via&lt;/code&gt; understands
the symbol &lt;code&gt;:patch&lt;/code&gt;. Tests can issue PATCH requests, request objects respond to
&lt;code&gt;patch?&lt;/code&gt;, etc. Please see the &lt;a href="https://github.com/rails/rails/commit/002713c64568114f3754799acc0723ea0d442f7a"&gt;original commit&lt;/a&gt; for details (with an important
followup &lt;a href="https://github.com/rails/rails/commit/b7a094536de6fdeb428aa79d21f1e2128169f45e"&gt;here&lt;/a&gt;).&lt;/p&gt;

&lt;h2&gt;Will my web server understand PATCH?&lt;/h2&gt;

&lt;p&gt;Yes, it should. I have personally tried Apache, nginx, Phusion Passenger,
Unicorn, Thin, and WEBrick. They all understood PATCH requests out of the box.&lt;/p&gt;

&lt;p&gt;Also, HTTP clients should be in general able to issue PATCH requests. For example
in curl(1) you'd execute:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;curl -d'user[name]=wadus' -X PATCH http://localhost:3000/users/1
&lt;/code&gt;&lt;/pre&gt;

&lt;h2&gt;Credits&lt;/h2&gt;

&lt;p&gt;We would like to thank &lt;a href="https://github.com/dlee"&gt;David Lee&lt;/a&gt; for this
contribution and endless patience to keep interested in this even &lt;a href="https://github.com/rails/rails/pull/505"&gt;after months
of discussion&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Also I would like to
highlight the quality of the patch itself. It is excellent: code, tests, all
docs revised, comments in code revised. Everything carefully and
thoroughly updated. &lt;a href="https://github.com/rails/rails/commit/002713c64568114f3754799acc0723ea0d442f7a"&gt;An exemplar patch&lt;/a&gt;.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/2/26/edge-rails-patch-is-the-new-primary-http-method-for-updates</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>fxn</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-01-26:30057</id>
    <published>2012-01-26T23:32:00Z</published>
    <updated>2012-01-26T23:33:09Z</updated>
    <category term="Releases" />
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/0bqtPVn_W2A/rails-3-2-1-has-been-released" rel="alternate" type="text/html" />
    <title>Rails 3.2.1 has been released</title>
<content type="html">
            &lt;p&gt;Rails 3.2.1 is out, with some fixes and doc improvements. Please check the &lt;a href="https://gist.github.com/1685812"&gt;CHANGELOGs gist&lt;/a&gt; for details. &lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/1/26/rails-3-2-1-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>David</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-01-20:29824</id>
    <published>2012-01-20T17:22:00Z</published>
    <updated>2012-01-20T18:36:35Z</updated>
    <category term="Releases" />
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/L2cdhO6bEoY/rails-3-2-0-faster-dev-mode-routing-explain-queries-tagged-logger-store" rel="alternate" type="text/html" />
    <title>Rails 3.2.0: Faster dev mode &amp; routing, explain queries, tagged logger, store</title>
<content type="html">
            &lt;p&gt;So we didn’t quite make the December release date as we intended, but hey, why break a good tradition and start hitting release targets now! In any case, your patience has been worldly rewarded young grasshopper: Rails 3.2 is done, baked, tested, and ready to roll!&lt;/p&gt;


	&lt;p&gt;I’ve been running on 3-2-stable for a few months working on &lt;a href="http://37signals.com/basecampnext/"&gt;Basecamp Next&lt;/a&gt; and it’s been a real treat. The new faster dev mode in particular is a major step up over 3.1.&lt;/p&gt;


	&lt;p&gt;Do remember that this is the last intended release series that’s going to support Ruby 1.8.7. The master git branch for Rails is now targeting Rails 4.0, which will require Ruby 1.9.3 and above. So now is a great time to start the work on getting your app ready for the current version of Ruby. Let’s not hang around old versions forever and a Sunday like those Python guys :).&lt;/p&gt;


	&lt;p&gt;There’s a &lt;a href="https://github.com/rails/rails/tree/v3.2.0"&gt;v3.2.0 tag on Github&lt;/a&gt; and we of course we still have the &lt;a href="https://github.com/rails/rails/tree/3-2-stable"&gt;3-2-stable branch&lt;/a&gt; as well. You can see all the glorious details of everything that was changed in our &lt;a href="https://gist.github.com/1648523"&gt;&lt;span class="caps"&gt;CHANGELOG&lt;/span&gt; compilation&lt;/a&gt;.&lt;/p&gt;


	&lt;p&gt;For documentation, we have the &lt;a href="http://guides.rubyonrails.org/3_2_release_notes.html"&gt;3.2 release notes with upgrade instructions&lt;/a&gt;, both &lt;a href="http://api.rubyonrails.org/"&gt;the &lt;span class="caps"&gt;API&lt;/span&gt; docs&lt;/a&gt; and &lt;a href="http://guides.rubyonrails.org/"&gt;the guides&lt;/a&gt; have been generated for 3.2 as well, and there’s a brand new &lt;a href="http://pragprog.com/book/rails4/agile-web-development-with-rails"&gt;3.2-compatible version of Agile Web Development with Rails&lt;/a&gt;. A smörgåsbord indeed!&lt;/p&gt;


	&lt;p&gt;Note: If you’re having trouble installing the gems under Ruby 1.8.7, you’ve probably hit a RubyGems bug with &lt;span class="caps"&gt;YAML&lt;/span&gt; that’s been fixed in RubyGems 1.8.15. You can upgrade RubyGems using “gem update—system”.&lt;/p&gt;


	&lt;p&gt;If you can’t be bothered with the full release notes, here’s a reprint of a few feature highlights from when we did the first release candidate:&lt;/p&gt;


	&lt;p&gt;&lt;strong&gt;Faster dev mode &amp; routing&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;The most noticeable new feature is that development mode got a ton and a half faster. Inspired by &lt;a href="https://github.com/paneq/active_reload"&gt;Active Reload&lt;/a&gt;, we now only reload classes from files you’ve actually changed. The difference is dramatic on a larger application.&lt;/p&gt;


	&lt;p&gt;Route recognition also got a bunch faster thanks to the &lt;a href="https://github.com/rails/journey"&gt;new Journey engine&lt;/a&gt; and we made linking much faster as well (especially apparent when you’re having 100+ links on a single page).&lt;/p&gt;


	&lt;p&gt;&lt;strong&gt;Explain queries&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;We’ve added a &lt;a href="http://weblog.rubyonrails.org/2011/12/6/what-s-new-in-edge-rails-explain"&gt;quick and easy way to explain quieries generated by ARel&lt;/a&gt;. In the console, you can run something like &lt;code&gt;puts Person.active.limit(5).explain&lt;/code&gt; and you’ll get the query ARel produces explained (so you can easily see whether its using the right indexes). There’s even a default threshold in development mode where if a query takes more than half a second to run, it’s automatically explained inline—how about that!&lt;/p&gt;


	&lt;p&gt;&lt;strong&gt;Tagged logger&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;When you’re running a multi-user, multi-account application, it’s a great help to be able to filter the log by who did what. Enter the TaggedLogging wrapper. It works like this:&lt;/p&gt;


	&lt;pre&gt;&lt;code&gt;Logger = ActiveSupport::TaggedLogging.new(Logger.new(STDOUT))
Logger.tagged("BCX") { Logger.info "Stuff" } # Logs "[BCX] Stuff" 
Logger.tagged("BCX") do
  Logger.tagged("Jason") do
    Logger.info "Stuff" # Logs "\[BCX\] \[Jason\] Stuff" 
  end
end&lt;/code&gt;&lt;/pre&gt;


	&lt;p&gt;&lt;strong&gt;Active Record Store&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;Key/value stores are great, but it’s not always you want to go the whole honking way just for a little variable-key action. Enter the Active Record Store:&lt;/p&gt;


	&lt;pre&gt;&lt;code&gt;class User &amp;lt; ActiveRecord::Base
  store :settings, accessors: [ :color, :homepage ]
end&lt;/code&gt;&lt;/pre&gt;


	&lt;pre&gt;&lt;code&gt;u = User.new(color: 'black', homepage: '37signals.com')
u.color                          # Accessor stored attribute
u.settings[:country] = 'Denmark' # Any attribute, even if not specified with an accessor&lt;/code&gt;&lt;/pre&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/1/20/rails-3-2-0-faster-dev-mode-routing-explain-queries-tagged-logger-store</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>spastorino</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2012-01-04:29804</id>
    <published>2012-01-04T21:01:00Z</published>
    <updated>2012-01-04T22:12:09Z</updated>
    <category term="Releases" />
    <category term="3.2.0" />
    <category term="rails" />
    <category term="Rails" />
    <category term="release" />
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/FVQsbdFRReI/rails-3-2-0-rc2-has-been-released" rel="alternate" type="text/html" />
    <title>Rails 3.2.0.rc2 has been released!</title>
<content type="html">
            &lt;p&gt;Hi everyone,&lt;/p&gt;

&lt;p&gt;Rails 3.2.0.rc2 has been released!&lt;/p&gt;

&lt;h2&gt;What to update in your apps&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Update your Gemfile to depend on rails ~&gt; 3.2.0.rc2&lt;/li&gt;
&lt;li&gt;Update your Gemfile to depend on sass-rails ~&gt; 3.2.3&lt;/li&gt;
&lt;li&gt;Start moving any remaining Rails 2.3-style &lt;code&gt;vendor/plugins/*&lt;/code&gt;. These are finally deprecated!&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Extract your vendor/plugins to their own gems and bundle them in your Gemfile. If they're tiny, not worthy of the own gem, fold it into your app as &lt;code&gt;lib/myplugin/*&lt;/code&gt; and &lt;code&gt;config/initializers/myplugin.rb&lt;/code&gt;.&lt;/p&gt;

&lt;h2&gt;Changes since RC1&lt;/h2&gt;

&lt;p&gt;&lt;em&gt;ActionMailer&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActionPack&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Add font_path helper method &lt;strong&gt;Santiago Pastorino&lt;/strong&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Depends on rack ~&gt; 1.4.0 &lt;strong&gt;Santiago Pastorino&lt;/strong&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Add :gzip option to &lt;code&gt;caches_page&lt;/code&gt;. The default option can be configured globally using &lt;code&gt;page_cache_compression&lt;/code&gt; &lt;strong&gt;Andrey Sitnik&lt;/strong&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActiveModel&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActiveRecord&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActiveResource&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActiveSupport&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;ActiveSupport::Base64 is deprecated in favor of ::Base64. &lt;strong&gt;Sergey Nartimov&lt;/strong&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;Railties&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Rails 2.3-style plugins in vendor/plugins are deprecated and will be removed in Rails 4.0. Move them out of vendor/plugins and bundle them in your Gemfile, or fold them in to your app as lib/myplugin/* and config/initializers/myplugin.rb. &lt;strong&gt;Santiago Pastorino&lt;/strong&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Guides are available as a single .mobi for the Kindle and free Kindle readers apps. &lt;strong&gt;Michael Pearson &amp;amp; Xavier Noria&lt;/strong&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Allow scaffold/model/migration generators to accept a "index" and "uniq" modifiers, as in: "tracking_id:integer:uniq" in order to generate (unique) indexes. Some types also accept custom options, for instance, you can specify the precision and scale for decimals as "price:decimal{7,2}". &lt;strong&gt;Dmitrii Samoilov&lt;/strong&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;Gem checksums&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;MD5 (actionmailer-3.2.0.rc2.gem) = 118c83b2cddaa935d1de7534cfb6c810&lt;/li&gt;
&lt;li&gt;MD5 (actionpack-3.2.0.rc2.gem) = 6b18851bc26d5c8958672f27adda05ca&lt;/li&gt;
&lt;li&gt;MD5 (activemodel-3.2.0.rc2.gem) = d82f4eed949dcff17f8bf2aed806679a&lt;/li&gt;
&lt;li&gt;MD5 (activerecord-3.2.0.rc2.gem) = d07806fd5fc464f960200d20ceb2193a&lt;/li&gt;
&lt;li&gt;MD5 (activeresource-3.2.0.rc2.gem) = f51af240ff4623b0b6f8a4293ffa50dc&lt;/li&gt;
&lt;li&gt;MD5 (activesupport-3.2.0.rc2.gem) = 01380240c12e0380c9e61c97dd45f2f1&lt;/li&gt;
&lt;li&gt;MD5 (rails-3.2.0.rc2.gem) = 134f923f7d821f514abf6bdf4af62ca7&lt;/li&gt;
&lt;li&gt;MD5 (railties-3.2.0.rc2.gem) = 4b3ac0f9c5da16b90a1875e8199253d2&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;You can find an exhaustive list of changes on &lt;a href="https://github.com/rails/rails/compare/v3.2.0.rc1...v3.2.0.rc2"&gt;github&lt;/a&gt;. Along with the &lt;a href="https://github.com/rails/rails/issues?milestone=3&amp;amp;state=closed"&gt;closed issues marked for v3.2.0&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;You can also see issues &lt;a href="https://github.com/rails/rails/issues?milestone=3&amp;amp;state=open"&gt;we haven't closed yet&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Thanks to everyone!&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2012/1/4/rails-3-2-0-rc2-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>David</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2011-12-20:29722</id>
    <published>2011-12-20T15:33:00Z</published>
    <updated>2011-12-20T16:06:41Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/_XseWIh5yEQ/rails-master-is-now-4-0-0-beta" rel="alternate" type="text/html" />
    <title>Rails/master is now 4.0.0.beta</title>
<content type="html">
            &lt;p&gt;The &lt;a href="http://weblog.rubyonrails.org/2011/12/20/rails-3-2-rc1-faster-dev-mode-routing-explain-queries-tagged-logger-store"&gt;forthcoming 3.2.x release series&lt;/a&gt; will be the last branch of Rails that supports Ruby 1.8.7. There’s a new &lt;a href="https://github.com/rails/rails/tree/3-2-stable"&gt;3-2-stable branch&lt;/a&gt; in git to track the changes we need until 3.2.0 final is release and for managing point releases after that.&lt;/p&gt;


	&lt;p&gt;So for now you should stop floating on rails/master if your application is not compatible with Ruby 1.9.3. We have updated the version numbers to indicate this backwards incompatibility to be 4.0.0.beta. This doesn’t mean that 4.0 is anywhere close to being released, mind you. We’re simply doing this now because we’re dropping support for Ruby 1.8.7 in rails/master and people should know what’s up.&lt;/p&gt;


	&lt;p&gt;Major versions of Rails has been on about 2-year release cycle since 1.0 (&lt;a href="http://weblog.rubyonrails.org/2005/12/13/rails-1-0-party-like-its-one-oh-oh/"&gt;released in 2005&lt;/a&gt;, &lt;a href="http://weblog.rubyonrails.org/2007/12/7/rails-2-0-it-s-done"&gt;followed by 2.0 in 2007&lt;/a&gt;, &lt;a href="http://weblog.rubyonrails.org/2010/8/29/rails-3-0-it-s-done"&gt;followed by 3.0 in 2010&lt;/a&gt;) and we intend to continue this pattern. The current internal target for Rails 4.0 is sometime in the Summer of 2012 &amp;mdash; but we have blown every major release estimate in the past, so don’t bet your farm on it.&lt;/p&gt;


	&lt;p&gt;There’s not a lot of details about what we’re going to include in Rails 4.0 yet as the primary purpose for bumping the major version number is to drop Ruby 1.8.7 support. But unlike Rails 3.0, we intend for it to be a much smoother transition. The intention is not for this to be a &lt;span class="caps"&gt;REWRITE EVERYTHING&lt;/span&gt; release in the same way 3.0 was to some extent.&lt;/p&gt;


	&lt;p&gt;But we’re getting ahead of ourselves. First mission is to get Rails 3.2 out!&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2011/12/20/rails-master-is-now-4-0-0-beta</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>David</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2011-12-20:29697</id>
    <published>2011-12-20T00:46:00Z</published>
    <updated>2011-12-20T00:48:09Z</updated>
    <category term="Releases" />
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/1ar_9qnCEHw/rails-3-2-rc1-faster-dev-mode-routing-explain-queries-tagged-logger-store" rel="alternate" type="text/html" />
    <title>Rails 3.2 RC1: Faster dev mode &amp; routing, explain queries, tagged logger, store</title>
<content type="html">
            &lt;p&gt;Once you’ve boarded the Rails train, you just know that every stop along the way is going to be a good time. This release candidate is no different and we’ve packed it with loving goodies without making upgrading a hassle.&lt;/p&gt;


	&lt;p&gt;&lt;strong&gt;Faster dev mode &amp; routing&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;The most noticeable new feature is that development mode got a ton and a half faster. Inspired by &lt;a href="https://github.com/paneq/active_reload"&gt;Active Reload&lt;/a&gt;, we now only reload classes from files you’ve actually changed. The difference is dramatic on a larger application.&lt;/p&gt;


	&lt;p&gt;Route recognition also got a bunch faster thanks to the &lt;a href="https://github.com/rails/journey"&gt;new Journey engine&lt;/a&gt; and we made linking much faster as well (especially apparent when you’re having 100+ links on a single page).&lt;/p&gt;


	&lt;p&gt;&lt;strong&gt;Explain queries&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;We’ve added a &lt;a href="http://weblog.rubyonrails.org/2011/12/6/what-s-new-in-edge-rails-explain"&gt;quick and easy way to explain quieries generated by ARel&lt;/a&gt;. In the console, you can run something like &lt;code&gt;puts Person.active.limit(5).explain&lt;/code&gt; and you’ll get the query ARel produces explained (so you can easily see whether its using the right indexes). There’s even a default threshold in development mode where if a query takes more than half a second to run, it’s automatically explained inline—how about that!&lt;/p&gt;


	&lt;p&gt;&lt;strong&gt;Tagged logger&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;When you’re running a multi-user, multi-account application, it’s a great help to be able to filter the log by who did what. Enter the TaggedLogging wrapper. It works like this:&lt;/p&gt;


	&lt;pre&gt;&lt;code&gt;Logger = ActiveSupport::TaggedLogging.new(Logger.new(STDOUT))
Logger.tagged("BCX") { Logger.info "Stuff" } # Logs "[BCX] Stuff" 
Logger.tagged("BCX") do
  Logger.tagged("Jason") do
    Logger.info "Stuff" # Logs "\[BCX\] \[Jason\] Stuff" 
  end
end&lt;/code&gt;&lt;/pre&gt;


	&lt;p&gt;&lt;strong&gt;Active Record Store&lt;/strong&gt;&lt;/p&gt;


	&lt;p&gt;Key/value stores are great, but it’s not always you want to go the whole honking way just for a little variable-key action. Enter the Active Record Store:&lt;/p&gt;


	&lt;pre&gt;&lt;code&gt;class User &amp;lt; ActiveRecord::Base
  store :settings, accessors: [ :color, :homepage ]
end&lt;/code&gt;&lt;/pre&gt;


	&lt;pre&gt;&lt;code&gt;u = User.new(color: 'black', homepage: '37signals.com')
u.color                          # Accessor stored attribute
u.settings[:country] = 'Denmark' # Any attribute, even if not specified with an accessor&lt;/code&gt;&lt;/pre&gt;


	&lt;p&gt;These are just a few of the highlights. The &lt;a href="https://gist.github.com/1472145"&gt;full release notes&lt;/a&gt; detail every loving change.&lt;/p&gt;


	&lt;p&gt;Given that this is a release candidate, we’re ever so eager to hear your feedback. We hope it’ll be a quick RC phase, but please do spoil that plan by &lt;a href="https://github.com/rails/rails/issues"&gt;reporting bugs&lt;/a&gt;.&lt;/p&gt;


	&lt;p&gt;As always, you install a release candidate by doing &lt;code&gt;gem install rails --pre&lt;/code&gt;.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2011/12/20/rails-3-2-rc1-faster-dev-mode-routing-explain-queries-tagged-logger-store</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>fxn</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2011-12-06:29687</id>
    <published>2011-12-06T21:20:00Z</published>
    <updated>2011-12-07T11:23:43Z</updated>
    <category term="Edge" />
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/_9AEzN2MToo/what-s-new-in-edge-rails-explain" rel="alternate" type="text/html" />
    <title>What's new in Edge Rails: EXPLAIN</title>
<content type="html">
            &lt;p&gt;There are some new features related to EXPLAIN in the forthcoming Ruby on Rails 3.2 we'd like
to share:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Running EXPLAIN manually&lt;/li&gt;
&lt;li&gt;Automatic EXPLAIN for slow queries&lt;/li&gt;
&lt;li&gt;Silencing automatic EXPLAIN&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;As of this writing they are available for the adapters &lt;code&gt;sqlite3&lt;/code&gt;, &lt;code&gt;mysql2&lt;/code&gt;, and
&lt;code&gt;postgresql&lt;/code&gt;.&lt;/p&gt;

&lt;h2&gt;Running EXPLAIN Manually&lt;/h2&gt;

&lt;p&gt;You can now run EXPLAIN on the SQL generated by a relation this way:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;User.where(:id =&amp;gt; 1).joins(:posts).explain
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;The result of that method call is a string that carefully imitates the output of
database shells. For example, under MySQL you get something similar to&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;EXPLAIN for: SELECT `users`.* FROM `users` INNER JOIN `posts` ON `posts`.`user_id` = `users`.`id` WHERE `users`.`id` = 1
+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------------+
| id | select_type | table | type  | possible_keys | key     | key_len | ref   | rows | Extra       |
+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------------+
|  1 | SIMPLE      | users | const | PRIMARY       | PRIMARY | 4       | const |    1 |             |
|  1 | SIMPLE      | posts | ALL   | NULL          | NULL    | NULL    | NULL  |    1 | Using where |
+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------------+
2 rows in set (0.00 sec)
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;and under PostgreSQL the same call yields something like&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;EXPLAIN for: SELECT "users".* FROM "users" INNER JOIN "posts" ON "posts"."user_id" = "users"."id" WHERE "users"."id" = 1
                                  QUERY PLAN
------------------------------------------------------------------------------
 Nested Loop Left Join  (cost=0.00..37.24 rows=8 width=0)
   Join Filter: (posts.user_id = users.id)
   -&amp;gt;  Index Scan using users_pkey on users  (cost=0.00..8.27 rows=1 width=4)
         Index Cond: (id = 1)
   -&amp;gt;  Seq Scan on posts  (cost=0.00..28.88 rows=8 width=4)
         Filter: (posts.user_id = 1)
(6 rows)
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;Please note that &lt;code&gt;explain&lt;/code&gt; &lt;strong&gt;runs&lt;/strong&gt; the query or queries and asks the
database for their respective query plan afterwards. This is because due to eager loading a relation may trigger several queries to fetch the records and their associations, and in such cases some queries need the result of
the previous ones.&lt;/p&gt;

&lt;p&gt;If the relation triggers several queries the method still returns a single
string with all the query plans. This is an output meant for human consumption so we preferred to present
everything as a string in a format which is familiar right away rather than a structure.&lt;/p&gt;

&lt;h2&gt;Automatic EXPLAIN For Slow Queries&lt;/h2&gt;

&lt;p&gt;Rails 3.2 has the ability to help in detecting slow queries.&lt;/p&gt;

&lt;p&gt;New applications get&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;config.active_record.auto_explain_threshold_in_seconds = 0.5
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;in &lt;em&gt;config/environments/development.rb&lt;/em&gt;. Active Record monitors queries and if
they take more than that threshold their query plan will be logged using &lt;code&gt;warn&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;That works for anything running &lt;code&gt;find_by_sql&lt;/code&gt; (which is almost everything, since
most of Active Record ends up calling that method). In the particular case of
relations, the threshold is compared against the total time needed to fetch the
records, not against the time taken by each individual query. Because
conceptually we are concerned with the cost of the call&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;User.where(:id =&amp;gt; 1).joins(:posts).explain
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;rather than the cost of the different queries that call may trigger due to the
implementation.&lt;/p&gt;

&lt;p&gt;By default the threshold is &lt;code&gt;nil&lt;/code&gt; in the test and production environments, which
means the feature is disabled.&lt;/p&gt;

&lt;p&gt;The value of that parameter is &lt;code&gt;nil&lt;/code&gt; also if the threshold is not set, so
existing applications will need to add it by hand if they migrate to 3.2 to be
able to enable automatic EXPLAIN.&lt;/p&gt;

&lt;h2&gt;Silencing Automatic EXPLAIN&lt;/h2&gt;

&lt;p&gt;With automatic EXPLAIN enabled, it could still be the case that some queries are
just slow and you know they have to be. For example, a heavyweight report in the
backoffice.&lt;/p&gt;

&lt;p&gt;The macro &lt;code&gt;silence_auto_explain&lt;/code&gt; allows you to avoid having EXPLAIN run
repeatedly in those areas of code:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;ActiveRecord::Base.silence_auto_explain do
  # no automatic EXPLAIN here
end
&lt;/code&gt;&lt;/pre&gt;

&lt;h2&gt;Interpreting Query Plans&lt;/h2&gt;

&lt;p&gt;The interpretation of the query plans is another topic, these are some pointers:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;SQLite: &lt;a href="http://www.sqlite.org/eqp.html"&gt;EXPLAIN QUERY PLAN&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;MySQL: &lt;a href="http://dev.mysql.com/doc/refman/5.6/en/explain-output.html"&gt;EXPLAIN Output Format&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;PostgreSQL: &lt;a href="http://www.postgresql.org/docs/current/static/using-explain.html"&gt;Using EXPLAIN&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Happy debugging!&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2011/12/6/what-s-new-in-edge-rails-explain</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>jonleighton</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2011-11-20:29652</id>
    <published>2011-11-20T23:14:00Z</published>
    <updated>2011-11-20T23:14:51Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/EmdZSBFjb_U/rails-3-1-3-has-been-released" rel="alternate" type="text/html" />
    <title>Rails 3.1.3 has been released</title>
<content type="html">
            &lt;p&gt;Rails 3.1.3 has been released. This release mainly contains fixes for regressions that popped up in 3.1.2.&lt;/p&gt;

&lt;h2&gt;Changes&lt;/h2&gt;

&lt;p&gt;Action Pack:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Downgrade sprockets to ~&gt; 2.0.3. Using 2.1.0 caused regressions.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix using &lt;code&gt;translate&lt;/code&gt; helper with a html translation which uses the &lt;code&gt;:count&lt;/code&gt; option for pluralization.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jon Leighton&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Record:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Perf fix: If we're deleting all records in an association, don't add a IN(..) clause to the query. &lt;em&gt;GH 3672&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jon Leighton&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix bug with referencing other mysql databases in set&lt;em&gt;table&lt;/em&gt;name. &lt;em&gt;GH 3690&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix performance bug with mysql databases on a server with lots of other databses. &lt;em&gt;GH 3678&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Christos Zisopoulos and Kenny J&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Railties:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;New apps should be generated with a sass-rails dependency of 3.1.5, not 3.1.5.rc.2&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;As ever, you can see &lt;a href="https://github.com/rails/rails/compare/v3.1.2...v3.1.3"&gt;a full list of changes&lt;/a&gt; on Github.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2011/11/20/rails-3-1-3-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>jonleighton</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2011-11-18:29621</id>
    <published>2011-11-18T01:51:00Z</published>
    <updated>2011-11-18T01:57:07Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/TBib444xHv8/rails-3-1-2-has-been-released" rel="alternate" type="text/html" />
    <title>Rails 3.1.2 has been released</title>
<content type="html">
            &lt;p&gt;Rails 3.1.2 has been released. This is a patch-level release containing bug fixes and an important security fix.&lt;/p&gt;

&lt;h2&gt;Possible XSS vulnerability in the translate helper method in Ruby on Rails&lt;/h2&gt;

&lt;p&gt;There is a vulnerability in the translate helper method which may allow an attacker to insert arbitrary code into a page.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Versions Affected&lt;/strong&gt;: 3.0.0 and later, 2.3.X in combination with the rails_xss plugin&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Not Affected&lt;/strong&gt;:      Pre-3.0.0 releases, without the rails_xss plugin, did no automatic XSS escaping, so are not considered vulnerable&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Fixed Versions&lt;/strong&gt;:    3.0.11, 3.1.2&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Please see &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/2b61d70fb73c7cc5"&gt;the rubyonrails-security posting&lt;/a&gt; and the changelog item below, for more details.&lt;/p&gt;

&lt;h2&gt;Changes&lt;/h2&gt;

&lt;p&gt;Action Mailer:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Action Pack:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Fix XSS security vulnerability in the &lt;code&gt;translate&lt;/code&gt; helper method. When using interpolation
in combination with HTML-safe translations, the interpolated input would not get HTML
escaped. &lt;em&gt;GH 3664&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;Before:&lt;/p&gt;

&lt;p&gt;translate('foo_html', :something =&amp;gt; '&amp;lt;script&amp;gt;') # =&amp;gt; "...&amp;lt;script&amp;gt;..."&lt;/p&gt;

&lt;p&gt;After:&lt;/p&gt;

&lt;p&gt;translate('foo_html', :something =&amp;gt; '&amp;lt;script&amp;gt;') # =&amp;gt; "...&amp;amp;lt;script&amp;amp;gt;..."&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Sergey Nartimov&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Upgrade sprockets dependency to ~&gt; 2.1.0&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Ensure that the format isn't applied twice to the cache key, else it becomes impossible to target with expire_action.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Christopher Meiklejohn&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Swallow error when can't unmarshall object from session.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Bruno Zanchet&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Implement a workaround for a bug in ruby-1.9.3p0 where an error would be raised while attempting to convert a template from one encoding to another.&lt;/p&gt;

&lt;p&gt;Please see &lt;a href="http://redmine.ruby-lang.org/issues/5564"&gt;http://redmine.ruby-lang.org/issues/5564&lt;/a&gt; for details of the bug.&lt;/p&gt;

&lt;p&gt;The workaround is to load all conversions into memory ahead of time, and will only happen if the ruby version is &lt;em&gt;exactly&lt;/em&gt; 1.9.3p0. The hope is obviously that the underlying problem will be resolved in the next patchlevel release of 1.9.3.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jon Leighton&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Ensure users upgrading from 3.0.x to 3.1.x will properly upgrade their flash object in session (issues #3298 and #2509)&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Model:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Record:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Fix problem with prepared statements and PostgreSQL when multiple schemas are used.
&lt;em&gt;GH #3232&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Juan M. Cuello&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix bug with PostgreSQLAdapter#indexes. When the search path has multiple schemas, spaces
were not being stripped from the schema names after the first.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Sean Kirby&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Preserve SELECT columns on the COUNT for finder_sql when possible. &lt;em&gt;GH 3503&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Justin Mazzi&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Reset prepared statement cache when schema changes impact statement results. &lt;em&gt;GH 3335&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Aaron Patterson&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Postgres: Do not attempt to deallocate a statement if the connection is no longer active.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Ian Leitch&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Prevent QueryCache leaking database connections. &lt;em&gt;GH 3243&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Mark J. Titorenko&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix bug where building the conditions of a nested through association could potentially
modify the conditions of the through and/or source association. If you have experienced
bugs with conditions appearing in the wrong queries when using nested through associations,
this probably solves your problems. &lt;em&gt;GH #3271&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jon Leighton&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;If a record is removed from a has_many :through, all of the join records relating to that
record should also be removed from the through association's target.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jon Leighton&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix adding multiple instances of the same record to a has_many :through. &lt;em&gt;GH #3425&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jon Leighton&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix creating records in a through association with a polymorphic source type. &lt;em&gt;GH #3247&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jon Leighton&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;MySQL: use the information_schema than the describe command when we look for a primary key. &lt;em&gt;GH #3440&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Kenny J&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Resource:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Support:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Railties:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Engines: don't blow up if db/seeds.rb is missing.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Jeremy Kemper&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;rails new foo --skip-test-unit&lt;/code&gt; should not add the &lt;code&gt;:test&lt;/code&gt; task to the rake default task.
&lt;em&gt;GH 2564&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;José Valim&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;As ever, you can &lt;a href="https://github.com/rails/rails/compare/v3.1.1...v3.1.2"&gt;see a full list of commits between the versions&lt;/a&gt; on Github.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2011/11/18/rails-3-1-2-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>jonleighton</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2011-11-18:29622</id>
    <published>2011-11-18T01:27:00Z</published>
    <updated>2011-11-18T01:55:13Z</updated>
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/gcr7aPe1kJg/rails-3-0-11-has-been-released" rel="alternate" type="text/html" />
    <title>Rails 3.0.11 has been released</title>
<content type="html">
            &lt;p&gt;Rails 3.0.11 has been released. This is a patch-level release containing bug fixes and an important security fix.&lt;/p&gt;

&lt;h2&gt;Possible XSS vulnerability in the translate helper method in Ruby on Rails&lt;/h2&gt;

&lt;p&gt;There is a vulnerability in the translate helper method which may allow an attacker to insert arbitrary code into a page.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Versions Affected&lt;/strong&gt;: 3.0.0 and later, 2.3.X in combination with the rails_xss plugin&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Not Affected&lt;/strong&gt;:      Pre-3.0.0 releases, without the rails_xss plugin, did no automatic XSS escaping, so are not considered vulnerable&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Fixed Versions&lt;/strong&gt;:    3.0.11, 3.1.2&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Please see &lt;a href="http://groups.google.com/group/rubyonrails-security/browse_thread/thread/2b61d70fb73c7cc5"&gt;the rubyonrails-security posting&lt;/a&gt; and the changelog item below, for more details.&lt;/p&gt;

&lt;h2&gt;Changes&lt;/h2&gt;

&lt;p&gt;Action Mailer:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Action Pack:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Fix XSS security vulnerability in the &lt;code&gt;translate&lt;/code&gt; helper method. When using interpolation
in combination with HTML-safe translations, the interpolated input would not get HTML
escaped. &lt;em&gt;GH 3664&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;Before:&lt;/p&gt;

&lt;p&gt;translate('foo_html', :something =&amp;gt; '&amp;lt;script&amp;gt;') # =&amp;gt; "...&amp;lt;script&amp;gt;..."&lt;/p&gt;

&lt;p&gt;After:&lt;/p&gt;

&lt;p&gt;translate('foo_html', :something =&amp;gt; '&amp;lt;script&amp;gt;') # =&amp;gt; "...&amp;amp;lt;script&amp;amp;gt;..."&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Sergey Nartimov&lt;/em&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Implement a workaround for a bug in ruby-1.9.3p0 where an error would be
raised while attempting to convert a template from one encoding to another.&lt;/p&gt;

&lt;p&gt;Please see &lt;a href="http://redmine.ruby-lang.org/issues/5564"&gt;http://redmine.ruby-lang.org/issues/5564&lt;/a&gt; for details of the bug.&lt;/p&gt;

&lt;p&gt;The workaround is to load all conversions into memory ahead of time, and will
only happen if the ruby version is exactly 1.9.3p0. The hope is obviously
that the underlying problem will be resolved in the next patchlevel release
of 1.9.3.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix assert_select_email to work on multipart and non-multipart emails as the method stopped working correctly in Rails 3.x due to changes in the new mail gem.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix url_for when passed a hash to prevent additional options (eg. :host, :protocol) from being added to the hash after calling it.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Model:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Record:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Exceptions from database adapters should not lose their backtrace.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Backport "ActiveRecord::Persistence#touch should not use default_scope" (GH #1519)&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Psych errors with poor yaml formatting are proxied. Fixes GH #2645 and
GH #2731&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix ActiveRecord#exists? when passsed a nil value&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Resource:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Active Support:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Railties:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Updated Prototype UJS to lastest version fixing multiples errors in IE [Guillermo Iguaran]&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;As ever, you can &lt;a href="https://github.com/rails/rails/compare/v3.0.10...v3.0.11"&gt;see a full list of commits between the versions&lt;/a&gt; on Github.&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2011/11/18/rails-3-0-11-has-been-released</feedburner:origLink></entry>
  <entry xml:base="http://weblog.rubyonrails.org/">
    <author>
      <name>spastorino</name>
    </author>
    <id>tag:weblog.rubyonrails.org,2011-10-07:29602</id>
    <published>2011-10-07T15:20:00Z</published>
    <updated>2011-10-07T17:26:36Z</updated>
    <category term="Releases" />
    <category term="3.1.1" />
    <category term="rails" />
    <category term="Rails" />
    <category term="release" />
    <link href="http://feedproxy.google.com/~r/RidingRails/~3/SF-F9PsU9bM/ann-rails-3-1-1" rel="alternate" type="text/html" />
    <title>Rails 3.1.1 has been released!</title>
<content type="html">
            &lt;p&gt;Hi everyone,&lt;/p&gt;

&lt;p&gt;Rails 3.1.1 has been released. &lt;strong&gt;This release requires at least sass-rails 3.1.4&lt;/strong&gt;&lt;/p&gt;

&lt;h2&gt;CHANGES&lt;/h2&gt;

&lt;p&gt;&lt;em&gt;ActionMailer&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActionPack&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;stylesheet&lt;em&gt;link&lt;/em&gt;tag('/stylesheets/application') and similar helpers doesn't
throw Sprockets::FileOutsidePaths exception anymore [Santiago Pastorino]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Ensure default&lt;em&gt;asset&lt;/em&gt;host_protocol is respected, closes #2980. [José Valim]&lt;/p&gt;

&lt;p&gt;Changing rake db:schema:dump to run :environment as well as :load_config,
as running :load_config alone will lead to the dumper being run without
including extensions such as those included in foreigner and
spatial_adapter.&lt;/p&gt;

&lt;p&gt;This reverses a change made here:
https://github.com/rails/rails/commit/5df72a238e9fcb18daf6ab6e6dc9051c9106d7bb#L0L324&lt;/p&gt;

&lt;p&gt;I'm assuming here that :load_config needs to be invoked
separately from :environment, as it is elsewhere in the
file for db operations, if not the alternative is to go
back to "task :dump =&gt; :environment do".&lt;/p&gt;

&lt;p&gt;[Ben Woosley]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Update to rack-cache 1.1.&lt;/p&gt;

&lt;p&gt;Versions prior to 1.1 delete the If-Modified-Since and If-Not-Modified
headers when config.action&lt;em&gt;controller.perform&lt;/em&gt;caching is true. This has two
problems:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;unexpected inconsistent behaviour between development &amp;amp;
production environments&lt;/li&gt;
&lt;li&gt;breaks applications that use of these headers&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;[Brendan Ribera]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Ensure that enhancements to assets:precompile task are only run once [Sam Pohlenz]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;TestCase should respect the view_assigns API instead of pulling variables on
its own. [José Valim]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;javascript&lt;em&gt;path and stylesheet&lt;/em&gt;path now refer to /assets if asset pipelining
is on. [Santiago Pastorino]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;button_to support form option. Now you're able to pass for example
'data-type' =&gt; 'json'. [ihower]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;image&lt;em&gt;path and image&lt;/em&gt;tag should use /assets if asset pipelining is turned
on. Closes #3126 [Santiago Pastorino and christos]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Avoid use of existing precompiled assets during rake assets:precompile run.
Closes #3119 [Guillermo Iguaran]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Copy assets to nondigested filenames too [Santiago Pastorino]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Give precedence to &lt;code&gt;config.digest = false&lt;/code&gt; over the existence of
manifest.yml asset digests [christos]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;escape options for the stylesheet&lt;em&gt;link&lt;/em&gt;tag method [Alexey Vakhov]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Re-launch assets:precompile task using (Rake.)ruby instead of Kernel.exec so
it works on Windows [cablegram]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;env var passed to process shouldn't be modified in process method. [Santiago
Pastorino]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;rake assets:precompile&lt;/code&gt; loads the application but does not initialize
it.&lt;/p&gt;

&lt;p&gt;To the app developer, this means configuration add in
config/initializers/* will not be executed.&lt;/p&gt;

&lt;p&gt;&lt;p&gt;Plugins developers need to special case their initializers that are
meant to be run in the assets group by adding :group =&gt; :assets. [José Valim]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Sprockets uses config.assets.prefix for asset_path [asee]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;FileStore key&lt;em&gt;file&lt;/em&gt;path properly limit filenames to 255 characters. [phuibonhoa]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix Hash#to&lt;em&gt;query edge case with html&lt;/em&gt;safe strings. [brainopia]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Allow asset tag helper methods to accept :digest =&gt; false option in order to completely avoid the digest generation.
Useful for linking assets from static html files or from emails when the user
could probably look at an older html email with an older asset. [Santiago Pastorino]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Don't mount Sprockets server at config.assets.prefix if config.assets.compile is false. [Mark J. Titorenko]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Set relative url root in assets when controller isn't available for Sprockets (eg. Sass files using asset_path). Fixes #2435 [Guillermo Iguaran]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix basic auth credential generation to not make newlines. GH #2882&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fixed the behavior of asset pipeline when config.assets.digest and config.assets.compile are false and requested asset isn't precompiled.
Before the requested asset were compiled anyway ignoring that the config.assets.compile flag is false. [Guillermo Iguaran]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;CookieJar is now Enumerable. Fixes #2795&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fixed AssetNotPrecompiled error raised when rake assets:precompile is compiling certain .erb files. See GH #2763 #2765 #2805 [Guillermo Iguaran]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Manifest is correctly placed in assets path when default assets prefix is changed. Fixes #2776 [Guillermo Iguaran]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fixed stylesheet&lt;em&gt;link&lt;/em&gt;tag and javascript&lt;em&gt;include&lt;/em&gt;tag to respect additional options passed by the users when debug is on. [Guillermo Iguaran]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix ActiveRecord#exists? when passsed a nil value&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix assert&lt;em&gt;select&lt;/em&gt;email to work on multipart and non-multipart emails as the method stopped working correctly in Rails 3.x due to changes in the new mail gem.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;em&gt;ActiveModel&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Remove hard dependency on bcrypt-ruby to avoid make ActiveModel dependent on a binary library.
You must add the gem explicitly to your Gemfile if you want use ActiveModel::SecurePassword:&lt;/p&gt;

&lt;p&gt;gem 'bcrypt-ruby', '~&gt; 3.0.0'&lt;/p&gt;

&lt;p&gt;See GH #2687. [Guillermo Iguaran]&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActiveRecord&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Add deprecation for the preload_associations method. Fixes #3022.&lt;/p&gt;

&lt;p&gt;[Jon Leighton]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Don't require a DB connection when loading a model that uses set&lt;em&gt;primary&lt;/em&gt;key. GH #2807.&lt;/p&gt;

&lt;p&gt;[Jon Leighton]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix using select() with a habtm association, e.g. Person.friends.select(:name). GH #3030 and #2923.&lt;/p&gt;

&lt;p&gt;[Hendy Tanata]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix belongs_to polymorphic with custom primary key on target. GH #3104.&lt;/p&gt;

&lt;p&gt;[Jon Leighton]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;CollectionProxy#replace should change the DB records rather than just mutating the array.
Fixes #3020.&lt;/p&gt;

&lt;p&gt;[Jon Leighton]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;LRU cache in mysql and sqlite are now per-process caches.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;lib/active&lt;em&gt;record/connection&lt;/em&gt;adapters/mysql_adapter.rb: LRU cache
keys are per process id.&lt;/li&gt;
&lt;li&gt;lib/active&lt;em&gt;record/connection&lt;/em&gt;adapters/sqlite_adapter.rb: ditto&lt;/li&gt;
&lt;/ul&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Database adapters use a statement pool for limiting the number of open
prepared statments on the database.  The limit defaults to 1000, but can
be adjusted in your database config by changing 'statement_limit'.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix clash between using 'preload', 'joins' or 'eager_load' in a default scope and including the
default scoped model in a nested through association. (GH #2834.) [Jon Leighton]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Ensure we are not comparing a string with a symbol in HasManyAssociation#inverse&lt;em&gt;updates&lt;/em&gt;counter_cache?.
Fixes GH #2755, where a counter cache could be decremented twice as far as it was supposed to be.&lt;/p&gt;

&lt;p&gt;[Jon Leighton]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Don't send any queries to the database when the foreign key of a belongs_to is nil. Fixes
GH #2828. [Georg Friedrich]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fixed find&lt;em&gt;in_batches method to not include order from default&lt;/em&gt;scope. See GH #2832 [Arun Agrawal]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Don't compute table name for abstract classes. Fixes problem with setting the primary key
in an abstract class. See GH #2791. [Akira Matsuda]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Psych errors with poor yaml formatting are proxied. Fixes GH #2645 and
GH #2731&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Use the LIMIT word with the methods #last and #first. Fixes GH #2783 [Damien Mathieu]&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActiveResource&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No changes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;ActiveSupport&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;ruby193: String#prepend is also unsafe [Akira Matsuda]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fix obviously breakage of Time.=== for Time subclasses [jeremyevans]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Added fix so that file store does not raise an exception when cache dir does
not exist yet. This can happen if a delete_matched is called before anything
is saved in the cache. [Philippe Huibonhoa]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Fixed performance issue where TimeZone lookups would require tzinfo each time [Tim Lucas]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;ActiveSupport::OrderedHash is now marked as extractable when using Array#extract_options! [Prem Sichanugrist]&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;em&gt;Railties&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Add jquery-rails to Gemfile of plugins, test/dummy app needs it. Closes #3091. [Santiago Pastorino]&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;rake assets:precompile&lt;/code&gt; loads the application but does not initialize it.&lt;/p&gt;

&lt;p&gt;To the app developer, this means configuration add in
config/initializers/* will not be executed.&lt;/p&gt;

&lt;p&gt;Plugins developers need to special case their initializers that are
meant to be run in the assets group by adding :group =&gt; :assets.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;SHA-1&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;9337cff7772da034b0b34b73b85cf249f1a70f52  actionmailer-3.1.1.gem&lt;/li&gt;
&lt;li&gt;7bb1b8d096a6ff1ff46dcfb778bf86a5daca1b0d  actionpack-3.1.1.gem&lt;/li&gt;
&lt;li&gt;d5dc71e1a9a0e20d819f4dff27ff0697e99a7f64  activemodel-3.1.1.gem&lt;/li&gt;
&lt;li&gt;7245632cb3b38612628304c1e244855d0053f7be  activerecord-3.1.1.gem&lt;/li&gt;
&lt;li&gt;6d09800202c2747e84249b8646f0fd480ed4924f  activeresource-3.1.1.gem&lt;/li&gt;
&lt;li&gt;66df2fd144aab22f52819fd489e33a976d68a46b  activesupport-3.1.1.gem&lt;/li&gt;
&lt;li&gt;6a35a49948bbd9f461839a1a271def90b23a851a  rails-3.1.1.gem&lt;/li&gt;
&lt;li&gt;6979ef891bd03fb639b979af9fdc56781f9358d9  railties-3.1.1.gem&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;You can find an exhaustive list of changes on &lt;a href="https://github.com/rails/rails/compare/v3.1.0...v3.1.1"&gt;github&lt;/a&gt;. Along with the &lt;a href="https://github.com/rails/rails/issues?milestone=6&amp;amp;state=closed"&gt;closed issues marked for v3.1.1&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Thanks to everyone!&lt;/p&gt;
          </content>  <feedburner:origLink>http://weblog.rubyonrails.org/2011/10/7/ann-rails-3-1-1</feedburner:origLink></entry>
</feed>
