Sha256: eefb2242368592fdb350db69392126f87e651f3137b44815cc30c80dc8e92e2e
Contents?: true
Size: 1.88 KB
Versions: 1
Compression:
Stored size: 1.88 KB
Contents
require 'database_cleaner/active_record/base' require 'database_cleaner/generic/transaction' module DatabaseCleaner::ActiveRecord class Transaction include ::DatabaseCleaner::ActiveRecord::Base include ::DatabaseCleaner::Generic::Transaction def start # Hack to make sure that the connection is properly setup for # the clean code. connection_class.connection.transaction{ } if connection_maintains_transaction_count? if connection_class.connection.respond_to?(:increment_open_transactions) connection_class.connection.increment_open_transactions else connection_class.__send__(:increment_open_transactions) end end if connection_class.connection.respond_to?(:begin_transaction) connection_class.connection.begin_transaction :joinable => false else connection_class.connection.begin_db_transaction end end def clean connection_class.connection_pool.connections.each do |connection| next unless connection.open_transactions > 0 if connection.respond_to?(:rollback_transaction) connection.rollback_transaction else connection.rollback_db_transaction end # The below is for handling after_commit hooks.. see https://github.com/bmabey/database_cleaner/issues/99 if connection.respond_to?(:rollback_transaction_records, true) connection.send(:rollback_transaction_records, true) end if connection_maintains_transaction_count? if connection.respond_to?(:decrement_open_transactions) connection.decrement_open_transactions else connection_class.__send__(:decrement_open_transactions) end end end end private def connection_maintains_transaction_count? ActiveRecord::VERSION::MAJOR < 4 end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
database_cleaner-active_record-2.0.0.beta | lib/database_cleaner/active_record/transaction.rb |