class OpsTasks::Deployment

Public Class Methods

new(args) click to toggle source
# File lib/ops_tasks/deployment.rb, line 7
def initialize(args)
  @client = AWS::OpsWorks::Client.new
  @layer_id = args[:layer_id]
  @recipe = args[:recipe]
  @stack_id = args[:stack_id]
  @app_id = args[:app_id]
  @slack_channel = args[:room]
  @project = args[:project]
  @run_in_background = args[:background]
end

Public Instance Methods

announce_log(id) click to toggle source
# File lib/ops_tasks/deployment.rb, line 107
def announce_log(id)
  return "" if log_url(id).empty?
  "Chef".
    says("log: #{URI.encode(log_url(id))}").
    to_channel(@slack_channel)
  # puts log_url(id)
end
announce_status(task, deployment_id) click to toggle source

def status(deployment_id)

@client.describe_deployments(:deployment_ids => [deployment_id])[:deployments].first[:status]

end

# File lib/ops_tasks/deployment.rb, line 91
def announce_status(task, deployment_id)
  return false if notifications_disabled?
  status = assess_status(deployment_id)
  "Chef".says("#{@project} #{task} <#{log_url(deployment_id)}|#{status}>").to_channel(@slack_channel)
end
assess_status(deployment_id) click to toggle source
# File lib/ops_tasks/deployment.rb, line 97
def assess_status(deployment_id)
  @client.describe_deployments(
    :deployment_ids => [deployment_id]
  )[:deployments].first[:status]
end
configure() click to toggle source
# File lib/ops_tasks/deployment.rb, line 50
def configure
  print "#{@project}: Preparing configuration... "
  id = @client.create_deployment(
    :stack_id => @stack_id,
    :instance_ids => instance_ids,
    :command => {
      name: "configure"
    }
  )[:deployment_id]
  puts "successful"
  return id
end
deploy() click to toggle source
# File lib/ops_tasks/deployment.rb, line 24
def deploy
  print "#{@project}: Preparing deployment... "
  id = @client.create_deployment(
    :stack_id => @stack_id,
    :app_id =>  @app_id,
    :command => {
      name: "deploy"
    }
  )[:deployment_id]
  puts "successful"
  return id
end
deployment_failed?(id) click to toggle source
# File lib/ops_tasks/deployment.rb, line 103
def deployment_failed?(id)
  assess_status(id) == 'failed'
end
instance_ids() click to toggle source
# File lib/ops_tasks/deployment.rb, line 18
def instance_ids
  client = AWS::OpsWorks::Client.new
  instance_objects = client.describe_instances(:layer_id => @layer_id)
  return instance_objects.instances.map{|i| i.instance_id}.to_a
end
log_url(deployment_id) click to toggle source
# File lib/ops_tasks/deployment.rb, line 75
def log_url(deployment_id)
  deploy = @client.describe_commands(
    :deployment_id => deployment_id
  )[:commands].first
  ShortURL.shorten(deploy[:log_url]).to_s rescue "https://console.aws.com"
end
notifications_disabled?() click to toggle source
# File lib/ops_tasks/deployment.rb, line 83
def notifications_disabled?
  ENV["#{@project}_room_notifications"] == 'false'
end
poll_api_for_status(deployment_id, running_status = 'running') click to toggle source
# File lib/ops_tasks/deployment.rb, line 115
def poll_api_for_status(deployment_id, running_status = 'running')
  sleep 1 until assess_status(deployment_id) != running_status
  astatus = assess_status(deployment_id)
  puts "#{astatus}"
  `open #{log_url(deployment_id)}` if astatus == 'failed'
end
setup() click to toggle source
# File lib/ops_tasks/deployment.rb, line 37
def setup
  print "#{@project}: Preparing setup... "
  id = @client.create_deployment(
    :stack_id => @stack_id,
    :instance_ids => instance_ids,
    :command => {
      name: "setup"
    }
  )[:deployment_id]
  puts "successful"
  return id
end
update_cookbooks() click to toggle source
# File lib/ops_tasks/deployment.rb, line 63
def update_cookbooks
  print "#{@project}: Preparing cookbook update... "

  id = @client.create_deployment(
    :stack_id => @stack_id,
    :instance_ids => instance_ids,
    :command => {name: 'update_custom_cookbooks'}
  )[:deployment_id]
  puts "successful"
  return id
end
wait_for_completion(deployment_id, task="deployment") click to toggle source
# File lib/ops_tasks/deployment.rb, line 122
def wait_for_completion(deployment_id, task="deployment")
  print "#{@project}: Running... "
  announce_status(task, deployment_id)
  poll_api_for_status(deployment_id)
  announce_status(task, deployment_id)
  # Process.daemon if @run_in_background
end