cloudfoundry/cloud_controller_ng

View on GitHub
lib/cloud_controller/diego/task_completion_handler.rb

Summary

Maintainability
A
35 mins
Test Coverage
module VCAP::CloudController
  module Diego
    class TaskCompletionHandler
      def complete_task(task, payload)
        begin
          response_parser.validate(payload)
        rescue Membrane::SchemaValidationError => e
          logger.error('failure.invalid-message', task_guid: task.guid, payload: payload, error: e.to_s)
          payload = { failed: true, failure_reason: 'Malformed task response from Diego' }
        end

        task.class.db.transaction do
          task.lock!

          if payload[:failed]
            task.state = TaskModel::FAILED_STATE
            task.failure_reason = payload[:failure_reason]
          else
            task.state = TaskModel::SUCCEEDED_STATE
          end

          task.save_changes(raise_on_save_failure: true)
        end
      rescue StandardError => e
        logger.error('diego.tasks.saving-failed', task_guid: task.guid, payload: payload, error: e.message)
      end

      private

      def app_usage_event_repository
        Repositories::AppUsageEventRepository.new
      end

      def logger
        Steno.logger('cc.tasks')
      end

      def response_parser
        Membrane::SchemaParser.parse do
          {
            failed: bool,
            failure_reason: String
          }
        end
      end
    end
  end
end