这不再适用,您可以将生成器设置为在生成 Rails 应用程序的新部分时创建 RSpec 规范文件,以及为应用程序的现有部分创建规范文件。
主要功能在于应用程序的生成器配置,该配置在运行 rspec-rails rspec:install 任务时启用,但如果您想指定特定的规范文件以包含/排除,你可能想要这个:
config/environments/development.rb // 或者你想要的任何环境
Rails.application.configure do
...
config.generators do |g|
g.test_framework :rspec
g.fixture_replacement :factory_bot
g.factory_bot dir: 'spec/factories'
g.controller_specs false
g.request_specs true
g.helper_specs false
g.feature_specs true
g.mailer_specs true
g.model_specs true
g.observer_specs false
g.routing_specs false
g.view_specs false
end
end
发电机设置
“test_framework”选项允许 rails 准确地知道要为哪个测试框架创建测试文件,并根据您的设置生成新文件。
使用“fixture_replacement”,我们可以在默认情况下阻止 rails 生成夹具,而是在创建每个模型时创建工厂。
最后是“factory_bot”选项,如果需要,您可以在其中更改工厂文件夹默认值,但在安装时将默认为该目录。您可以在Factory Girl/Bot Instructions 中找到更多选项。
现在当我们生成新的东西时,比如模型:
> rails g model settings
invoke active_record
create db/migrate/20170915173537_create_settings.rb
create app/models/setting.rb
invoke rspec
create spec/models/setting_spec.rb
invoke factory_girl
create spec/factories/settings.rb
为应用程序的预生成部分生成规范文件
类似于生成rails文件,可以通过Rspec自己的task生成spec文件:
> rails g rspec:model old_settings
create spec/models/old_settings_spec.rb
invoke factory_girl
create spec/factories/old_settings.rb
此命令使用与 rails 的 generate 命令相同的约定来创建规范文件,包括 scaffold,因此您可以为整个命名空间创建规范文件。