Sha256: d61a9831c1958851594c11dc110cdff4a8c4bc6f9505a645cc6c3964de4dbfbe
Contents?: true
Size: 1.73 KB
Versions: 3
Compression:
Stored size: 1.73 KB
Contents
module Actions module Pulp module Consumer class AbstractContentAction < Pulp::AbstractAsyncTask include Helpers::Presenter include Actions::Pulp::ExpectOneTask def external_task=(external_task_data) super(external_task_data) task_errors = find_errors(output[:pulp_tasks]) if task_errors.any? fail ::Katello::Errors::PulpError, task_errors.join("\n") end end def process_timeout accept_timeout = Setting['content_action_accept_timeout'] finish_timeout = Setting['content_action_finish_timeout'] pulp_state = output[:pulp_tasks][0][:state] if pulp_state == 'waiting' fail _("Host did not respond within %s seconds. Is katello-agent installed and goferd running on the Host?") % accept_timeout elsif output[:client_accepted].nil? output[:client_accepted] = Time.now.to_s schedule_timeout(finish_timeout) elsif pulp_state == 'running' fail _("Host did not finish content action in %s seconds") % finish_timeout end end def find_errors(tasks) messages = [] tasks.each do |pulp_task| if pulp_task[:result] && pulp_task[:result][:details] pulp_task[:result][:details].each do |_content_type, result| unless result[:succeeded] messages << result[:details][:message] end end end end messages end def presenter Consumer::ContentPresenter.new(self) end def rescue_strategy Dynflow::Action::Rescue::Skip end end end end end
Version data entries
3 entries across 3 versions & 1 rubygems