Guard rspec-rails: запускать только спецификации моделей - PullRequest
3 голосов
/ 09 июля 2019

Мы используем Guard gem для автоматического запуска спецификаций в приложении Rails 5. Как настроить его для запуска только спецификации моделей? Наш конфиг:

guard :rspec, cmd: 'spring rspec -p', parallel: true, failed_mode: :focus do

Мы пытались изменить его на

guard :rspec, cmd: 'spring rspec ./spec/models/ -p', parallel: true, failed_mode: :focus do

но он все еще запускает все тесты.

1 Ответ

0 голосов
/ 09 июля 2019

В Guardfile ищите любые строки, подобные этим:

  watch(%r{^app/controllers/(.+)_(controller)\.rb$})  { "spec/features" }
  watch(%r{^app/models/(.+)\.rb$})  { "spec/features" }
  watch(rails.controllers) do |m|
    [
      rspec.spec.call("routing/#{m[1]}_routing"),
      rspec.spec.call("controllers/#{m[1]}_controller"),
      rspec.spec.call("acceptance/#{m[1]}")
    ]
  end

Эта строка, например:

watch(%r{^app/models/(.+)\.rb$})  { "spec/features" }

Как вы можете видеть, он наблюдает за изменениями, которые происходят с папкой моделей, затемзапустите спецификацию / функции

Замените ее на:

watch(%r{^app/models/(.+)\.rb$})  { "spec/models" }

Запустите спецификацию моделей только при изменении какого-либо файла на моделях.

Это мой Gaurdfile, который яЯ использую в случае, если это может помочь вам

guard :rspec, cmd: "bundle exec rspec" do
  require "guard/rspec/dsl"
  dsl = Guard::RSpec::Dsl.new(self)

  # RSpec files
  rspec = dsl.rspec
  watch(rspec.spec_helper) { rspec.spec_dir }
  watch(rspec.spec_support) { rspec.spec_dir }
  watch(rspec.spec_files)

  # Ruby files
  ruby = dsl.ruby
  dsl.watch_spec_files_for(ruby.lib_files)

  # Rails files
  rails = dsl.rails(view_extensions: %w(erb haml slim))
  dsl.watch_spec_files_for(rails.app_files)
  dsl.watch_spec_files_for(rails.views)

  watch(%r{^app/controllers/(.+)_(controller)\.rb$})  { "spec/features" }
  watch(%r{^app/models/(.+)\.rb$})  { "spec/features" }
  watch(rails.controllers) do |m|
    [
      rspec.spec.call("routing/#{m[1]}_routing"),
      rspec.spec.call("controllers/#{m[1]}_controller"),
      rspec.spec.call("acceptance/#{m[1]}")
    ]
  end

  # Rails config changes
  watch(rails.spec_helper)     { rspec.spec_dir }
  watch(rails.routes)          { "#{rspec.spec_dir}/routing" }
  watch(rails.routes)          { "spec"  } # { "#{rspec.spec_dir}/routing"  }
  watch(rails.app_controller)  { "#{rspec.spec_dir}/controllers" }

  # Capybara features specs
  watch(rails.view_dirs)     { "spec/features"  } # { |m| rspec.spec.call("features/#{m[1]}")  }
  watch(rails.layouts)       { |m| rspec.spec.call("features/#{m[1]}") }

  # Turnip features and steps
  watch(%r{^spec/acceptance/(.+)\.feature$})
  watch(%r{^spec/acceptance/steps/(.+)_steps\.rb$}) do |m|
    Dir[File.join("**/#{m[1]}.feature")][0] || "spec/acceptance"
  end
end

Если вы решили использовать этот скрипт, просто замените строки, которые я упомянул выше, в то время как я рекомендую вам использовать ваши собственные конфигурации, так как Guardfile предназначен дляразные в зависимости от потребностей каждого

...