Sha256: 4b251b4d2595d85a52ebfe652064f868933538c589b1f04bdcde82076c6459af

Contents?: true

Size: 1.87 KB

Versions: 4

Compression:

Stored size: 1.87 KB

Contents

module Kuroko2
  module Workflow
    module Task
      class Fork < Base
        def execute
          if fork_children_ids.empty?
            message = "(token #{token.uuid}) Start to fork."

            token.job_instance.logs.info(message)
            Kuroko2.logger.info(message)
            extract_child_nodes

            :pass
          elsif token.children.where(id: fork_children_ids).all?(&:finished?)
            message = "(token #{token.uuid}) All children are finished."

            token.job_instance.logs.info(message)
            Kuroko2.logger.info(message)

            :next_sibling
          else
            :pass
          end
        end

        def validate
          if node.children.empty?
            raise Workflow::AssertionError, "#{self.class} must have children node"
          end
        end

        private

        def fork_children_ids
          token.context['fork_children_ids'] ||= {}
          token.context['fork_children_ids'][token.path] ||= []
        end

        def extract_child_nodes
          node.children.each do |child|
            create_child_token(child_node: child)
          end
        end

        def create_child_token(child_node:, env: {})
          attributes = token.attributes.except('id', 'uuid', 'script', 'path', 'message', 'created_at', 'updated_at', 'context')
          attributes = attributes.merge(uuid: SecureRandom.uuid, parent: token, script: child_node.to_script, path: '/', context: token.context.deep_dup)
          attributes[:context]['ENV'] = (attributes[:context]['ENV'] || {}).merge(env)

          Token.create!(attributes).tap do |created|
            fork_children_ids << created.id
            message = "(token #{created.uuid}) New token are created for #{child_node.path}"
            created.job_instance.logs.info(message)
            Kuroko2.logger.info(message)
          end
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
kuroko2-0.8.0 lib/autoload/kuroko2/workflow/task/fork.rb
kuroko2-0.7.0 lib/autoload/kuroko2/workflow/task/fork.rb
kuroko2-0.6.0 lib/autoload/kuroko2/workflow/task/fork.rb
kuroko2-0.5.2 lib/autoload/kuroko2/workflow/task/fork.rb