Newer
Older
namespace :app do
desc 'Start server'
task :start do
sh 'yarn'
sh 'rails tmp:cache:clear'
sh 'rails server'
end
desc 'Fix things'
task fix: :environment do
Communication::Block.where(template: 'partners').find_each do |partner|
next if partner.data.nil?
data = partner.data
next unless data.has_key? 'elements'
elements = data['elements']
next if elements.none?
first = elements.first
next unless first.has_key? 'partners'
partner.title = first['title']
partner.data['elements'] = first['partners']
partner.save
namespace :db do
desc 'Get database from Scalingo'
task :staging do
# Get a new backup archive from Scalingo
# PG Addon ID from `scalingo addons` CLI command.
sh "scalingo --app #{ENV['OSUNY_STAGING_APP_NAME']} backups-create --addon #{ENV['OSUNY_STAGING_PG_ADDON_ID']}"
sh "scalingo --app #{ENV['OSUNY_STAGING_APP_NAME']} backups-download --addon #{ENV['OSUNY_STAGING_PG_ADDON_ID']} --output db/scalingo-dump.tar.gz"
sh 'rm -f db/latest.dump' # Remove an old backup file if it exists
sh 'tar zxvf db/scalingo-dump.tar.gz -C db/' # Extract the new backup archive
sh 'rm db/scalingo-dump.tar.gz' # Remove the backup archive
sh 'mv db/*.pgsql db/latest.dump' # Rename the backup file
sh 'DISABLE_DATABASE_ENVIRONMENT_CHECK=1 bundle exec rails db:drop'
sh 'bundle exec rails db:create'
begin
sh 'pg_restore --verbose --clean --no-acl --no-owner -h localhost -U postgres -d osuny_development db/latest.dump'
rescue
'There were some warnings or errors while restoring'
end
sh 'rails db:migrate'
sh 'rails db:seed'
end