summaryrefslogtreecommitdiffstats
path: root/azure/aria/aria-extension-cloudify/src/aria/tests/orchestrator/context/__init__.py
blob: 780db074f26b8667ce1d232f4b68d04159eae524 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements.  See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You 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.

import sys

from aria.orchestrator.workflows.core import engine, graph_compiler


def op_path(func, module_path=None):
    module_path = module_path or sys.modules[__name__].__name__
    return '{0}.{1}'.format(module_path, func.__name__)


def execute(workflow_func, workflow_context, executor):
    graph = workflow_func(ctx=workflow_context)

    graph_compiler.GraphCompiler(workflow_context, executor.__class__).compile(graph)
    eng = engine.Engine(executors={executor.__class__: executor})

    eng.execute(workflow_context)