SkipDatabase
Adds functionality to Test::Unit tests descending from ActiveSupport::TestCase to toggle database execution within a single test suite.
Installation
gem install skip_database
Usage
In order to toggle database skipping, run tests with the –skip-database command-line option.
Within test classes descending from ActiveSupport::TestCase, commands executed within the skip_database block are only executed when the skip-database option is set. Commands within the with_database block are only executed for tests run with database execution.
SkipDatabase uses “UnitRecord”:github.com/dan-manges/unit-record to raise exceptions when database statements are executed. By default, ActiveRecord::Base is disconnected with the options :stub_associations set to true and :strategy set to :raise.
Immediately after ActiveRecord::Base is disconnected, SkipDatabase requires any files found in test/skip_database/ under the Rails root directory.
Example
class UserTest < ActiveSupport::TestCase
def test_user_name_must_be_unique
user = User.new(:first => "Elwin", :last => "Ransom")
# this block won't be executed unless we're skipping the database
skip_database do
User.expects(:create!).with(:first => user.first, :last => user.last)
user.expects(:save).returns false
user.errors.add(:name, "must be unique")
end
User.create!(:first => "Elwin", :last => "Ransom")
assert !user.save
assert_equal user.errors.on(:name), "must be unique"
end
# Do not run the following tests when skipping database execution
with_database do
def test_complex_methods
Company.build_by_factory(:users => 3, :admin => 1)
users = User.find_by_sql <<-SQL
select * from users
join permissions on permissions.user_id = users.id
join companies on companies.id = users.company_id
where permissions.role = 'user' and companies.active is true
SQL
admins = User.find_by_sql <<-SQL
select * from users
join permissions on permissions.user_id = users.id
join companies on companies.id = users.company_id
where permissions.role = 'admin' and companies.active is true
SQL
assert_equal 2, users.size
assert_equal 1, admins.size
end
end
end
$ ruby test/unit/user_test.rb –skip-database Loaded suite test/unit/user_test Started . Finished in 0.01123 seconds.
1 tests, 4 assertions, 0 failures, 0 errors
$ ruby test/unit/user_test.rb Loaded suite test/unit/user_test Started .. Finished in 0.31526 seconds.
2 tests, 4 assertions, 0 failures, 0 errors
Copyright © 2010 Mike Bradford <[email protected]>, released under the MIT license