Sha256: b20f45075c923f48fa69a083e401bd1a1400e1431c89bac2ee16a62ae53042ab

Contents?: true

Size: 1.26 KB

Versions: 5

Compression:

Stored size: 1.26 KB

Contents

require "log4r"

module VagrantPlugins
  module ManagedServers
    module Action
      class TrackDeploymentEnd
        def initialize(app, _env)
          @app    = app
          @logger = Log4r::Logger.new("vagrant_managed_servers::action::track_deployment_end")
        end

        def call(env)
          track_deployment_end(env[:tracker_host], env[:start_time], env[:success], env[:ui])
          @app.call(env)
        end

        def track_deployment_end(host, start, success, ui)
          return unless host
          @logger.debug("Tracking deployment end to #{host}.")
          id = VagrantPlugins::Orchestrate::DEPLOYMENT_ID
          result = success ? "success" : "failure"
          elapsed_seconds = (Time.now - start).to_i
          deployment = { deployment_id: id,
                         result: result,
                         assert_empty_server_result: true,
                         elapsed_seconds: elapsed_seconds }
          DeploymentTrackerClient::DefaultApi.put_deployment(id, deployment)
        rescue => ex
          ui.warn("There was an error notifying deployment tracker. See error log for details.")
          @logger.warn("Error tracking deployment end for deployment #{id}")
          @logger.warn(ex)
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
vagrant-orchestrate-0.7.0.pre.5 lib/vagrant-managed-servers/action/track_deployment_end.rb
vagrant-orchestrate-0.7.0.pre.3 lib/vagrant-managed-servers/action/track_deployment_end.rb
vagrant-orchestrate-0.7.0.pre.2 lib/vagrant-managed-servers/action/track_deployment_end.rb
vagrant-orchestrate-0.7.0.pre.1 lib/vagrant-managed-servers/action/track_deployment_end.rb
vagrant-orchestrate-0.7.0.pre lib/vagrant-managed-servers/action/track_deployment_end.rb