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

Version Path
appmap-0.51.3 spec/rails_spec_helper.rb
appmap-0.51.2 spec/rails_spec_helper.rb
appmap-0.51.1 spec/rails_spec_helper.rb
appmap-0.51.0 spec/rails_spec_helper.rb
appmap-0.50.0 spec/rails_spec_helper.rb
appmap-0.49.0 spec/rails_spec_helper.rb
appmap-0.48.2 spec/rails_spec_helper.rb
appmap-0.48.1 spec/rails_spec_helper.rb
appmap-0.48.0 spec/rails_spec_helper.rb
appmap-0.47.1 spec/rails_spec_helper.rb
appmap-0.47.0 spec/rails_spec_helper.rb
appmap-0.46.0 spec/rails_spec_helper.rb
appmap-0.45.1 spec/rails_spec_helper.rb
appmap-0.45.0 spec/rails_spec_helper.rb
appmap-0.44.0 spec/rails_spec_helper.rb
appmap-0.43.0 spec/rails_spec_helper.rb
appmap-0.42.1 spec/rails_spec_helper.rb
appmap-0.42.0 spec/rails_spec_helper.rb
appmap-0.41.2 spec/rails_spec_helper.rb
appmap-0.41.1 spec/rails_spec_helper.rb