FactoryFaster optimizes your Rails app's FactoryGirl usage by replacing
build where it's safe to do so.
Add this line to your application's
Gemfile in the 'development' group:
And then execute:
Process just one file with:
bundle exec script/rails runner "FactoryFaster::Batch.new('test/unit/foo_test.rb').process"
Or if you want to include the gem but not
require it in your
bundle exec script/rails runner "require 'factory_faster' ; FactoryFaster::Batch.new('test/unit/foo_test.rb').process"
Or use a glob to process lots of files:
bundle exec script/rails runner "FactoryFaster::Batch.new('test/unit/*.rb').process"
The output will be something like this:
foo> $ bundle exec script/rails runner "FactoryFaster::Batch.new('test/unit/foo_test.rb').process" Processing test/unit/foo_test.rb Checking target 1 of 2 on line 42 Replacing create with build Running test Passed! Checking target 2 of 2 on line 207 Replacing create with build Running test Passed! 2 of 2 could be replaced, so replacing those
BUGS / TODO
Adding a new test to a file invalidates all the skip line numbers after the addition. Subsequent runs then get both the old and the new line numbers, so gradually more and more lines get skipped.
FactoryFaster will miss the case there a test case has multiple calls to
Factory.create and if more than one of then has to be switched to
Factory.build in order to trigger an error.
FactoryFaster depends on
sed to replace the code. It could use plain old Ruby instead.
FactoryFaster doesn't skip commented out lines.
- Fork it ( http://github.com//factory_faster/fork )
- Create your feature branch (
git checkout -b my-new-feature)
- Commit your changes (
git commit -am 'Add some feature')
- Push to the branch (
git push origin my-new-feature)
- Create new Pull Request
- Tom Copeland - author
- Ronnie Miller - method name bugfix