Module: workflow_phase
Expand source code
# Copyright (C) 2023-present The Project Contributors
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from dataclasses import dataclass
from typing import List
from typing import final
from cl.runtime.records.record_mixin import RecordMixin
from cl.runtime.workflows.workflow_phase_key import WorkflowPhaseKey
@final
@dataclass(slots=True, kw_only=True)
class WorkflowPhase(WorkflowPhaseKey, RecordMixin[WorkflowPhaseKey]):
"""
Determines the order of task execution within the workflow.
Notes:
- Each task is assigned a single phase
- Tasks run in parallel within each phase, in the order of phases
- Running tasks can create new tasks assigned to the same phase or subsequent phases
- Workflow will wait until all prerequisite phases are completed before running tasks in this phase
"""
prerequisites: List[WorkflowPhaseKey] | None = None
"""Workflow will wait until all prerequisite phases are completed before running tasks in this phase."""
def get_key(self) -> WorkflowPhaseKey:
return WorkflowPhaseKey(phase_id=self.phase_id)
Classes
class WorkflowPhase (*, phase_id: str = None, prerequisites: Optional[List[WorkflowPhaseKey]] = None)
-
Determines the order of task execution within the workflow.
Notes
- Each task is assigned a single phase
- Tasks run in parallel within each phase, in the order of phases
- Running tasks can create new tasks assigned to the same phase or subsequent phases
- Workflow will wait until all prerequisite phases are completed before running tasks in this phase
Expand source code
@final @dataclass(slots=True, kw_only=True) class WorkflowPhase(WorkflowPhaseKey, RecordMixin[WorkflowPhaseKey]): """ Determines the order of task execution within the workflow. Notes: - Each task is assigned a single phase - Tasks run in parallel within each phase, in the order of phases - Running tasks can create new tasks assigned to the same phase or subsequent phases - Workflow will wait until all prerequisite phases are completed before running tasks in this phase """ prerequisites: List[WorkflowPhaseKey] | None = None """Workflow will wait until all prerequisite phases are completed before running tasks in this phase.""" def get_key(self) -> WorkflowPhaseKey: return WorkflowPhaseKey(phase_id=self.phase_id)
Ancestors
- WorkflowPhaseKey
- KeyMixin
- abc.ABC
- RecordMixin
- typing.Generic
Static methods
def get_key_type() -> Type
-
Inherited from:
WorkflowPhaseKey
.get_key_type
Return key type even when called from a record.
Fields
var phase_id -> str
-
Inherited from:
WorkflowPhaseKey
.phase_id
Unique workflow phase identifier.
var prerequisites -> Optional[List[WorkflowPhaseKey]]
-
Workflow will wait until all prerequisite phases are completed before running tasks in this phase.
Methods
def get_key(self) -> WorkflowPhaseKey
-
Inherited from:
RecordMixin
.get_key
Return a new key object whose fields populated from self, do not return self.
def init_all(self) -> None
-
Inherited from:
RecordMixin
.init_all
Invoke ‘init’ for each class in the order from base to derived, then validate against schema.