-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathGuardfile
43 lines (35 loc) · 1.45 KB
/
Guardfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# frozen_string_literal: true
# A sample Guardfile
# More info at https://github.com/guard/guard#readme
## Uncomment and set this to only include directories you want to watch
# directories %(app lib config test spec feature)
## Uncomment to clear the screen before every task
# clearing :on
# NOTE: The cmd option is now required due to the increasing number of ways
# rspec may be run, below are examples of the most common uses.
# * bundler: 'bundle exec rspec'
# * bundler binstubs: 'bin/rspec'
# * spring: 'bin/rspec' (This will use spring if running and you have
# installed the spring binstubs per the docs)
# * zeus: 'zeus rspec' (requires the server to be started separately)
# * 'just' rspec: 'rspec'
guard :rspec, cmd: 'bundle exec rspec' do
require 'ostruct'
# Generic Ruby apps
rspec = OpenStruct.new
rspec.spec = ->(m) { "spec/#{m}_spec.rb" }
rspec.spec_dir = 'spec'
rspec.spec_helper = 'spec/spec_helper.rb'
rspec.spec_support = %r{^spec/support/(.+)\.rb$}
rspec.factories = %r{^spec/factories(.+)\.rb$}
watch(%r{^spec/.+_spec\.rb$}) { rspec.spec_dir }
watch(%r{^lib/(.+)\.rb$}) { |m| rspec.spec.call("lib/#{m[1]}") }
watch(rspec.spec_helper) { rspec.spec_dir }
watch(rspec.spec_support) { rspec.spec_dir }
watch(rspec.factories) { rspec.spec_dir }
end
guard :rubocop do
watch(/.+\.rb$/)
watch(/.+\.gemspec$/)
watch(%r{(?:.+/)?\.rubocop\.yml$}) { |m| File.dirname(m[0]) }
end