diff --git a/Capfile b/Capfile index 9c8794c8..2f2f2932 100644 --- a/Capfile +++ b/Capfile @@ -12,7 +12,6 @@ install_plugin Capistrano::SCM::Git # # For documentation on these, see for example: # -# https://github.com/capistrano/rvm # https://github.com/capistrano/rbenv # https://github.com/capistrano/chruby # https://github.com/capistrano/bundler @@ -21,7 +20,6 @@ install_plugin Capistrano::SCM::Git # require 'capistrano/rails' -require 'capistrano/rvm' require 'capistrano/passenger' require 'capistrano/cul' diff --git a/Gemfile b/Gemfile index 72cfbf46..5771a629 100644 --- a/Gemfile +++ b/Gemfile @@ -63,8 +63,7 @@ group :development, :test do gem 'capistrano-cul', require: false gem 'capistrano-passenger', '~> 0.2', require: false gem 'capistrano-rails', '~> 1.4', require: false - gem 'capistrano-resque', '~> 0.2.2', require: false - gem 'capistrano-rvm', '~> 0.1', require: false + gem 'capistrano-resque', '~> 0.2.1', require: false gem 'rubocul', '~> 4.0', require: false diff --git a/Gemfile.lock b/Gemfile.lock index ecbea91a..76346ac9 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -154,9 +154,6 @@ GEM capistrano resque resque-scheduler - capistrano-rvm (0.1.2) - capistrano (~> 3.0) - sshkit (~> 1.2) capybara (3.39.2) addressable matrix @@ -664,8 +661,7 @@ DEPENDENCIES capistrano-cul capistrano-passenger (~> 0.2) capistrano-rails (~> 1.4) - capistrano-resque (~> 0.2.2) - capistrano-rvm (~> 0.1) + capistrano-resque (~> 0.2.1) capybara (~> 3.39) cul-ldap cul_omniauth (>= 0.7.0) diff --git a/config/deploy.rb b/config/deploy.rb index 0cfa9075..c24da9bd 100644 --- a/config/deploy.rb +++ b/config/deploy.rb @@ -21,9 +21,6 @@ # Default value for :format is :airbrussh # set :format, :airbrussh -# Default value for :log_level is :debug -set :log_level, :info - # Default value for linked_dirs is [] set :linked_dirs, fetch(:linked_dirs, []).push('log','tmp/pids', 'storage', 'public/feature-logos', 'node_modules', 'public/packs') @@ -42,6 +39,28 @@ 'public/robots.txt', ) +# Default value for :log_level is :debug +set :log_level, :info + +# NVM Setup, for selecting the correct node version +# NOTE: This NVM configuration MUST be configured before the RVM setup steps because: +# This works: +# nvm exec 16 ~/.rvm-alma8/bin/rvm example_app_dev do node --version +# But this does not work: +# ~/.rvm-alma8/bin/rvm example_app_dev do nvm exec 16 node --version +set :nvm_node_version, fetch(:deploy_name) # This NVM alias must exist on the server +[:rake, :node, :npm, :yarn].each do |command_to_prefix| + SSHKit.config.command_map.prefix[command_to_prefix].push("nvm exec #{fetch(:nvm_node_version)}") +end + +# RVM Setup, for selecting the correct ruby version (instead of capistrano-rvm gem) +set :rvm_ruby_version, fetch(:deploy_name) # This RVM alias must exist on the server +[:rake, :gem, :bundle, :ruby].each do |command_to_prefix| + SSHKit.config.command_map.prefix[command_to_prefix].push( + "#{fetch(:rvm_custom_path, '~/.rvm')}/bin/rvm #{fetch(:rvm_ruby_version)} do" + ) +end + set :ssh_options, { forward_agent: true } # Namespace crontab based on app environment.