-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathGuardfile
40 lines (32 loc) · 1.6 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
# 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', all_after_pass: true 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'
watch(%r{^spec/.+_spec\.rb$})
watch(%r{^lib/(.+)\.rb$}) { |m| rspec.spec.("lib/#{m[1]}") }
watch(rspec.spec_helper) { rspec.spec_dir }
hound = OpenStruct.new
hound.libspec = ->(m) { "spec/lib/hound/tools/#{m}_spec.rb" }
hound.libspecs = ->(m) { m.map { |name| hound.libspec.(name) } }
hound.template_r = ->(m) { /^#{Regexp.quote("lib/hound/tools/templates/_#{m}")}$/ }
watch('lib/hound/tools/template.rb') { hound.libspecs.(%w(cli hound_yml hound_defaults)) }
watch(hound.template_r.('.hound.yml')) { hound.libspecs.(%w(cli hound_yml)) }
watch(hound.template_r.('.rubocop.hound_defaults.yml')) { hound.libspecs.(%w(cli hound_defaults)) }
end