1) Edit the Gemfile:
group :development, :test do gem 'guard-rspec', '1.2.1' end # Add System-dependent gems group :test do gem 'capybara', '1.1.2' # Test gems on Macintosh OS X gem 'rb-fsevent', '0.9.1', :require => false gem 'growl', '1.0.3' # Test gems on Linux gem 'rb-inotify', '0.8.8' gem 'libnotify', '0.5.9' # Test gems on Windows gem 'rb-fchange', '0.0.5' gem 'rb-notifu', '0.0.4' gem 'win32console', '1.3.0' end
2) Run the bundler.
$ bundle install
3) Initialize Guard so that it works with RSpec.
$ bundle exec guard init rspec
4) Edit the resulting Guardfile so that Guard will run the right tests when the integration tests and views are updated
require 'active_support/core_ext' guard 'rspec', :version => 2, :all_after_pass => false do # Ensures that Guard doesnt run all the tests after a failing test (to speed up the Red-Green-Refactor cycle). . . . watch(%r{^app/controllers/(.+)_(controller)\.rb$}) do |m| ["spec/routing/#{m[1]}_routing_spec.rb", "spec/#{m[2]}s/#{m[1]}_#{m[2]}_spec.rb", "spec/acceptance/#{m[1]}_spec.rb", (m[1][/_pages/] ? "spec/requests/#{m[1]}_spec.rb" : "spec/requests/#{m[1].singularize}_pages_spec.rb")] end watch(%r{^app/views/(.+)/}) do |m| (m[1][/_pages/] ? "spec/requests/#{m[1]}_spec.rb" : "spec/requests/#{m[1].singularize}_pages_spec.rb") end . . . end
5) Start guard
$ bundle exec guard
NOTE:
To clear the screen everytime guard runs, add -c parameter. Ex: guard -c
If you get a Guard error complaining about the absence of a spec/routing directory, you can fix it by creating an empty one: $ mkdir spec/routing