开发者

Rails' new_record? not reset (to true) if transaction is rolled back

So take the following test in Rspec:

require 'spec_helper'
describe Author do
  self.use_transactional_fixtures = false

  after(:each) do
    Author.destroy_all
  end

  i开发者_开发百科t "should behave normal when using transactions" do
    my_author = nil
    begin
      Author.transaction do
        my_author = Author.new(:name => "My Name")
        my_author.new_record?.should be_true
        my_author.save!
        raise "some exception"
      end
    rescue
    end
    Author.count.should == 0
    my_author.new_record?.should be_true
  end
end

The last line:

my_author.new_record?.should be_true

gives:

'Author should behave normal when using transactions' FAILED
expected true, got false

at least when you roll back some record creation, I expect it to roll back completely, so resetting the new_record? and the id too. Am I missing something here? Is this intended? I'm using rails 2.3.5


Delph, this is a bug in rails. It should reset id and new_record, but it does not.

See the link below for more info

https://rails.lighthouseapp.com/projects/8994/tickets/1948-transaction-block-sets-model-id-to-non-existent-row


Yes, this is intended. The transaction operation is a database-only block. It will not change anything about about your in-memory ruby objects.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜