Sha256: fa5fc6299095535085235048b47da9283fb677037c0e8342c1c6b60f7e094a27
Contents?: true
Size: 1.29 KB
Versions: 24
Compression:
Stored size: 1.29 KB
Contents
# frozen_string_literal: true require 'spec_helper' require 'open3' def wait_for_container(app_name) start_time = Time.now until `docker-compose ps -q --filter health=healthy #{app_name}`.strip != '' elapsed = Time.now - start_time raise "Timeout waiting for container #{app_name} to be ready" if elapsed > 10 $stderr.write '.' if elapsed > 3 sleep 0.25 end end def run_cmd(*cmd, &failed) out, status = Open3.capture2e(*cmd) return [ out, status ] if status.success? warn <<~WARNING Command failed: #{cmd} <<< Output: #{out} >>> End of output WARNING failed&.call raise 'Command failed' end shared_context 'Rails app pg database' do |fixture_dir| define_method(:fixture_dir) { fixture_dir } before(:all) do print_pg_logs = lambda do logs, = run_cmd 'docker-compose logs pg' puts "docker-compose logs for pg:" puts puts logs end Dir.chdir fixture_dir do run_cmd 'docker-compose down -v' cmd = 'docker-compose up -d pg' run_cmd cmd wait_for_container 'pg' cmd = 'docker-compose run --rm app ./create_app' run_cmd cmd, &print_pg_logs end end after(:all) do if ENV['NOKILL'] != 'true' cmd = 'docker-compose down -v' run_cmd cmd, chdir: fixture_dir end end end
Version data entries
24 entries across 24 versions & 1 rubygems