guardfile work

This commit is contained in:
Mark Moser 2016-09-01 14:49:13 -05:00
parent 6639f1c6e7
commit 3f8d089701
3 changed files with 54 additions and 33 deletions

View File

@ -16,47 +16,68 @@
# and, you'll have to watch "config/Guardfile" instead of "Guardfile" # and, you'll have to watch "config/Guardfile" instead of "Guardfile"
guard 'livereload' do guard 'livereload' do
watch(%r{app/assets/.+\.(scss|css|js|erb)}) extensions = {
watch(%r{app/views/.+\.(erb|haml|slim)$}) css: :css,
watch(%r{app/controllers/.+\.rb}) scss: :css,
watch(%r{app/helpers/.+\.rb}) sass: :css,
watch(%r{public/.+\.(css|js|html)}) js: :js,
watch(%r{config/locales/.+\.yml}) coffee: :js,
html: :html,
png: :png,
gif: :gif,
jpg: :jpg,
jpeg: :jpeg,
# less: :less, # uncomment if you want LESS stylesheets done in browser
}
# Rails Assets Pipeline rails_view_exts = %w(erb haml slim)
watch(%r{(app|vendor)(/assets/\w+/(.+\.(scss|css|js|erb|html|png|jpg))).*}) do |m|
"/assets/#{m[3]}" # file types LiveReload may optimize refresh for
compiled_exts = extensions.values.uniq
watch(%r{public/.+\.(#{compiled_exts * '|'})})
extensions.each do |ext, type|
watch(%r{
(?:app|vendor)
(?:/assets/\w+/(?<path>[^.]+) # path+base without extension
(?<ext>\.#{ext})) # matching extension (must be first encountered)
(?:\.\w+|$) # other extensions
}x) do |m|
path = m[1]
"/assets/#{path}.#{type}"
end
end end
# file needing a full reload of the page anyway
watch(%r{app/views/.+\.(#{rails_view_exts * '|'})$})
watch(%r{app/(helpers|controllers)/.+\.rb})
watch(%r{config/locales/.+\.yml})
end end
guard :minitest, spring: true, all_after_pass: true do guard :minitest, spring: "bin/rails test" do # all_after_pass: true
watch(%r{^app/(.+)\.rb$}) { |m| "test/#{m[1]}_test.rb" }
watch(%r{^app/controllers/(admin|application)_controller\.rb$}) { 'test/controllers' }
watch(%r{^app/controllers/(.+)_controller\.rb$}) { |m| "test/integration/#{m[1]}_test.rb" }
watch(%r{^app/views/(.+)_mailer/.+}) { |m| "test/mailers/#{m[1]}_mailer_test.rb" }
watch(%r{^lib/(.+)\.rb$}) { |m| "test/lib/#{m[1]}_test.rb" }
watch(%r{^test/test_helper\.rb$}) { 'test' } watch(%r{^test/test_helper\.rb$}) { 'test' }
watch(%r{^test/(.*)\/?(.*)_test\.rb$}) watch(%r{^test/.+_test\.rb$})
# run tests when touching files matching: /app/**/*.rb
watch(%r{^app/(.*/)?([^/]+)\.rb$}) { |m| ["test/#{m[1]}#{m[2]}_test.rb", "test/#{m[1]}#{m[2]}"] }
# run tests when touching files matching: /lib/**/*.rb
watch(%r{^lib/(.*/)?([^/]+)\.rb$}) { |m| ["test/lib/#{m[1]}#{m[2]}_test.rb", "test/lib/#{m[1]}#{m[2]}"] }
# run controller/integration test when touching erb files # run controller/integration test when touching erb files
watch(%r{^app/views/((?!_mailer).)*([^/]+)\.erb$}) { ["test/controllers", "test/integration"] } watch(%r{^app/views/((?!_mailer).)*([^/]+)\.erb$}) { ["test/controllers", "test/integration"] }
# run mailers/integration test when touching mailer erb files # run mailers/integration test when touching mailer erb files
watch(%r{^app/views/(.*_mailer/)?([^/]+)\.erb$}) { ["test/mailers", "test/integration"] } watch(%r{^app/views/(.*_mailer/)?([^/]+)\.erb$}) { ["test/mailers", "test/integration"] }
end end
# ESLint
guard :shell, all_on_start: true do
watch %r{app/assets/javascripts/*/.*} do |file|
system %(echo "ESLinting \033[32m#{file[0]}\033[0m")
system %(eslint #{file[0]})
end
end
guard :rubocop do guard :rubocop do
watch(/.+\.rb$/) watch(/.+\.rb$/)
watch(/Rakefile/) watch(/Rakefile/)
watch(%r{(?:.+/)?\.rubocop\.yml$}) { |m| File.dirname(m[0]) } watch(%r{(?:.+/)?\.rubocop\.yml$}) { |m| File.dirname(m[0]) }
end end
# This breaks in the container.
# instead, try using: https://github.com/appfolio/eslint-rails
# # ESLint
# guard :shell, all_on_start: true do
# watch %r{app/assets/javascripts/*/.*} do |file|
# `eslint #{file[0]}`
# end
# end

View File

@ -9,18 +9,18 @@ if [ -d '/usr/app' ]; then
echo "edit and update proper values" echo "edit and update proper values"
echo '' echo ''
else else
if [ ! -f '~/.container-setup' ]; then if [ ! -f '/root/.container-setup' ]; then
bundle bundle
npm install npm install
bower install --allow-root bower install --allow-root
rails db:setup rails db:setup
rails db:migrate rails db:migrate
rails db:fixtures:load rails db:fixtures:load
touch ~/.container-setup touch /root/.container-setup
fi fi
tmux new-session -d -s 'rails-dev' 'rails s -b 0.0.0.0' tmux new-session -d -s 'rails-dev' 'rails s -b 0.0.0.0'
tmux split-window -p 15 -v tmux split-window -p 15 -v
tmux split-window -p 85 -v 'bundle exec guard' tmux split-window -p 85 -v 'bundle exec guard start --wait-for-delay 1.5'
tmux attach -t rails-dev tmux attach -t rails-dev
fi fi
else else

View File

@ -9,14 +9,14 @@ if [ -d '/usr/app' ]; then
echo "edit and update proper values" echo "edit and update proper values"
echo '' echo ''
else else
if [ ! -f '~/.container-setup' ]; then if [ ! -f '/root/.container-setup' ]; then
bundle bundle
npm install npm install
bower install --allow-root bower install --allow-root
rails db:setup rails db:setup
rails db:migrate rails db:migrate
rails db:fixtures:load rails db:fixtures:load
touch ~/.container-setup touch /root/.container-setup
fi fi
echo 'Delete ~/.container-setup and re-run startup script to update app.' echo 'Delete ~/.container-setup and re-run startup script to update app.'
rails s -b 0.0.0.0 rails s -b 0.0.0.0