Sha256: 924fd2f13048cee5437166497623be17d72842de81c2ce80014479a56fdc3d6d

Contents?: true

Size: 1.77 KB

Versions: 2

Compression:

Stored size: 1.77 KB

Contents

# frozen_string_literal: true

module Dynflow
  module Action::WithPollingSubPlans
    REFRESH_INTERVAL = 10
    Poll = Algebrick.atom

    def run(event = nil)
      case event
      when Poll
        poll
      else
        super(event)
      end
    end

    def poll
      recalculate_counts
      try_to_finish || suspend_and_ping
    end

    def initiate
      ping
      super
    end

    def wait_for_sub_plans(sub_plans)
      increase_counts(sub_plans.count, 0)
      suspend
    end

    def resume
      if sub_plans.all? { |sub_plan| sub_plan.error_in_plan? }
        output[:resumed_count] ||= 0
        output[:resumed_count] += output[:failed_count]
        # We're starting over and need to reset the counts
        %w(total failed pending success).each { |key| output.delete("#{key}_count".to_sym) }
        initiate
      else
        if self.is_a?(::Dynflow::Action::WithBulkSubPlans) && can_spawn_next_batch?
          # Not everything was spawned
          ping
          spawn_plans
          suspend
        else
          poll
        end
      end
    end

    def notify_on_finish(_sub_plans)
      suspend
    end

    def suspend_and_ping
      ping
      suspend
    end

    def ping(_suspended_action = nil)
      plan_event(Poll, REFRESH_INTERVAL)
    end

    def recalculate_counts
      total      = sub_plans_count
      failed     = sub_plans_count('state' => %w(paused stopped), 'result' => 'error')
      success    = sub_plans_count('state' => 'stopped', 'result' => 'success')
      output.update(:total_count   => total - output.fetch(:resumed_count, 0),
                    :pending_count => total - failed - success,
                    :failed_count  => failed - output.fetch(:resumed_count, 0),
                    :success_count => success)
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
dynflow-1.9.0 lib/dynflow/action/with_polling_sub_plans.rb
dynflow-1.8.3 lib/dynflow/action/with_polling_sub_plans.rb