Helps you spawn ActiveRecord databases at the beginning of your tests and destroying them when you're done. Handles database configuration with YAML. Only works for mysql at the moment.
Add this line to your application's Gemfile:
gem 'phenix'
And then execute:
$ bundle
Or install it yourself as:
$ gem install phenix
# helper.rb
Phenix.configure do |config| # do not pass any block if you just want the defaults
config.database_config_path = '/my/path/database.yml' # defaults to 'test/database.yml'
config.schema_path = 'my/path/schema.rb' # defaults to 'test/schema.rb'
config.skip_database = ->(name, conf) { name =~ /do_not_create/ } # define this lambda if you want to skip the creation of some databases
end
# in your test file
before do
Phenix.rise! # pass with_schema: false if you don't want the schema loaded
end
after do
Phenix.burn!
end
bundle exec rspec
This will assume that your DB is accessible via localhost for root with no password.
For a different configuration, you can use the MYSQL_URL environment variable (see test/complex_database.yml).
Bug reports and pull requests are welcome on GitHub at https://github.com/zendesk/phenix.