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.
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论