1
0
Fork 0
mirror of https://github.com/thoughtbot/factory_bot_rails.git synced 2022-11-09 11:49:18 -05:00
thoughtbot--factory_bot_rails/README.md

90 lines
2.8 KiB
Markdown
Raw Normal View History

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
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
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
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
Add `factory_girl_rails` to your Gemfile:
2010-06-09 11:42:48 -04:00
```ruby
gem 'factory_girl_rails'
```
2010-06-09 11:42:48 -04:00
Generators for factories will automatically substitute fixture (and maybe any other
`fixture_replacement` you set). If you want to disable this feature, add the
following to your application.rb file:
```ruby
config.generators do |g|
g.factory_girl false
end
```
Default factories directory is `test/factories`, or `spec/factories` if
`test_framework` generator is set to `:rspec`; change this behavior with:
```ruby
config.generators do |g|
g.factory_girl dir: 'custom/dir/for/factories'
end
```
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.
2014-07-25 16:26:52 -04:00
factory_girl takes an option `suffix: 'some_suffix'` to generate factories as
`modelname_some_suffix.rb`.
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`.
2014-07-25 16:26:52 -04:00
## Contributing
2010-06-09 11:42:48 -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
![thoughtbot](http://thoughtbot.com/images/tm/logo.png)
2010-06-09 11:42:48 -04: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
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
[LICENSE](LICENSE) file.
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