2014-07-25 16:26:52 -04:00
|
|
|
# factory_girl_rails [![Build Status][ci-image]][ci] [![Code Climate][grade-image]][grade]
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
[factory_girl][fg] is a fixtures replacement with a straightforward definition
|
2010-06-09 11:42:48 -04:00
|
|
|
syntax, support for multiple build strategies (saved instances, unsaved
|
|
|
|
instances, attribute hashes, and stubbed objects), and support for multiple
|
2013-02-08 15:27:10 -05:00
|
|
|
factories for the same class (`user`, `admin_user`, and so on), including factory
|
2010-06-09 11:42:48 -04:00
|
|
|
inheritance.
|
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
## Rails
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
factory_girl_rails provides Rails integration for [factory_girl][fg].
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2011-07-28 09:46:06 -04:00
|
|
|
Currently, automatic factory definition loading is the only Rails-specific feature.
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-05-26 23:39:51 -04:00
|
|
|
Supported Rails versions are listed in [`Appraisals`](Appraisals). Supported
|
|
|
|
Ruby versions are listed in [`.travis.yml`](.travis.yml).
|
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
## Download
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
Github: http://github.com/thoughtbot/factory_girl_rails
|
2010-06-09 11:42:48 -04:00
|
|
|
|
|
|
|
Gem:
|
2011-07-28 09:46:06 -04:00
|
|
|
|
2016-05-08 10:53:37 -04:00
|
|
|
$ gem install factory_girl_rails
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
## Configuration
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2013-02-08 15:27:10 -05:00
|
|
|
Add `factory_girl_rails` to your Gemfile:
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-04-16 06:33:02 -04:00
|
|
|
```ruby
|
2016-07-16 15:02:53 -04:00
|
|
|
group :development, :test do
|
|
|
|
gem 'factory_girl_rails'
|
|
|
|
end
|
2014-04-16 06:33:02 -04:00
|
|
|
```
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2013-02-19 10:41:54 -05:00
|
|
|
Generators for factories will automatically substitute fixture (and maybe any other
|
2014-01-12 23:01:57 -05:00
|
|
|
`fixture_replacement` you set). If you want to disable this feature, add the
|
2013-02-19 10:41:54 -05:00
|
|
|
following to your application.rb file:
|
2012-11-29 05:46:29 -05:00
|
|
|
|
2014-04-16 06:33:02 -04:00
|
|
|
```ruby
|
|
|
|
config.generators do |g|
|
|
|
|
g.factory_girl false
|
|
|
|
end
|
|
|
|
```
|
2013-02-19 10:41:54 -05:00
|
|
|
|
|
|
|
Default factories directory is `test/factories`, or `spec/factories` if
|
|
|
|
`test_framework` generator is set to `:rspec`; change this behavior with:
|
|
|
|
|
2014-04-16 06:33:02 -04:00
|
|
|
```ruby
|
|
|
|
config.generators do |g|
|
|
|
|
g.factory_girl dir: 'custom/dir/for/factories'
|
|
|
|
end
|
|
|
|
```
|
2012-11-29 05:46:29 -05:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
If you use factory_girl for fixture replacement, ensure that
|
|
|
|
factory_girl_rails is available in the development group. If it's not, Rails
|
|
|
|
will generate standard .yml files instead of factory files.
|
2013-02-08 15:27:10 -05:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
factory_girl takes an option `suffix: 'some_suffix'` to generate factories as
|
2014-08-07 19:15:39 -04:00
|
|
|
`modelname_some_suffix.rb`.
|
2014-07-25 19:10:08 -04:00
|
|
|
|
|
|
|
If you use factory_girl for fixture replacement and already have a
|
|
|
|
`factories.rb` file in the directory that contains your tests,
|
|
|
|
factory_girl_rails will insert new factory definitions at the top of
|
|
|
|
`factories.rb`.
|
2012-11-29 05:46:29 -05:00
|
|
|
|
2015-11-18 03:28:27 -05:00
|
|
|
You may need to configure your test suite to include factory_girl methods; see
|
|
|
|
[configuration](https://github.com/thoughtbot/factory_girl/blob/master/GETTING_STARTED.md#configure-your-test-suite).
|
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
## Contributing
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-08-06 20:42:20 -04:00
|
|
|
Please see [CONTRIBUTING.md](CONTRIBUTING.md).
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
## Credits
|
2011-07-28 09:46:06 -04:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
[factory_girl][fg] was originally written by Joe Ferris.
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2011-01-19 13:27:57 -05:00
|
|
|
![thoughtbot](http://thoughtbot.com/images/tm/logo.png)
|
2010-06-09 11:42:48 -04:00
|
|
|
|
2011-01-19 13:27:57 -05:00
|
|
|
factory_girl is maintained and funded by [thoughtbot, inc](http://thoughtbot.com/community)
|
|
|
|
|
|
|
|
The names and logos for thoughtbot are trademarks of thoughtbot, inc.
|
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
## License
|
|
|
|
|
2016-04-02 16:05:26 -04:00
|
|
|
factory_girl_rails is Copyright © 2008-2016 Joe Ferris and thoughtbot. It is free
|
2014-07-25 16:26:52 -04:00
|
|
|
software, and may be redistributed under the terms specified in the
|
2016-04-02 16:05:26 -04:00
|
|
|
[LICENSE](LICENSE) file.
|
2011-01-19 13:27:57 -05:00
|
|
|
|
2014-07-25 16:26:52 -04:00
|
|
|
[fg]: https://github.com/thoughtbot/factory_girl
|
|
|
|
[ci]: http://travis-ci.org/thoughtbot/factory_girl_rails?branch=master
|
|
|
|
[ci-image]: https://secure.travis-ci.org/thoughtbot/factory_girl_rails.png
|
|
|
|
[grade]: https://codeclimate.com/github/thoughtbot/factory_girl_rails
|
|
|
|
[grade-image]: https://codeclimate.com/github/thoughtbot/factory_girl_rails.png
|