Create and run a workflow within a namespace
Allow adding many workflows with the same name. The way this works is by adding the new workflows under another namespace. Notice that: 1. Namespaces are not part of the mistral DSL. 2. When executing a workflow, the namespace passes down to the subworkflow. 3. When searching for the sub-workflow definition - If no workflow was found in the given namespace, than the defualt namespace will be used. 4. The default namespace is an empty string. 5. The namespace property or the workflow execution will be under params Partially-Implements: blueprint create-and-run-workflows-within-a-namespace Change-Id: Id248ec5906a0899d188675d002b45f6249d36d90
This commit is contained in:
parent
6bd95e1fa2
commit
cbee740de5
@ -23,7 +23,7 @@ fi
|
|||||||
echo "Successfully contacted Mistral API"
|
echo "Successfully contacted Mistral API"
|
||||||
|
|
||||||
# Where tempest code lives
|
# Where tempest code lives
|
||||||
TEMPEST_DIR=${TEMPEST_DIR:-/opt/stack/new/tempest}
|
TEMPEST_DIR=${TEMPEST_DIR:-/opt/stack/tempest}
|
||||||
|
|
||||||
# Path to directory with tempest.conf file, otherwise it will
|
# Path to directory with tempest.conf file, otherwise it will
|
||||||
# take relative path from where the run tests command is being executed.
|
# take relative path from where the run tests command is being executed.
|
||||||
@ -31,8 +31,8 @@ export TEMPEST_CONFIG_DIR=${TEMPEST_CONFIG_DIR:-$TEMPEST_DIR/etc/}
|
|||||||
echo "Tempest configuration file directory: $TEMPEST_CONFIG_DIR"
|
echo "Tempest configuration file directory: $TEMPEST_CONFIG_DIR"
|
||||||
|
|
||||||
# Where mistral code and mistralclient code live
|
# Where mistral code and mistralclient code live
|
||||||
MISTRAL_DIR=/opt/stack/new/mistral
|
MISTRAL_DIR=/opt/stack/mistral
|
||||||
MISTRALCLIENT_DIR=/opt/stack/new/python-mistralclient
|
MISTRALCLIENT_DIR=/opt/stack/python-mistralclient
|
||||||
|
|
||||||
# Define PYTHONPATH
|
# Define PYTHONPATH
|
||||||
export PYTHONPATH=$PYTHONPATH:$TEMPEST_DIR
|
export PYTHONPATH=$PYTHONPATH:$TEMPEST_DIR
|
||||||
|
@ -208,6 +208,7 @@ class ExecutionsController(rest.RestController):
|
|||||||
|
|
||||||
result = engine.start_workflow(
|
result = engine.start_workflow(
|
||||||
exec_dict.get('workflow_id', exec_dict.get('workflow_name')),
|
exec_dict.get('workflow_id', exec_dict.get('workflow_name')),
|
||||||
|
exec_dict.get('workflow_namespace', ''),
|
||||||
exec_dict.get('input'),
|
exec_dict.get('input'),
|
||||||
exec_dict.get('description', ''),
|
exec_dict.get('description', ''),
|
||||||
**exec_dict.get('params') or {}
|
**exec_dict.get('params') or {}
|
||||||
|
@ -69,6 +69,7 @@ class Workflow(resource.Resource):
|
|||||||
|
|
||||||
id = wtypes.text
|
id = wtypes.text
|
||||||
name = wtypes.text
|
name = wtypes.text
|
||||||
|
namespace = wtypes.text
|
||||||
input = wtypes.text
|
input = wtypes.text
|
||||||
|
|
||||||
definition = wtypes.text
|
definition = wtypes.text
|
||||||
@ -92,7 +93,8 @@ class Workflow(resource.Resource):
|
|||||||
scope='private',
|
scope='private',
|
||||||
project_id='a7eb669e9819420ea4bd1453e672c0a7',
|
project_id='a7eb669e9819420ea4bd1453e672c0a7',
|
||||||
created_at='1970-01-01T00:00:00.000000',
|
created_at='1970-01-01T00:00:00.000000',
|
||||||
updated_at='1970-01-01T00:00:00.000000')
|
updated_at='1970-01-01T00:00:00.000000',
|
||||||
|
namespace='')
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def _set_input(cls, obj, wf_spec):
|
def _set_input(cls, obj, wf_spec):
|
||||||
@ -214,6 +216,14 @@ class Execution(resource.Resource):
|
|||||||
workflow_name = wtypes.text
|
workflow_name = wtypes.text
|
||||||
"reference to workflow definition"
|
"reference to workflow definition"
|
||||||
|
|
||||||
|
workflow_namespace = wtypes.text
|
||||||
|
("reference to workflow namespace. The workflow namespace is also saved "
|
||||||
|
"under params and passed to all sub-workflow executions. When looking for"
|
||||||
|
" the next sub-workflow to run, The correct workflow will be found by "
|
||||||
|
"name and namespace, where the namespace can be the workflow namespace or"
|
||||||
|
" the default namespace. Workflows in the same namespace will be given "
|
||||||
|
"a higher priority.")
|
||||||
|
|
||||||
workflow_id = wtypes.text
|
workflow_id = wtypes.text
|
||||||
"reference to workflow ID"
|
"reference to workflow ID"
|
||||||
|
|
||||||
@ -246,6 +256,7 @@ class Execution(resource.Resource):
|
|||||||
def sample(cls):
|
def sample(cls):
|
||||||
return cls(id='123e4567-e89b-12d3-a456-426655440000',
|
return cls(id='123e4567-e89b-12d3-a456-426655440000',
|
||||||
workflow_name='flow',
|
workflow_name='flow',
|
||||||
|
workflow_namespace='some_namespace',
|
||||||
workflow_id='123e4567-e89b-12d3-a456-426655441111',
|
workflow_id='123e4567-e89b-12d3-a456-426655441111',
|
||||||
description='this is the first execution.',
|
description='this is the first execution.',
|
||||||
state='SUCCESS',
|
state='SUCCESS',
|
||||||
@ -287,6 +298,7 @@ class Task(resource.Resource):
|
|||||||
type = wtypes.text
|
type = wtypes.text
|
||||||
|
|
||||||
workflow_name = wtypes.text
|
workflow_name = wtypes.text
|
||||||
|
workflow_namespace = wtypes.text
|
||||||
workflow_id = wtypes.text
|
workflow_id = wtypes.text
|
||||||
workflow_execution_id = wtypes.text
|
workflow_execution_id = wtypes.text
|
||||||
|
|
||||||
@ -358,6 +370,7 @@ class ActionExecution(resource.Resource):
|
|||||||
id = wtypes.text
|
id = wtypes.text
|
||||||
|
|
||||||
workflow_name = wtypes.text
|
workflow_name = wtypes.text
|
||||||
|
workflow_namespace = wtypes.text
|
||||||
task_name = wtypes.text
|
task_name = wtypes.text
|
||||||
task_execution_id = wtypes.text
|
task_execution_id = wtypes.text
|
||||||
|
|
||||||
|
@ -76,27 +76,34 @@ class WorkflowsController(rest.RestController, hooks.HookController):
|
|||||||
)
|
)
|
||||||
|
|
||||||
@rest_utils.wrap_wsme_controller_exception
|
@rest_utils.wrap_wsme_controller_exception
|
||||||
@wsme_pecan.wsexpose(resources.Workflow, wtypes.text)
|
@wsme_pecan.wsexpose(resources.Workflow, wtypes.text, wtypes.text)
|
||||||
def get(self, identifier):
|
def get(self, identifier, namespace=''):
|
||||||
"""Return the named workflow.
|
"""Return the named workflow.
|
||||||
|
|
||||||
:param identifier: Name or UUID of the workflow to retrieve.
|
:param identifier: Name or UUID of the workflow to retrieve.
|
||||||
|
:param namespace: Optional. Namespace of the workflow to retrieve.
|
||||||
"""
|
"""
|
||||||
acl.enforce('workflows:get', context.ctx())
|
acl.enforce('workflows:get', context.ctx())
|
||||||
|
|
||||||
LOG.info("Fetch workflow [identifier=%s]", identifier)
|
LOG.info("Fetch workflow [identifier=%s]", identifier)
|
||||||
|
|
||||||
db_model = db_api.get_workflow_definition(identifier)
|
db_model = db_api.get_workflow_definition(
|
||||||
|
identifier,
|
||||||
|
namespace=namespace
|
||||||
|
)
|
||||||
|
|
||||||
return resources.Workflow.from_db_model(db_model)
|
return resources.Workflow.from_db_model(db_model)
|
||||||
|
|
||||||
@rest_utils.wrap_pecan_controller_exception
|
@rest_utils.wrap_pecan_controller_exception
|
||||||
@pecan.expose(content_type="text/plain")
|
@pecan.expose(content_type="text/plain")
|
||||||
def put(self, identifier=None):
|
def put(self, identifier=None, namespace=''):
|
||||||
"""Update one or more workflows.
|
"""Update one or more workflows.
|
||||||
|
|
||||||
:param identifier: Optional. If provided, it's UUID of a workflow.
|
:param identifier: Optional. If provided, it's UUID of a workflow.
|
||||||
Only one workflow can be updated with identifier param.
|
Only one workflow can be updated with identifier param.
|
||||||
|
:param namespace: Optional. If provided int's the namespace of the
|
||||||
|
workflow/workflows. currently namespace cannot be
|
||||||
|
changed.
|
||||||
|
|
||||||
The text is allowed to have definitions of multiple workflows. In this
|
The text is allowed to have definitions of multiple workflows. In this
|
||||||
case they all will be updated.
|
case they all will be updated.
|
||||||
@ -117,7 +124,8 @@ class WorkflowsController(rest.RestController, hooks.HookController):
|
|||||||
db_wfs = workflows.update_workflows(
|
db_wfs = workflows.update_workflows(
|
||||||
definition,
|
definition,
|
||||||
scope=scope,
|
scope=scope,
|
||||||
identifier=identifier
|
identifier=identifier,
|
||||||
|
namespace=namespace
|
||||||
)
|
)
|
||||||
|
|
||||||
workflow_list = [
|
workflow_list = [
|
||||||
@ -129,11 +137,15 @@ class WorkflowsController(rest.RestController, hooks.HookController):
|
|||||||
|
|
||||||
@rest_utils.wrap_pecan_controller_exception
|
@rest_utils.wrap_pecan_controller_exception
|
||||||
@pecan.expose(content_type="text/plain")
|
@pecan.expose(content_type="text/plain")
|
||||||
def post(self):
|
def post(self, namespace=''):
|
||||||
"""Create a new workflow.
|
"""Create a new workflow.
|
||||||
|
|
||||||
NOTE: The text is allowed to have definitions
|
NOTE: The text is allowed to have definitions
|
||||||
of multiple workflows. In this case they all will be created.
|
of multiple workflows. In this case they all will be created.
|
||||||
|
|
||||||
|
:param namespace: Optional. The namespace to create the workflow
|
||||||
|
in. Workflows with the same name can be added to a given
|
||||||
|
project if are in two different namespaces.
|
||||||
"""
|
"""
|
||||||
acl.enforce('workflows:create', context.ctx())
|
acl.enforce('workflows:create', context.ctx())
|
||||||
|
|
||||||
@ -149,7 +161,11 @@ class WorkflowsController(rest.RestController, hooks.HookController):
|
|||||||
|
|
||||||
LOG.info("Create workflow(s) [definition=%s]", definition)
|
LOG.info("Create workflow(s) [definition=%s]", definition)
|
||||||
|
|
||||||
db_wfs = workflows.create_workflows(definition, scope=scope)
|
db_wfs = workflows.create_workflows(
|
||||||
|
definition,
|
||||||
|
scope=scope,
|
||||||
|
namespace=namespace
|
||||||
|
)
|
||||||
|
|
||||||
workflow_list = [
|
workflow_list = [
|
||||||
resources.Workflow.from_db_model(db_wf) for db_wf in db_wfs
|
resources.Workflow.from_db_model(db_wf) for db_wf in db_wfs
|
||||||
@ -158,30 +174,32 @@ class WorkflowsController(rest.RestController, hooks.HookController):
|
|||||||
return resources.Workflows(workflows=workflow_list).to_json()
|
return resources.Workflows(workflows=workflow_list).to_json()
|
||||||
|
|
||||||
@rest_utils.wrap_wsme_controller_exception
|
@rest_utils.wrap_wsme_controller_exception
|
||||||
@wsme_pecan.wsexpose(None, wtypes.text, status_code=204)
|
@wsme_pecan.wsexpose(None, wtypes.text, wtypes.text, status_code=204)
|
||||||
def delete(self, identifier):
|
def delete(self, identifier, namespace=''):
|
||||||
"""Delete a workflow.
|
"""Delete a workflow.
|
||||||
|
|
||||||
:param identifier: Name or ID of workflow to delete.
|
:param identifier: Name or ID of workflow to delete.
|
||||||
|
:param namespace: Optional. Namespace of the workflow to delete.
|
||||||
"""
|
"""
|
||||||
acl.enforce('workflows:delete', context.ctx())
|
acl.enforce('workflows:delete', context.ctx())
|
||||||
|
|
||||||
LOG.info("Delete workflow [identifier=%s]", identifier)
|
LOG.info("Delete workflow [identifier=%s, namespace=%s]",
|
||||||
|
identifier, namespace)
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
db_api.delete_workflow_definition(identifier)
|
db_api.delete_workflow_definition(identifier, namespace)
|
||||||
|
|
||||||
@rest_utils.wrap_wsme_controller_exception
|
@rest_utils.wrap_wsme_controller_exception
|
||||||
@wsme_pecan.wsexpose(resources.Workflows, types.uuid, int,
|
@wsme_pecan.wsexpose(resources.Workflows, types.uuid, int,
|
||||||
types.uniquelist, types.list, types.uniquelist,
|
types.uniquelist, types.list, types.uniquelist,
|
||||||
wtypes.text, wtypes.text, wtypes.text, wtypes.text,
|
wtypes.text, wtypes.text, wtypes.text, wtypes.text,
|
||||||
resources.SCOPE_TYPES, types.uuid, wtypes.text,
|
resources.SCOPE_TYPES, types.uuid, wtypes.text,
|
||||||
wtypes.text, bool)
|
wtypes.text, bool, wtypes.text)
|
||||||
def get_all(self, marker=None, limit=None, sort_keys='created_at',
|
def get_all(self, marker=None, limit=None, sort_keys='created_at',
|
||||||
sort_dirs='asc', fields='', name=None, input=None,
|
sort_dirs='asc', fields='', name=None, input=None,
|
||||||
definition=None, tags=None, scope=None,
|
definition=None, tags=None, scope=None,
|
||||||
project_id=None, created_at=None, updated_at=None,
|
project_id=None, created_at=None, updated_at=None,
|
||||||
all_projects=False):
|
all_projects=False, namespace=None):
|
||||||
"""Return a list of workflows.
|
"""Return a list of workflows.
|
||||||
|
|
||||||
:param marker: Optional. Pagination marker for large data sets.
|
:param marker: Optional. Pagination marker for large data sets.
|
||||||
@ -198,6 +216,8 @@ class WorkflowsController(rest.RestController, hooks.HookController):
|
|||||||
fields if it's provided, since it will be used when
|
fields if it's provided, since it will be used when
|
||||||
constructing 'next' link.
|
constructing 'next' link.
|
||||||
:param name: Optional. Keep only resources with a specific name.
|
:param name: Optional. Keep only resources with a specific name.
|
||||||
|
:param namespace: Optional. Keep only resources with a specific
|
||||||
|
namespace
|
||||||
:param input: Optional. Keep only resources with a specific input.
|
:param input: Optional. Keep only resources with a specific input.
|
||||||
:param definition: Optional. Keep only resources with a specific
|
:param definition: Optional. Keep only resources with a specific
|
||||||
definition.
|
definition.
|
||||||
@ -224,7 +244,8 @@ class WorkflowsController(rest.RestController, hooks.HookController):
|
|||||||
updated_at=updated_at,
|
updated_at=updated_at,
|
||||||
input=input,
|
input=input,
|
||||||
definition=definition,
|
definition=definition,
|
||||||
project_id=project_id
|
project_id=project_id,
|
||||||
|
namespace=namespace
|
||||||
)
|
)
|
||||||
|
|
||||||
LOG.info("Fetch workflows. marker=%s, limit=%s, sort_keys=%s, "
|
LOG.info("Fetch workflows. marker=%s, limit=%s, sort_keys=%s, "
|
||||||
|
@ -0,0 +1,114 @@
|
|||||||
|
# Copyright 2017 OpenStack Foundation.
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
"""namespace_support
|
||||||
|
|
||||||
|
Revision ID: 022
|
||||||
|
Revises: 021
|
||||||
|
Create Date: 2017-06-11 13:09:06.782095
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
# revision identifiers, used by Alembic.
|
||||||
|
revision = '022'
|
||||||
|
down_revision = '021'
|
||||||
|
|
||||||
|
from alembic import op
|
||||||
|
import sqlalchemy as sa
|
||||||
|
from sqlalchemy.sql import table, column
|
||||||
|
|
||||||
|
# A simple model of the workflow definitions table with only the field needed
|
||||||
|
wf_def = table('workflow_definitions_v2', column('namespace'))
|
||||||
|
|
||||||
|
# A simple model of the workflow executions table with only the field needed
|
||||||
|
wf_exec = table('workflow_executions_v2', column('workflow_namespace'))
|
||||||
|
|
||||||
|
# A simple model of the task executions table with only the field needed
|
||||||
|
task_exec = table('task_executions_v2', column('workflow_namespace'))
|
||||||
|
|
||||||
|
# A simple model of the action executions table with only the fields needed
|
||||||
|
action_executions = sa.Table(
|
||||||
|
'action_executions_v2',
|
||||||
|
sa.MetaData(),
|
||||||
|
sa.Column('id', sa.String(36), nullable=False),
|
||||||
|
sa.Column('workflow_name', sa.String(255)),
|
||||||
|
sa.Column('workflow_namespace', sa.String(255), nullable=True)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def upgrade():
|
||||||
|
|
||||||
|
# ### commands auto generated by Alembic - please adjust! ###
|
||||||
|
op.add_column(
|
||||||
|
'workflow_definitions_v2',
|
||||||
|
sa.Column(
|
||||||
|
'namespace',
|
||||||
|
sa.String(length=255),
|
||||||
|
nullable=True
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
op.drop_index('name', table_name='workflow_definitions_v2')
|
||||||
|
op.create_unique_constraint(
|
||||||
|
None,
|
||||||
|
'workflow_definitions_v2',
|
||||||
|
['name', 'namespace', 'project_id']
|
||||||
|
)
|
||||||
|
|
||||||
|
op.add_column(
|
||||||
|
'workflow_executions_v2',
|
||||||
|
sa.Column(
|
||||||
|
'workflow_namespace',
|
||||||
|
sa.String(length=255),
|
||||||
|
nullable=True
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
op.add_column(
|
||||||
|
'task_executions_v2',
|
||||||
|
sa.Column(
|
||||||
|
'workflow_namespace',
|
||||||
|
sa.String(length=255),
|
||||||
|
nullable=True
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
op.add_column(
|
||||||
|
'action_executions_v2',
|
||||||
|
sa.Column('workflow_namespace', sa.String(length=255), nullable=True)
|
||||||
|
)
|
||||||
|
|
||||||
|
session = sa.orm.Session(bind=op.get_bind())
|
||||||
|
values = []
|
||||||
|
|
||||||
|
for row in session.query(action_executions):
|
||||||
|
values.append({'id': row[0],
|
||||||
|
'workflow_name': row[1]})
|
||||||
|
|
||||||
|
with session.begin(subtransactions=True):
|
||||||
|
session.execute(wf_def.update().values(namespace=''))
|
||||||
|
session.execute(wf_exec.update().values(workflow_namespace=''))
|
||||||
|
session.execute(task_exec.update().values(workflow_namespace=''))
|
||||||
|
|
||||||
|
for value in values:
|
||||||
|
if value['workflow_name']:
|
||||||
|
session.execute(action_executions.update().values(
|
||||||
|
workflow_namespace=''
|
||||||
|
).where(action_executions.c.id == value['id']))
|
||||||
|
|
||||||
|
# this commit appears to be necessary
|
||||||
|
session.commit()
|
||||||
|
|
||||||
|
# ### end Alembic commands ###
|
@ -114,17 +114,17 @@ def delete_workbooks(**kwargs):
|
|||||||
|
|
||||||
# Workflow definitions.
|
# Workflow definitions.
|
||||||
|
|
||||||
def get_workflow_definition(identifier):
|
def get_workflow_definition(identifier, namespace=''):
|
||||||
return IMPL.get_workflow_definition(identifier)
|
return IMPL.get_workflow_definition(identifier, namespace=namespace)
|
||||||
|
|
||||||
|
|
||||||
def get_workflow_definition_by_id(id):
|
def get_workflow_definition_by_id(id):
|
||||||
return IMPL.get_workflow_definition_by_id(id)
|
return IMPL.get_workflow_definition_by_id(id)
|
||||||
|
|
||||||
|
|
||||||
def load_workflow_definition(name):
|
def load_workflow_definition(name, namespace=''):
|
||||||
"""Unlike get_workflow_definition this method is allowed to return None."""
|
"""Unlike get_workflow_definition this method is allowed to return None."""
|
||||||
return IMPL.load_workflow_definition(name)
|
return IMPL.load_workflow_definition(name, namespace)
|
||||||
|
|
||||||
|
|
||||||
def get_workflow_definitions(limit=None, marker=None, sort_keys=None,
|
def get_workflow_definitions(limit=None, marker=None, sort_keys=None,
|
||||||
@ -143,16 +143,16 @@ def create_workflow_definition(values):
|
|||||||
return IMPL.create_workflow_definition(values)
|
return IMPL.create_workflow_definition(values)
|
||||||
|
|
||||||
|
|
||||||
def update_workflow_definition(identifier, values):
|
def update_workflow_definition(identifier, values, namespace):
|
||||||
return IMPL.update_workflow_definition(identifier, values)
|
return IMPL.update_workflow_definition(identifier, values, namespace)
|
||||||
|
|
||||||
|
|
||||||
def create_or_update_workflow_definition(name, values):
|
def create_or_update_workflow_definition(name, values):
|
||||||
return IMPL.create_or_update_workflow_definition(name, values)
|
return IMPL.create_or_update_workflow_definition(name, values)
|
||||||
|
|
||||||
|
|
||||||
def delete_workflow_definition(identifier):
|
def delete_workflow_definition(identifier, namespace=''):
|
||||||
IMPL.delete_workflow_definition(identifier)
|
IMPL.delete_workflow_definition(identifier, namespace)
|
||||||
|
|
||||||
|
|
||||||
def delete_workflow_definitions(**kwargs):
|
def delete_workflow_definitions(**kwargs):
|
||||||
|
@ -253,8 +253,36 @@ def _get_collection_sorted_by_time(model, insecure=False, fields=None,
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def _get_db_object_by_name(model, name):
|
def _get_db_object_by_name(model, name, filter_=None, order_by=None):
|
||||||
return _secure_query(model).filter_by(name=name).first()
|
|
||||||
|
query = _secure_query(model)
|
||||||
|
final_filter = model.name == name
|
||||||
|
|
||||||
|
if filter_ is not None:
|
||||||
|
final_filter = sa.and_(final_filter, filter_)
|
||||||
|
|
||||||
|
if order_by is not None:
|
||||||
|
query = query.order_by(order_by)
|
||||||
|
|
||||||
|
return query.filter(final_filter).first()
|
||||||
|
|
||||||
|
|
||||||
|
def _get_wf_object_by_name_and_namespace(model, name, namespace=None):
|
||||||
|
|
||||||
|
query = _secure_query(model)
|
||||||
|
filter_ = model.name == name
|
||||||
|
|
||||||
|
if namespace is not None:
|
||||||
|
in_namespace = sa.or_(
|
||||||
|
model.namespace == namespace,
|
||||||
|
model.namespace == ''
|
||||||
|
)
|
||||||
|
filter_ = sa.and_(filter_, in_namespace)
|
||||||
|
|
||||||
|
# Give priority to objects not in the default namespace.
|
||||||
|
query = query.order_by(model.namespace.desc())
|
||||||
|
|
||||||
|
return query.filter(filter_).first()
|
||||||
|
|
||||||
|
|
||||||
def _get_db_object_by_id(model, id, insecure=False):
|
def _get_db_object_by_id(model, id, insecure=False):
|
||||||
@ -264,11 +292,28 @@ def _get_db_object_by_id(model, id, insecure=False):
|
|||||||
|
|
||||||
|
|
||||||
def _get_db_object_by_name_or_id(model, identifier, insecure=False):
|
def _get_db_object_by_name_or_id(model, identifier, insecure=False):
|
||||||
|
return _get_db_object_by_name_and_namespace_or_id(
|
||||||
|
model,
|
||||||
|
identifier,
|
||||||
|
insecure=insecure
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def _get_db_object_by_name_and_namespace_or_id(model, identifier,
|
||||||
|
namespace=None, insecure=False):
|
||||||
|
|
||||||
query = b.model_query(model) if insecure else _secure_query(model)
|
query = b.model_query(model) if insecure else _secure_query(model)
|
||||||
|
|
||||||
|
match_name = model.name == identifier
|
||||||
|
|
||||||
|
if namespace is not None:
|
||||||
|
match_name = sa.and_(match_name, model.namespace == namespace)
|
||||||
|
|
||||||
|
match_id = model.id == identifier
|
||||||
query = query.filter(
|
query = query.filter(
|
||||||
sa.or_(
|
sa.or_(
|
||||||
model.id == identifier,
|
match_id,
|
||||||
model.name == identifier
|
match_name
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -421,24 +466,27 @@ def delete_workbooks(session=None, **kwargs):
|
|||||||
# Workflow definitions.
|
# Workflow definitions.
|
||||||
|
|
||||||
@b.session_aware()
|
@b.session_aware()
|
||||||
def get_workflow_definition(identifier, session=None):
|
def get_workflow_definition(identifier, namespace='', session=None):
|
||||||
"""Gets workflow definition by name or uuid.
|
"""Gets workflow definition by name or uuid.
|
||||||
|
|
||||||
:param identifier: Identifier could be in the format of plain string or
|
:param identifier: Identifier could be in the format of plain string or
|
||||||
uuid.
|
uuid.
|
||||||
|
:param namespace: The namespace the workflow is in. Optional.
|
||||||
:return: Workflow definition.
|
:return: Workflow definition.
|
||||||
"""
|
"""
|
||||||
ctx = context.ctx()
|
ctx = context.ctx()
|
||||||
|
|
||||||
wf_def = _get_db_object_by_name_or_id(
|
wf_def = _get_db_object_by_name_and_namespace_or_id(
|
||||||
models.WorkflowDefinition,
|
models.WorkflowDefinition,
|
||||||
identifier,
|
identifier,
|
||||||
|
namespace=namespace,
|
||||||
insecure=ctx.is_admin
|
insecure=ctx.is_admin
|
||||||
)
|
)
|
||||||
|
|
||||||
if not wf_def:
|
if not wf_def:
|
||||||
raise exc.DBEntityNotFoundError(
|
raise exc.DBEntityNotFoundError(
|
||||||
"Workflow not found [workflow_identifier=%s]" % identifier
|
"Workflow not found [workflow_identifier=%s, namespace=%s]"
|
||||||
|
% (identifier, namespace)
|
||||||
)
|
)
|
||||||
|
|
||||||
return wf_def
|
return wf_def
|
||||||
@ -457,8 +505,23 @@ def get_workflow_definition_by_id(id, session=None):
|
|||||||
|
|
||||||
|
|
||||||
@b.session_aware()
|
@b.session_aware()
|
||||||
def load_workflow_definition(name, session=None):
|
def load_workflow_definition(name, namespace='', session=None):
|
||||||
return _get_db_object_by_name(models.WorkflowDefinition, name)
|
model = models.WorkflowDefinition
|
||||||
|
|
||||||
|
filter_ = sa.or_(
|
||||||
|
model.namespace == namespace,
|
||||||
|
model.namespace == ''
|
||||||
|
)
|
||||||
|
|
||||||
|
# Give priority to objects not in the default namespace.
|
||||||
|
order_by = model.namespace.desc()
|
||||||
|
|
||||||
|
return _get_db_object_by_name(
|
||||||
|
model,
|
||||||
|
name,
|
||||||
|
filter_,
|
||||||
|
order_by
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
@b.session_aware()
|
@b.session_aware()
|
||||||
@ -493,8 +556,8 @@ def create_workflow_definition(values, session=None):
|
|||||||
|
|
||||||
|
|
||||||
@b.session_aware()
|
@b.session_aware()
|
||||||
def update_workflow_definition(identifier, values, session=None):
|
def update_workflow_definition(identifier, values, namespace='', session=None):
|
||||||
wf_def = get_workflow_definition(identifier)
|
wf_def = get_workflow_definition(identifier, namespace=namespace)
|
||||||
|
|
||||||
m_dbutils.check_db_obj_access(wf_def)
|
m_dbutils.check_db_obj_access(wf_def)
|
||||||
|
|
||||||
@ -537,8 +600,8 @@ def create_or_update_workflow_definition(name, values, session=None):
|
|||||||
|
|
||||||
|
|
||||||
@b.session_aware()
|
@b.session_aware()
|
||||||
def delete_workflow_definition(identifier, session=None):
|
def delete_workflow_definition(identifier, namespace='', session=None):
|
||||||
wf_def = get_workflow_definition(identifier)
|
wf_def = get_workflow_definition(identifier, namespace)
|
||||||
|
|
||||||
m_dbutils.check_db_obj_access(wf_def)
|
m_dbutils.check_db_obj_access(wf_def)
|
||||||
|
|
||||||
|
@ -121,9 +121,13 @@ class WorkflowDefinition(Definition):
|
|||||||
"""Contains info about workflow (including definition in Mistral DSL)."""
|
"""Contains info about workflow (including definition in Mistral DSL)."""
|
||||||
|
|
||||||
__tablename__ = 'workflow_definitions_v2'
|
__tablename__ = 'workflow_definitions_v2'
|
||||||
|
namespace = sa.Column(sa.String(255), nullable=True)
|
||||||
__table_args__ = (
|
__table_args__ = (
|
||||||
sa.UniqueConstraint('name', 'project_id'),
|
sa.UniqueConstraint(
|
||||||
|
'name',
|
||||||
|
'namespace',
|
||||||
|
'project_id'
|
||||||
|
),
|
||||||
sa.Index('%s_is_system' % __tablename__, 'is_system'),
|
sa.Index('%s_is_system' % __tablename__, 'is_system'),
|
||||||
sa.Index('%s_project_id' % __tablename__, 'project_id'),
|
sa.Index('%s_project_id' % __tablename__, 'project_id'),
|
||||||
sa.Index('%s_scope' % __tablename__, 'scope'),
|
sa.Index('%s_scope' % __tablename__, 'scope'),
|
||||||
@ -162,6 +166,7 @@ class Execution(mb.MistralSecureModelBase):
|
|||||||
name = sa.Column(sa.String(255))
|
name = sa.Column(sa.String(255))
|
||||||
description = sa.Column(sa.String(255), nullable=True)
|
description = sa.Column(sa.String(255), nullable=True)
|
||||||
workflow_name = sa.Column(sa.String(255))
|
workflow_name = sa.Column(sa.String(255))
|
||||||
|
workflow_namespace = sa.Column(sa.String(255))
|
||||||
workflow_id = sa.Column(sa.String(80))
|
workflow_id = sa.Column(sa.String(80))
|
||||||
spec = sa.Column(st.JsonMediumDictType())
|
spec = sa.Column(st.JsonMediumDictType())
|
||||||
state = sa.Column(sa.String(20))
|
state = sa.Column(sa.String(20))
|
||||||
|
@ -144,6 +144,7 @@ class Action(object):
|
|||||||
values.update({
|
values.update({
|
||||||
'task_execution_id': self.task_ex.id,
|
'task_execution_id': self.task_ex.id,
|
||||||
'workflow_name': self.task_ex.workflow_name,
|
'workflow_name': self.task_ex.workflow_name,
|
||||||
|
'workflow_namespace': self.task_ex.workflow_namespace,
|
||||||
'workflow_id': self.task_ex.workflow_id,
|
'workflow_id': self.task_ex.workflow_id,
|
||||||
'project_id': self.task_ex.project_id,
|
'project_id': self.task_ex.project_id,
|
||||||
})
|
})
|
||||||
@ -492,7 +493,8 @@ class WorkflowAction(Action):
|
|||||||
wf_def = engine_utils.resolve_workflow_definition(
|
wf_def = engine_utils.resolve_workflow_definition(
|
||||||
parent_wf_ex.workflow_name,
|
parent_wf_ex.workflow_name,
|
||||||
parent_wf_spec.get_name(),
|
parent_wf_spec.get_name(),
|
||||||
wf_spec_name
|
namespace=parent_wf_ex.params['namespace'],
|
||||||
|
wf_spec_name=wf_spec_name
|
||||||
)
|
)
|
||||||
|
|
||||||
wf_spec = spec_parser.get_workflow_spec_by_definition_id(
|
wf_spec = spec_parser.get_workflow_spec_by_definition_id(
|
||||||
@ -502,7 +504,8 @@ class WorkflowAction(Action):
|
|||||||
|
|
||||||
wf_params = {
|
wf_params = {
|
||||||
'task_execution_id': self.task_ex.id,
|
'task_execution_id': self.task_ex.id,
|
||||||
'index': index
|
'index': index,
|
||||||
|
'namespace': parent_wf_ex.params['namespace']
|
||||||
}
|
}
|
||||||
|
|
||||||
if 'env' in parent_wf_ex.params:
|
if 'env' in parent_wf_ex.params:
|
||||||
@ -516,6 +519,7 @@ class WorkflowAction(Action):
|
|||||||
|
|
||||||
wf_handler.start_workflow(
|
wf_handler.start_workflow(
|
||||||
wf_def.id,
|
wf_def.id,
|
||||||
|
wf_def.namespace,
|
||||||
input_dict,
|
input_dict,
|
||||||
"sub-workflow execution",
|
"sub-workflow execution",
|
||||||
wf_params
|
wf_params
|
||||||
|
@ -28,13 +28,14 @@ class Engine(object):
|
|||||||
"""Engine interface."""
|
"""Engine interface."""
|
||||||
|
|
||||||
@abc.abstractmethod
|
@abc.abstractmethod
|
||||||
def start_workflow(self, wf_identifier, wf_input, description='',
|
def start_workflow(self, wf_identifier, wf_namespace='', wf_input=None,
|
||||||
**params):
|
description='', **params):
|
||||||
"""Starts the specified workflow.
|
"""Starts the specified workflow.
|
||||||
|
|
||||||
:param wf_identifier: Workflow ID or name. Workflow ID is recommended,
|
:param wf_identifier: Workflow ID or name. Workflow ID is recommended,
|
||||||
workflow name will be deprecated since Mitaka.
|
workflow name will be deprecated since Mitaka.
|
||||||
:param wf_input: Workflow input data as a dictionary.
|
:param wf_input: Workflow input data as a dictionary.
|
||||||
|
:param wf_namespace: Workflow input data as a dictionary.
|
||||||
:param description: Execution description.
|
:param description: Execution description.
|
||||||
:param params: Additional workflow type specific parameters.
|
:param params: Additional workflow type specific parameters.
|
||||||
:return: Workflow execution object.
|
:return: Workflow execution object.
|
||||||
|
@ -36,12 +36,16 @@ from mistral.workflow import states
|
|||||||
class DefaultEngine(base.Engine):
|
class DefaultEngine(base.Engine):
|
||||||
@action_queue.process
|
@action_queue.process
|
||||||
@profiler.trace('engine-start-workflow', hide_args=True)
|
@profiler.trace('engine-start-workflow', hide_args=True)
|
||||||
def start_workflow(self, wf_identifier, wf_input, description='',
|
def start_workflow(self, wf_identifier, wf_namespace='', wf_input=None,
|
||||||
**params):
|
description='', **params):
|
||||||
|
if wf_namespace:
|
||||||
|
params['namespace'] = wf_namespace
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = wf_handler.start_workflow(
|
wf_ex = wf_handler.start_workflow(
|
||||||
wf_identifier,
|
wf_identifier,
|
||||||
wf_input,
|
wf_namespace,
|
||||||
|
wf_input or {},
|
||||||
description,
|
description,
|
||||||
params
|
params
|
||||||
)
|
)
|
||||||
|
@ -78,12 +78,13 @@ class EngineServer(service_base.MistralService):
|
|||||||
if self._rpc_server:
|
if self._rpc_server:
|
||||||
self._rpc_server.stop(graceful)
|
self._rpc_server.stop(graceful)
|
||||||
|
|
||||||
def start_workflow(self, rpc_ctx, workflow_identifier, workflow_input,
|
def start_workflow(self, rpc_ctx, workflow_identifier, workflow_namespace,
|
||||||
description, params):
|
workflow_input, description, params):
|
||||||
"""Receives calls over RPC to start workflows on engine.
|
"""Receives calls over RPC to start workflows on engine.
|
||||||
|
|
||||||
:param rpc_ctx: RPC request context.
|
:param rpc_ctx: RPC request context.
|
||||||
:param workflow_identifier: Workflow definition identifier.
|
:param workflow_identifier: Workflow definition identifier.
|
||||||
|
:param workflow_namespace: Workflow definition identifier.
|
||||||
:param workflow_input: Workflow input.
|
:param workflow_input: Workflow input.
|
||||||
:param description: Workflow execution description.
|
:param description: Workflow execution description.
|
||||||
:param params: Additional workflow type specific parameters.
|
:param params: Additional workflow type specific parameters.
|
||||||
@ -101,6 +102,7 @@ class EngineServer(service_base.MistralService):
|
|||||||
|
|
||||||
return self.engine.start_workflow(
|
return self.engine.start_workflow(
|
||||||
workflow_identifier,
|
workflow_identifier,
|
||||||
|
workflow_namespace,
|
||||||
workflow_input,
|
workflow_input,
|
||||||
description,
|
description,
|
||||||
**params
|
**params
|
||||||
|
@ -216,6 +216,7 @@ class Task(object):
|
|||||||
'name': task_name,
|
'name': task_name,
|
||||||
'workflow_execution_id': self.wf_ex.id,
|
'workflow_execution_id': self.wf_ex.id,
|
||||||
'workflow_name': self.wf_ex.workflow_name,
|
'workflow_name': self.wf_ex.workflow_name,
|
||||||
|
'workflow_namespace': self.wf_ex.workflow_namespace,
|
||||||
'workflow_id': self.wf_ex.workflow_id,
|
'workflow_id': self.wf_ex.workflow_id,
|
||||||
'state': state,
|
'state': state,
|
||||||
'state_info': state_info,
|
'state_info': state_info,
|
||||||
|
@ -67,7 +67,7 @@ def validate_input(expected_input, actual_input, obj_name, obj_class):
|
|||||||
|
|
||||||
|
|
||||||
def resolve_workflow_definition(parent_wf_name, parent_wf_spec_name,
|
def resolve_workflow_definition(parent_wf_name, parent_wf_spec_name,
|
||||||
wf_spec_name):
|
namespace, wf_spec_name):
|
||||||
wf_def = None
|
wf_def = None
|
||||||
|
|
||||||
if parent_wf_name != parent_wf_spec_name:
|
if parent_wf_name != parent_wf_spec_name:
|
||||||
@ -80,14 +80,15 @@ def resolve_workflow_definition(parent_wf_name, parent_wf_spec_name,
|
|||||||
|
|
||||||
wf_full_name = "%s.%s" % (wb_name, wf_spec_name)
|
wf_full_name = "%s.%s" % (wb_name, wf_spec_name)
|
||||||
|
|
||||||
wf_def = db_api.load_workflow_definition(wf_full_name)
|
wf_def = db_api.load_workflow_definition(wf_full_name, namespace)
|
||||||
|
|
||||||
if not wf_def:
|
if not wf_def:
|
||||||
wf_def = db_api.load_workflow_definition(wf_spec_name)
|
wf_def = db_api.load_workflow_definition(wf_spec_name, namespace)
|
||||||
|
|
||||||
if not wf_def:
|
if not wf_def:
|
||||||
raise exc.WorkflowException(
|
raise exc.WorkflowException(
|
||||||
"Failed to find workflow [name=%s]" % wf_spec_name
|
"Failed to find workflow [name=%s] [namespace=%s]" %
|
||||||
|
(wf_spec_name, namespace)
|
||||||
)
|
)
|
||||||
|
|
||||||
return wf_def
|
return wf_def
|
||||||
|
@ -33,11 +33,16 @@ _CHECK_AND_COMPLETE_PATH = (
|
|||||||
|
|
||||||
|
|
||||||
@profiler.trace('workflow-handler-start-workflow', hide_args=True)
|
@profiler.trace('workflow-handler-start-workflow', hide_args=True)
|
||||||
def start_workflow(wf_identifier, wf_input, desc, params):
|
def start_workflow(wf_identifier, wf_namespace, wf_input, desc, params):
|
||||||
wf = workflows.Workflow()
|
wf = workflows.Workflow()
|
||||||
|
|
||||||
|
wf_def = db_api.get_workflow_definition(wf_identifier, wf_namespace)
|
||||||
|
|
||||||
|
if 'namespace' not in params:
|
||||||
|
params['namespace'] = wf_def.namespace
|
||||||
|
|
||||||
wf.start(
|
wf.start(
|
||||||
wf_def=db_api.get_workflow_definition(wf_identifier),
|
wf_def=wf_def,
|
||||||
input_dict=wf_input,
|
input_dict=wf_input,
|
||||||
desc=desc,
|
desc=desc,
|
||||||
params=params
|
params=params
|
||||||
|
@ -233,6 +233,7 @@ class Workflow(object):
|
|||||||
'name': wf_def.name,
|
'name': wf_def.name,
|
||||||
'description': desc,
|
'description': desc,
|
||||||
'workflow_name': wf_def.name,
|
'workflow_name': wf_def.name,
|
||||||
|
'workflow_namespace': wf_def.namespace,
|
||||||
'workflow_id': wf_def.id,
|
'workflow_id': wf_def.id,
|
||||||
'spec': self.wf_spec.to_dict(),
|
'spec': self.wf_spec.to_dict(),
|
||||||
'state': states.IDLE,
|
'state': states.IDLE,
|
||||||
|
@ -79,8 +79,8 @@ class EngineClient(eng.Engine):
|
|||||||
self._client = base.get_rpc_client_driver()(rpc_conf_dict)
|
self._client = base.get_rpc_client_driver()(rpc_conf_dict)
|
||||||
|
|
||||||
@base.wrap_messaging_exception
|
@base.wrap_messaging_exception
|
||||||
def start_workflow(self, wf_identifier, wf_input, description='',
|
def start_workflow(self, wf_identifier, wf_namespace, wf_input=None,
|
||||||
**params):
|
description='', **params):
|
||||||
"""Starts workflow sending a request to engine over RPC.
|
"""Starts workflow sending a request to engine over RPC.
|
||||||
|
|
||||||
:return: Workflow execution.
|
:return: Workflow execution.
|
||||||
@ -89,6 +89,7 @@ class EngineClient(eng.Engine):
|
|||||||
auth_ctx.ctx(),
|
auth_ctx.ctx(),
|
||||||
'start_workflow',
|
'start_workflow',
|
||||||
workflow_identifier=wf_identifier,
|
workflow_identifier=wf_identifier,
|
||||||
|
workflow_namespace=wf_namespace,
|
||||||
workflow_input=wf_input or {},
|
workflow_input=wf_input or {},
|
||||||
description=description,
|
description=description,
|
||||||
params=params
|
params=params
|
||||||
|
@ -99,6 +99,7 @@ def _create_or_update_workflows(wb_db, workflows_spec):
|
|||||||
'spec': wf_spec.to_dict(),
|
'spec': wf_spec.to_dict(),
|
||||||
'scope': wb_db.scope,
|
'scope': wb_db.scope,
|
||||||
'project_id': wb_db.project_id,
|
'project_id': wb_db.project_id,
|
||||||
|
'namespace': '',
|
||||||
'tags': wf_spec.get_tags()
|
'tags': wf_spec.get_tags()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,7 +36,8 @@ def register_standard_workflows(run_in_tx=True):
|
|||||||
workflow_definition,
|
workflow_definition,
|
||||||
scope='public',
|
scope='public',
|
||||||
is_system=True,
|
is_system=True,
|
||||||
run_in_tx=run_in_tx
|
run_in_tx=run_in_tx,
|
||||||
|
namespace=''
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -52,7 +53,7 @@ def sync_db():
|
|||||||
|
|
||||||
|
|
||||||
def create_workflows(definition, scope='private', is_system=False,
|
def create_workflows(definition, scope='private', is_system=False,
|
||||||
run_in_tx=True):
|
run_in_tx=True, namespace=''):
|
||||||
LOG.debug("creating workflows")
|
LOG.debug("creating workflows")
|
||||||
wf_list_spec = spec_parser.get_workflow_list_spec_from_yaml(definition)
|
wf_list_spec = spec_parser.get_workflow_list_spec_from_yaml(definition)
|
||||||
db_wfs = []
|
db_wfs = []
|
||||||
@ -63,6 +64,7 @@ def create_workflows(definition, scope='private', is_system=False,
|
|||||||
definition,
|
definition,
|
||||||
is_system,
|
is_system,
|
||||||
scope,
|
scope,
|
||||||
|
namespace,
|
||||||
wf_list_spec,
|
wf_list_spec,
|
||||||
db_wfs
|
db_wfs
|
||||||
)
|
)
|
||||||
@ -71,6 +73,7 @@ def create_workflows(definition, scope='private', is_system=False,
|
|||||||
definition,
|
definition,
|
||||||
is_system,
|
is_system,
|
||||||
scope,
|
scope,
|
||||||
|
namespace,
|
||||||
wf_list_spec,
|
wf_list_spec,
|
||||||
db_wfs
|
db_wfs
|
||||||
)
|
)
|
||||||
@ -78,14 +81,22 @@ def create_workflows(definition, scope='private', is_system=False,
|
|||||||
return db_wfs
|
return db_wfs
|
||||||
|
|
||||||
|
|
||||||
def _append_all_workflows(definition, is_system, scope, wf_list_spec, db_wfs):
|
def _append_all_workflows(definition, is_system, scope, namespace,
|
||||||
|
wf_list_spec, db_wfs):
|
||||||
for wf_spec in wf_list_spec.get_workflows():
|
for wf_spec in wf_list_spec.get_workflows():
|
||||||
db_wfs.append(
|
db_wfs.append(
|
||||||
_create_workflow(wf_spec, definition, scope, is_system)
|
_create_workflow(
|
||||||
|
wf_spec,
|
||||||
|
definition,
|
||||||
|
scope,
|
||||||
|
namespace,
|
||||||
|
is_system
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def update_workflows(definition, scope='private', identifier=None):
|
def update_workflows(definition, scope='private', identifier=None,
|
||||||
|
namespace=''):
|
||||||
LOG.debug("updating workflows")
|
LOG.debug("updating workflows")
|
||||||
wf_list_spec = spec_parser.get_workflow_list_spec_from_yaml(definition)
|
wf_list_spec = spec_parser.get_workflow_list_spec_from_yaml(definition)
|
||||||
wfs = wf_list_spec.get_workflows()
|
wfs = wf_list_spec.get_workflows()
|
||||||
@ -105,6 +116,7 @@ def update_workflows(definition, scope='private', identifier=None):
|
|||||||
wf_spec,
|
wf_spec,
|
||||||
definition,
|
definition,
|
||||||
scope,
|
scope,
|
||||||
|
namespace=namespace,
|
||||||
identifier=identifier
|
identifier=identifier
|
||||||
))
|
))
|
||||||
|
|
||||||
@ -128,29 +140,33 @@ def update_workflow_execution_env(wf_ex, env):
|
|||||||
return wf_ex
|
return wf_ex
|
||||||
|
|
||||||
|
|
||||||
def _get_workflow_values(wf_spec, definition, scope, is_system=False):
|
def _get_workflow_values(wf_spec, definition, scope, namespace=None,
|
||||||
|
is_system=False):
|
||||||
values = {
|
values = {
|
||||||
'name': wf_spec.get_name(),
|
'name': wf_spec.get_name(),
|
||||||
'tags': wf_spec.get_tags(),
|
'tags': wf_spec.get_tags(),
|
||||||
'definition': definition,
|
'definition': definition,
|
||||||
'spec': wf_spec.to_dict(),
|
'spec': wf_spec.to_dict(),
|
||||||
'scope': scope,
|
'scope': scope,
|
||||||
|
'namespace': namespace,
|
||||||
'is_system': is_system
|
'is_system': is_system
|
||||||
}
|
}
|
||||||
|
|
||||||
return values
|
return values
|
||||||
|
|
||||||
|
|
||||||
def _create_workflow(wf_spec, definition, scope, is_system):
|
def _create_workflow(wf_spec, definition, scope, namespace, is_system):
|
||||||
return db_api.create_workflow_definition(
|
return db_api.create_workflow_definition(
|
||||||
_get_workflow_values(wf_spec, definition, scope, is_system)
|
_get_workflow_values(wf_spec, definition, scope, namespace, is_system)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def _update_workflow(wf_spec, definition, scope, identifier=None):
|
def _update_workflow(wf_spec, definition, scope, identifier=None,
|
||||||
values = _get_workflow_values(wf_spec, definition, scope)
|
namespace=''):
|
||||||
|
values = _get_workflow_values(wf_spec, definition, scope, namespace)
|
||||||
|
|
||||||
return db_api.update_workflow_definition(
|
return db_api.update_workflow_definition(
|
||||||
identifier if identifier else values['name'],
|
identifier if identifier else values['name'],
|
||||||
values
|
values,
|
||||||
|
namespace=namespace
|
||||||
)
|
)
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
version: '2.0'
|
||||||
|
lowest_level_wf:
|
||||||
|
tasks:
|
||||||
|
noop_task:
|
||||||
|
action: std.noop
|
6
mistral/tests/resources/for_wf_namespace/middle_wf.yaml
Normal file
6
mistral/tests/resources/for_wf_namespace/middle_wf.yaml
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
version: '2.0'
|
||||||
|
middle_wf:
|
||||||
|
tasks:
|
||||||
|
run_workflow_with_name_lowest_level_wf:
|
||||||
|
workflow: lowest_level_wf
|
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
version: '2.0'
|
||||||
|
top_level_wf:
|
||||||
|
tasks:
|
||||||
|
run_workflow_with_name_middle_wf:
|
||||||
|
workflow: middle_wf
|
@ -468,6 +468,7 @@ class TestExecutionsController(base.APITest):
|
|||||||
|
|
||||||
f.assert_called_once_with(
|
f.assert_called_once_with(
|
||||||
exec_dict['workflow_id'],
|
exec_dict['workflow_id'],
|
||||||
|
'',
|
||||||
json.loads(exec_dict['input']),
|
json.loads(exec_dict['input']),
|
||||||
exec_dict['description'],
|
exec_dict['description'],
|
||||||
**json.loads(exec_dict['params'])
|
**json.loads(exec_dict['params'])
|
||||||
|
@ -167,9 +167,7 @@ class TestMembersController(base.APITest):
|
|||||||
def test_get_memberships_nonexistent_wf(self, auth_mock):
|
def test_get_memberships_nonexistent_wf(self, auth_mock):
|
||||||
nonexistent_wf_id = uuidutils.generate_uuid()
|
nonexistent_wf_id = uuidutils.generate_uuid()
|
||||||
|
|
||||||
resp = self.app.get(
|
resp = self.app.get('/v2/workflows/%s/members' % nonexistent_wf_id)
|
||||||
'/v2/workflows/%s/members' % nonexistent_wf_id,
|
|
||||||
)
|
|
||||||
|
|
||||||
self.assertEqual(200, resp.status_int)
|
self.assertEqual(200, resp.status_int)
|
||||||
self.assertEqual(0, len(resp.json['members']))
|
self.assertEqual(0, len(resp.json['members']))
|
||||||
|
@ -60,6 +60,26 @@ WF = {
|
|||||||
'input': 'param1'
|
'input': 'param1'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WF_DB_WITHIN_ABC_NAMESPACE = models.WorkflowDefinition(
|
||||||
|
id='234560fe-162a-4060-a16a-a0d9eee9b408',
|
||||||
|
name='flow',
|
||||||
|
namespace='abc',
|
||||||
|
definition=WF_DEFINITION,
|
||||||
|
created_at=datetime.datetime(1970, 1, 1),
|
||||||
|
updated_at=datetime.datetime(1970, 1, 1),
|
||||||
|
spec={'input': ['param1']}
|
||||||
|
)
|
||||||
|
|
||||||
|
WF_WITH_NAMESPACE = {
|
||||||
|
'id': '234560fe-162a-4060-a16a-a0d9eee9b408',
|
||||||
|
'name': 'flow',
|
||||||
|
'namespace': 'abc',
|
||||||
|
'definition': WF_DEFINITION,
|
||||||
|
'created_at': '1970-01-01 00:00:00',
|
||||||
|
'updated_at': '1970-01-01 00:00:00',
|
||||||
|
'input': 'param1'
|
||||||
|
}
|
||||||
|
|
||||||
WF_DEFINITION_WITH_INPUT = """
|
WF_DEFINITION_WITH_INPUT = """
|
||||||
---
|
---
|
||||||
version: '2.0'
|
version: '2.0'
|
||||||
@ -218,7 +238,8 @@ class TestWorkflowsController(base.APITest):
|
|||||||
update_mock.assert_called_once_with(
|
update_mock.assert_called_once_with(
|
||||||
UPDATED_WF_DEFINITION,
|
UPDATED_WF_DEFINITION,
|
||||||
scope='private',
|
scope='private',
|
||||||
identifier='123e4567-e89b-12d3-a456-426655440000'
|
identifier='123e4567-e89b-12d3-a456-426655440000',
|
||||||
|
namespace=''
|
||||||
)
|
)
|
||||||
self.assertDictEqual(UPDATED_WF, resp.json)
|
self.assertDictEqual(UPDATED_WF, resp.json)
|
||||||
|
|
||||||
@ -603,3 +624,45 @@ class TestWorkflowsController(base.APITest):
|
|||||||
self.assertEqual(200, resp.status_int)
|
self.assertEqual(200, resp.status_int)
|
||||||
self.assertFalse(resp.json['valid'])
|
self.assertFalse(resp.json['valid'])
|
||||||
self.assertIn("Invalid DSL", resp.json['error'])
|
self.assertIn("Invalid DSL", resp.json['error'])
|
||||||
|
|
||||||
|
@mock.patch("mistral.services.workflows.update_workflows")
|
||||||
|
@mock.patch.object(db_api, "create_workflow_definition")
|
||||||
|
def test_workflow_within_namespace(self, mock_mtd, update_mock):
|
||||||
|
mock_mtd.return_value = WF_DB_WITHIN_ABC_NAMESPACE
|
||||||
|
|
||||||
|
namespace = 'abc'
|
||||||
|
resp = self.app.post(
|
||||||
|
'/v2/workflows?namespace=%s' % namespace,
|
||||||
|
WF_DEFINITION,
|
||||||
|
headers={'Content-Type': 'text/plain'}
|
||||||
|
)
|
||||||
|
|
||||||
|
self.assertEqual(201, resp.status_int)
|
||||||
|
self.assertDictEqual({'workflows': [WF_WITH_NAMESPACE]}, resp.json)
|
||||||
|
|
||||||
|
self.assertEqual(1, mock_mtd.call_count)
|
||||||
|
|
||||||
|
spec = mock_mtd.call_args[0][0]['spec']
|
||||||
|
|
||||||
|
self.assertIsNotNone(spec)
|
||||||
|
self.assertEqual(WF_DB.name, spec['name'])
|
||||||
|
self.assertEqual(WF_DB_WITHIN_ABC_NAMESPACE.namespace, namespace)
|
||||||
|
|
||||||
|
update_mock.return_value = [WF_DB_WITHIN_ABC_NAMESPACE]
|
||||||
|
|
||||||
|
id_ = '234560fe-162a-4060-a16a-a0d9eee9b408'
|
||||||
|
|
||||||
|
resp = self.app.put(
|
||||||
|
'/v2/workflows/%s?namespace=%s' % (id_, namespace),
|
||||||
|
WF_DEFINITION,
|
||||||
|
headers={'Content-Type': 'text/plain'}
|
||||||
|
)
|
||||||
|
|
||||||
|
self.assertEqual(200, resp.status_int)
|
||||||
|
update_mock.assert_called_once_with(
|
||||||
|
WF_DEFINITION,
|
||||||
|
scope='private',
|
||||||
|
identifier=id_,
|
||||||
|
namespace='abc'
|
||||||
|
)
|
||||||
|
self.assertDictEqual(WF_WITH_NAMESPACE, resp.json)
|
||||||
|
@ -373,7 +373,8 @@ WF_DEFINITIONS = [
|
|||||||
'scope': 'public',
|
'scope': 'public',
|
||||||
'project_id': '1233',
|
'project_id': '1233',
|
||||||
'trust_id': '1234',
|
'trust_id': '1234',
|
||||||
'created_at': datetime.datetime(2016, 12, 1, 15, 0, 0)
|
'created_at': datetime.datetime(2016, 12, 1, 15, 0, 0),
|
||||||
|
'namespace': ''
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'name': 'my_wf2',
|
'name': 'my_wf2',
|
||||||
@ -383,7 +384,8 @@ WF_DEFINITIONS = [
|
|||||||
'scope': 'private',
|
'scope': 'private',
|
||||||
'project_id': '1233',
|
'project_id': '1233',
|
||||||
'trust_id': '12345',
|
'trust_id': '12345',
|
||||||
'created_at': datetime.datetime(2016, 12, 1, 15, 1, 0)
|
'created_at': datetime.datetime(2016, 12, 1, 15, 1, 0),
|
||||||
|
'namespace': ''
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ class ActionContextTest(base.EngineTestCase):
|
|||||||
def test_action_context(self):
|
def test_action_context(self):
|
||||||
wb_service.create_workbook_v2(WORKBOOK)
|
wb_service.create_workbook_v2(WORKBOOK)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1')
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -105,7 +105,7 @@ class ActionDefaultTest(base.EngineTestCase):
|
|||||||
def test_action_defaults_from_env(self):
|
def test_action_defaults_from_env(self):
|
||||||
wf_service.create_workflows(WORKFLOW1)
|
wf_service.create_workflows(WORKFLOW1)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf1', None, env=ENV)
|
wf_ex = self.engine.start_workflow('wf1', env=ENV)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -131,7 +131,7 @@ class ActionDefaultTest(base.EngineTestCase):
|
|||||||
def test_action_defaults_from_env_not_applied(self):
|
def test_action_defaults_from_env_not_applied(self):
|
||||||
wf_service.create_workflows(WORKFLOW2)
|
wf_service.create_workflows(WORKFLOW2)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf2', None, env=ENV)
|
wf_ex = self.engine.start_workflow('wf2', env=ENV)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -167,6 +167,7 @@ class ActionDefaultTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf1_with_items',
|
'wf1_with_items',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
env=ENV
|
env=ENV
|
||||||
)
|
)
|
||||||
@ -206,6 +207,7 @@ class ActionDefaultTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf2_with_items',
|
'wf2_with_items',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
env=ENV
|
env=ENV
|
||||||
)
|
)
|
||||||
|
@ -112,6 +112,7 @@ class AdhocActionsTest(base.EngineTestCase):
|
|||||||
def test_run_workflow_with_adhoc_action(self):
|
def test_run_workflow_with_adhoc_action(self):
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'my_wb.wf1',
|
'my_wb.wf1',
|
||||||
|
'',
|
||||||
{'str1': 'a', 'str2': 'b'}
|
{'str1': 'a', 'str2': 'b'}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -131,6 +132,7 @@ class AdhocActionsTest(base.EngineTestCase):
|
|||||||
def test_run_adhoc_action_without_input_value(self):
|
def test_run_adhoc_action_without_input_value(self):
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'my_wb.wf2',
|
'my_wb.wf2',
|
||||||
|
'',
|
||||||
{'str1': 'a', 'str2': 'b'}
|
{'str1': 'a', 'str2': 'b'}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -149,6 +151,7 @@ class AdhocActionsTest(base.EngineTestCase):
|
|||||||
def test_run_adhoc_action_without_sufficient_input_value(self):
|
def test_run_adhoc_action_without_sufficient_input_value(self):
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'my_wb.wf3',
|
'my_wb.wf3',
|
||||||
|
'',
|
||||||
{'str1': 'a', 'str2': 'b'}
|
{'str1': 'a', 'str2': 'b'}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -157,7 +160,7 @@ class AdhocActionsTest(base.EngineTestCase):
|
|||||||
|
|
||||||
def test_run_adhoc_action_with_env(self):
|
def test_run_adhoc_action_with_env(self):
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'my_wb.wf4', {'str1': 'a'}, env={'foo': 'bar'})
|
'my_wb.wf4', '', {'str1': 'a'}, env={'foo': 'bar'})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
|
@ -58,7 +58,7 @@ class SimpleEngineCommandsTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK1)
|
wb_service.create_workbook_v2(WORKBOOK1)
|
||||||
|
|
||||||
def test_fail(self):
|
def test_fail(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 1})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 1})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -75,7 +75,7 @@ class SimpleEngineCommandsTest(base.EngineTestCase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def test_succeed(self):
|
def test_succeed(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 2})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 2})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -92,7 +92,7 @@ class SimpleEngineCommandsTest(base.EngineTestCase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def test_pause(self):
|
def test_pause(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 3})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 3})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -144,7 +144,7 @@ class SimpleEngineWorkflowLevelCommandsTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK2)
|
wb_service.create_workbook_v2(WORKBOOK2)
|
||||||
|
|
||||||
def test_fail(self):
|
def test_fail(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 1})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 1})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -161,7 +161,7 @@ class SimpleEngineWorkflowLevelCommandsTest(base.EngineTestCase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def test_succeed(self):
|
def test_succeed(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 2})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 2})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -178,7 +178,7 @@ class SimpleEngineWorkflowLevelCommandsTest(base.EngineTestCase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def test_pause(self):
|
def test_pause(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 3})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 3})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -263,7 +263,7 @@ class OrderEngineCommandsTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK3)
|
wb_service.create_workbook_v2(WORKBOOK3)
|
||||||
|
|
||||||
def test_fail_first(self):
|
def test_fail_first(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.fail_first_wf', None)
|
wf_ex = self.engine.start_workflow('my_wb.fail_first_wf', '', None)
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -280,7 +280,7 @@ class OrderEngineCommandsTest(base.EngineTestCase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def test_fail_second(self):
|
def test_fail_second(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.fail_second_wf', None)
|
wf_ex = self.engine.start_workflow('my_wb.fail_second_wf', '', None)
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -301,7 +301,7 @@ class OrderEngineCommandsTest(base.EngineTestCase):
|
|||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
def test_succeed_first(self):
|
def test_succeed_first(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.succeed_first_wf', None)
|
wf_ex = self.engine.start_workflow('my_wb.succeed_first_wf', '', None)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -318,7 +318,7 @@ class OrderEngineCommandsTest(base.EngineTestCase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def test_succeed_second(self):
|
def test_succeed_second(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.succeed_second_wf', None)
|
wf_ex = self.engine.start_workflow('my_wb.succeed_second_wf', '', None)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -371,7 +371,7 @@ class SimpleEngineCmdsWithMsgTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK4)
|
wb_service.create_workbook_v2(WORKBOOK4)
|
||||||
|
|
||||||
def test_fail(self):
|
def test_fail(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 1})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 1})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -390,7 +390,7 @@ class SimpleEngineCmdsWithMsgTest(base.EngineTestCase):
|
|||||||
self.assertEqual('my_var value is 1', wf_ex.state_info)
|
self.assertEqual('my_var value is 1', wf_ex.state_info)
|
||||||
|
|
||||||
def test_succeed(self):
|
def test_succeed(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 2})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 2})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -409,7 +409,7 @@ class SimpleEngineCmdsWithMsgTest(base.EngineTestCase):
|
|||||||
self.assertEqual("my_var value is 2", wf_ex.state_info)
|
self.assertEqual("my_var value is 2", wf_ex.state_info)
|
||||||
|
|
||||||
def test_pause(self):
|
def test_pause(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 3})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 3})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -462,7 +462,7 @@ class SimpleEngineWorkflowLevelCmdsWithMsgTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK5)
|
wb_service.create_workbook_v2(WORKBOOK5)
|
||||||
|
|
||||||
def test_fail(self):
|
def test_fail(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 1})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 1})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -481,7 +481,7 @@ class SimpleEngineWorkflowLevelCmdsWithMsgTest(base.EngineTestCase):
|
|||||||
self.assertEqual("my_var value is 1", wf_ex.state_info)
|
self.assertEqual("my_var value is 1", wf_ex.state_info)
|
||||||
|
|
||||||
def test_succeed(self):
|
def test_succeed(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 2})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 2})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -500,7 +500,7 @@ class SimpleEngineWorkflowLevelCmdsWithMsgTest(base.EngineTestCase):
|
|||||||
self.assertEqual("my_var value is 2", wf_ex.state_info)
|
self.assertEqual("my_var value is 2", wf_ex.state_info)
|
||||||
|
|
||||||
def test_pause(self):
|
def test_pause(self):
|
||||||
wf_ex = self.engine.start_workflow('my_wb.wf', {'my_var': 3})
|
wf_ex = self.engine.start_workflow('my_wb.wf', '', {'my_var': 3})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(linear_wf)
|
wf_service.create_workflows(linear_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {}, env={'from': 'Neo'})
|
wf_ex = self.engine.start_workflow('wf', '', {}, env={'from': 'Neo'})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -133,7 +133,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(linear_with_branches_wf)
|
wf_service.create_workflows(linear_with_branches_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {}, env={'from': 'Neo'})
|
wf_ex = self.engine.start_workflow('wf', '', {}, env={'from': 'Neo'})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -208,7 +208,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(parallel_tasks_wf)
|
wf_service.create_workflows(parallel_tasks_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -286,7 +286,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(parallel_tasks_complex_wf)
|
wf_service.create_workflows(parallel_tasks_complex_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -367,6 +367,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
env={'from': 'Neo'}
|
env={'from': 'Neo'}
|
||||||
)
|
)
|
||||||
@ -425,6 +426,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
env={'from': 'Neo'}
|
env={'from': 'Neo'}
|
||||||
)
|
)
|
||||||
@ -482,7 +484,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(linear_wf)
|
wf_service.create_workflows(linear_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -517,7 +519,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(linear_wf)
|
wf_service.create_workflows(linear_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -557,7 +559,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf)
|
wf_service.create_workflows(wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf1_with_items', {})
|
wf_ex = self.engine.start_workflow('wf1_with_items', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -595,7 +597,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_def)
|
wf_service.create_workflows(wf_def)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -655,7 +657,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(wb_def)
|
wb_service.create_workbook_v2(wb_def)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -701,7 +703,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', wf_input)
|
wf_ex = self.engine.start_workflow('wf', '', wf_input)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -734,7 +736,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -773,7 +775,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -817,7 +819,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -858,7 +860,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -905,7 +907,7 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -110,6 +110,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
'my execution',
|
'my execution',
|
||||||
task_name='task2'
|
task_name='task2'
|
||||||
@ -154,6 +155,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
task_name='task1'
|
task_name='task1'
|
||||||
)
|
)
|
||||||
@ -200,6 +202,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
env=env,
|
env=env,
|
||||||
task_name='task2')
|
task_name='task2')
|
||||||
@ -221,6 +224,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
env='test',
|
env='test',
|
||||||
task_name='task2'
|
task_name='task2'
|
||||||
@ -238,6 +242,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
exc.InputException,
|
exc.InputException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'param1': '<% env().key1 %>',
|
'param1': '<% env().key1 %>',
|
||||||
'param2': 'some value'
|
'param2': 'some value'
|
||||||
@ -253,6 +258,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
exc.InputException,
|
exc.InputException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'param1': '<% env().key1 %>',
|
'param1': '<% env().key1 %>',
|
||||||
'param2': 'some value'
|
'param2': 'some value'
|
||||||
@ -268,6 +274,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
exc.InputException,
|
exc.InputException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
None,
|
None,
|
||||||
task_name='task2'
|
task_name='task2'
|
||||||
)
|
)
|
||||||
@ -280,6 +287,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
exc.InputException,
|
exc.InputException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'param1': 'Hey',
|
'param1': 'Hey',
|
||||||
'param2': 'Hi',
|
'param2': 'Hi',
|
||||||
@ -297,6 +305,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
task_name='task2'
|
task_name='task2'
|
||||||
)
|
)
|
||||||
@ -410,6 +419,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'param1': 'Hey',
|
'param1': 'Hey',
|
||||||
'param2': 'Hi'
|
'param2': 'Hi'
|
||||||
@ -432,6 +442,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'param1': 'Hey',
|
'param1': 'Hey',
|
||||||
'param2': 'Hi'
|
'param2': 'Hi'
|
||||||
@ -453,6 +464,7 @@ class DefaultEngineTest(base.DbTestCase):
|
|||||||
def test_stop_workflow_bad_status(self):
|
def test_stop_workflow_bad_status(self):
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb.wf',
|
'wb.wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'param1': 'Hey',
|
'param1': 'Hey',
|
||||||
'param2': 'Hi'
|
'param2': 'Hi'
|
||||||
|
@ -32,7 +32,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
def _run_workflow(self, wf_text, expected_state=states.ERROR):
|
def _run_workflow(self, wf_text, expected_state=states.ERROR):
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf_ex.id, expected_state)
|
self.await_workflow_state(wf_ex.id, expected_state)
|
||||||
|
|
||||||
@ -113,7 +113,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -147,7 +147,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -243,7 +243,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', None)
|
wf_ex = self.engine.start_workflow('wf', '', None)
|
||||||
|
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
"Failed to find action [action_name=wrong.task]",
|
"Failed to find action [action_name=wrong.task]",
|
||||||
@ -406,7 +406,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', None)
|
wf_ex = self.engine.start_workflow('wf', '', None)
|
||||||
|
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
"Can not evaluate YAQL expression [expression=wrong(yaql)",
|
"Can not evaluate YAQL expression [expression=wrong(yaql)",
|
||||||
@ -429,7 +429,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {'var': 2})
|
wf_ex = self.engine.start_workflow('wf', '', {'var': 2})
|
||||||
|
|
||||||
self.assertIn("Can not evaluate YAQL expression", wf_ex.state_info)
|
self.assertIn("Can not evaluate YAQL expression", wf_ex.state_info)
|
||||||
self.assertEqual(states.ERROR, wf_ex.state)
|
self.assertEqual(states.ERROR, wf_ex.state)
|
||||||
@ -460,7 +460,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -612,7 +612,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
calls = db_api.get_delayed_calls()
|
calls = db_api.get_delayed_calls()
|
||||||
|
|
||||||
@ -639,7 +639,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
calls = db_api.get_delayed_calls()
|
calls = db_api.get_delayed_calls()
|
||||||
|
|
||||||
@ -670,7 +670,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -705,7 +705,7 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -224,7 +224,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -326,7 +326,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {}, env=env)
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {}, env=env)
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -472,7 +472,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -526,7 +526,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WITH_ITEMS_WORKBOOK)
|
wb_service.create_workbook_v2(WITH_ITEMS_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb3.wf1', {})
|
wf_ex = self.engine.start_workflow('wb3.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -618,7 +618,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WITH_ITEMS_WORKBOOK_CONCURRENCY)
|
wb_service.create_workbook_v2(WITH_ITEMS_WORKBOOK_CONCURRENCY)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb3.wf1', {})
|
wf_ex = self.engine.start_workflow('wb3.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -700,7 +700,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
env = {'var1': 'fee fi fo fum'}
|
env = {'var1': 'fee fi fo fum'}
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb3.wf1', {}, env=env)
|
wf_ex = self.engine.start_workflow('wb3.wf1', '', {}, env=env)
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -806,7 +806,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(JOIN_WORKBOOK)
|
wb_service.create_workbook_v2(JOIN_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
|
|
||||||
@ -905,7 +905,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(JOIN_WORKBOOK)
|
wb_service.create_workbook_v2(JOIN_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -1057,7 +1057,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WITH_ITEMS_WORKBOOK)
|
wb_service.create_workbook_v2(WITH_ITEMS_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb3.wf1', {})
|
wf_ex = self.engine.start_workflow('wb3.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -1206,7 +1206,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(SUBFLOW_WORKBOOK)
|
wb_service.create_workbook_v2(SUBFLOW_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -1299,7 +1299,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(SUBFLOW_WORKBOOK)
|
wb_service.create_workbook_v2(SUBFLOW_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
|
@ -65,7 +65,7 @@ class DirectWorkflowRerunCancelledTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(wb_def)
|
wb_service.create_workbook_v2(wb_def)
|
||||||
|
|
||||||
wf1_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf1_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
||||||
|
|
||||||
@ -232,7 +232,7 @@ class DirectWorkflowRerunCancelledTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(wb_def)
|
wb_service.create_workbook_v2(wb_def)
|
||||||
|
|
||||||
wf1_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf1_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
||||||
|
|
||||||
@ -402,7 +402,7 @@ class DirectWorkflowRerunCancelledTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(wb_def)
|
wb_service.create_workbook_v2(wb_def)
|
||||||
|
|
||||||
wf1_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf1_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
||||||
|
|
||||||
@ -561,7 +561,7 @@ class DirectWorkflowRerunCancelledTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(wb_def)
|
wb_service.create_workbook_v2(wb_def)
|
||||||
|
|
||||||
wf1_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf1_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
||||||
|
|
||||||
|
@ -58,7 +58,7 @@ class DirectWorkflowWithCyclesTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf')
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -120,7 +120,7 @@ class DirectWorkflowWithCyclesTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -195,7 +195,7 @@ class DirectWorkflowWithCyclesTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -104,7 +104,7 @@ class EnvironmentTest(base.EngineTestCase):
|
|||||||
|
|
||||||
@mock.patch.object(r_exe.RemoteExecutor, 'run_action', MOCK_RUN_AT_TARGET)
|
@mock.patch.object(r_exe.RemoteExecutor, 'run_action', MOCK_RUN_AT_TARGET)
|
||||||
def _test_subworkflow(self, env):
|
def _test_subworkflow(self, env):
|
||||||
wf2_ex = self.engine.start_workflow('my_wb.wf2', {}, env=env)
|
wf2_ex = self.engine.start_workflow('my_wb.wf2', '', {}, env=env)
|
||||||
|
|
||||||
# Execution of 'wf2'.
|
# Execution of 'wf2'.
|
||||||
self.assertIsNotNone(wf2_ex)
|
self.assertIsNotNone(wf2_ex)
|
||||||
@ -225,6 +225,7 @@ class EnvironmentTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
env=env,
|
env=env,
|
||||||
evaluate_env=True
|
evaluate_env=True
|
||||||
@ -249,6 +250,7 @@ class EnvironmentTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
env=env,
|
env=env,
|
||||||
evaluate_env=False
|
evaluate_env=False
|
||||||
@ -297,6 +299,7 @@ class EnvironmentTest(base.EngineTestCase):
|
|||||||
|
|
||||||
parent_wf_ex = self.engine.start_workflow(
|
parent_wf_ex = self.engine.start_workflow(
|
||||||
'parent_wf',
|
'parent_wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
env=env,
|
env=env,
|
||||||
evaluate_env=False
|
evaluate_env=False
|
||||||
@ -329,6 +332,7 @@ class EnvironmentTest(base.EngineTestCase):
|
|||||||
|
|
||||||
parent_wf_ex = self.engine.start_workflow(
|
parent_wf_ex = self.engine.start_workflow(
|
||||||
'parent_wf',
|
'parent_wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
env=env,
|
env=env,
|
||||||
evaluate_env=True
|
evaluate_env=True
|
||||||
|
@ -62,6 +62,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
exc.InputException,
|
exc.InputException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{'wrong_param': 'some_value'}
|
{'wrong_param': 'some_value'}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -87,7 +88,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.assertEqual(states.RUNNING, wf_ex.state)
|
self.assertEqual(states.RUNNING, wf_ex.state)
|
||||||
self.assertIsNotNone(db_api.get_workflow_execution(wf_ex.id))
|
self.assertIsNotNone(db_api.get_workflow_execution(wf_ex.id))
|
||||||
@ -118,7 +119,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -148,7 +149,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -206,7 +207,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -257,7 +258,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -309,7 +310,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -357,7 +358,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -398,7 +399,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -426,7 +427,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -453,7 +454,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -481,7 +482,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -510,7 +511,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -545,7 +546,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -584,7 +585,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(wb_text)
|
wb_service.create_workbook_v2(wb_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', {})
|
wf_ex = self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -620,7 +621,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -656,7 +657,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -687,7 +688,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -727,7 +728,7 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
|
@ -83,6 +83,7 @@ class ErrorResultTest(base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'success_result': None,
|
'success_result': None,
|
||||||
'error_result': 2
|
'error_result': 2
|
||||||
@ -116,6 +117,7 @@ class ErrorResultTest(base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'success_result': None,
|
'success_result': None,
|
||||||
'error_result': 3
|
'error_result': 3
|
||||||
@ -149,6 +151,7 @@ class ErrorResultTest(base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'success_result': 'success',
|
'success_result': 'success',
|
||||||
'error_result': None
|
'error_result': None
|
||||||
|
@ -123,7 +123,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(new_wf)
|
wf_service.create_workflows(new_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -137,6 +137,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
exc.SizeLimitExceededException,
|
exc.SizeLimitExceededException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{}
|
{}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -153,6 +154,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
exc.SizeLimitExceededException,
|
exc.SizeLimitExceededException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{'workflow_input': ''.join('A' for _ in range(1024))}
|
{'workflow_input': ''.join('A' for _ in range(1024))}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -167,7 +169,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(new_wf)
|
wf_service.create_workflows(new_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.assertEqual(states.ERROR, wf_ex.state)
|
self.assertEqual(states.ERROR, wf_ex.state)
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
@ -181,6 +183,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{'action_output_length': 1024}
|
{'action_output_length': 1024}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -201,7 +204,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(new_wf)
|
wf_service.create_workflows(new_wf)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -234,6 +237,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
exc.SizeLimitExceededException,
|
exc.SizeLimitExceededException,
|
||||||
self.engine.start_workflow,
|
self.engine.start_workflow,
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
'',
|
'',
|
||||||
env={'param': long_string}
|
env={'param': long_string}
|
||||||
@ -257,6 +261,7 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{
|
{
|
||||||
'action_output_length': 80000,
|
'action_output_length': 80000,
|
||||||
'action_output_dict': True,
|
'action_output_dict': True,
|
||||||
|
@ -69,7 +69,7 @@ class JavaScriptEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK)
|
wb_service.create_workbook_v2(WORKBOOK)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('test_js.js_test', {'num': 50})
|
wf_ex = self.engine.start_workflow('test_js.js_test', '', {'num': 50})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -88,7 +88,7 @@ class JavaScriptEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK)
|
wb_service.create_workbook_v2(WORKBOOK)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('test_js.js_test', {'num': 50})
|
wf_ex = self.engine.start_workflow('test_js.js_test', '', {'num': 50})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -95,7 +95,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -148,7 +148,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -209,7 +209,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
def _num_of_tasks():
|
def _num_of_tasks():
|
||||||
return len(
|
return len(
|
||||||
@ -290,7 +290,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -372,7 +372,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -449,7 +449,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -531,7 +531,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wfs_tasks_join_complex)
|
wf_service.create_workflows(wfs_tasks_join_complex)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('main', {})
|
wf_ex = self.engine.start_workflow('main', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -596,7 +596,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('main', {})
|
wf_ex = self.engine.start_workflow('main', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -655,7 +655,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('main', {})
|
wf_ex = self.engine.start_workflow('main', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -709,7 +709,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('test-join', {})
|
wf_ex = self.engine.start_workflow('test-join', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -741,7 +741,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -785,7 +785,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -818,7 +818,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -851,7 +851,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
tasks = db_api.get_task_executions(workflow_execution_id=wf_ex.id)
|
tasks = db_api.get_task_executions(workflow_execution_id=wf_ex.id)
|
||||||
|
|
||||||
@ -909,7 +909,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
tasks = db_api.get_task_executions(workflow_execution_id=wf_ex.id)
|
tasks = db_api.get_task_executions(workflow_execution_id=wf_ex.id)
|
||||||
|
|
||||||
@ -975,7 +975,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -1037,7 +1037,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1061,7 +1061,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1119,7 +1119,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -1195,7 +1195,7 @@ class JoinEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ class LookupUtilsTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ class NoopTaskEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(WF)
|
wf_service.create_workflows(WF)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {'num1': 1, 'num2': 1})
|
wf_ex = self.engine.start_workflow('wf', '', {'num1': 1, 'num2': 1})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -107,7 +107,7 @@ class NoopTaskEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(WF)
|
wf_service.create_workflows(WF)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {'num1': 1, 'num2': 2})
|
wf_ex = self.engine.start_workflow('wf', '', {'num1': 1, 'num2': 2})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -423,7 +423,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WAIT_BEFORE_WB)
|
wb_service.create_workbook_v2(WAIT_BEFORE_WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -443,7 +443,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WAIT_BEFORE_FROM_VAR)
|
wb_service.create_workbook_v2(WAIT_BEFORE_FROM_VAR)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {'wait_before': 1})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {'wait_before': 1})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -471,7 +471,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -488,7 +488,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WAIT_AFTER_WB)
|
wb_service.create_workbook_v2(WAIT_AFTER_WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -506,7 +506,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WAIT_AFTER_FROM_VAR)
|
wb_service.create_workbook_v2(WAIT_AFTER_FROM_VAR)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {'wait_after': 2})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {'wait_after': 2})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -531,7 +531,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(RETRY_WB)
|
wb_service.create_workbook_v2(RETRY_WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -561,7 +561,11 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(RETRY_WB_FROM_VAR)
|
wb_service.create_workbook_v2(RETRY_WB_FROM_VAR)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {'count': 3, 'delay': 1})
|
wf_ex = self.engine.start_workflow(
|
||||||
|
'wb.wf1',
|
||||||
|
'',
|
||||||
|
{'count': 3, 'delay': 1}
|
||||||
|
)
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -606,7 +610,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -649,7 +653,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -692,7 +696,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -736,7 +740,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -777,7 +781,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -816,7 +820,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -862,7 +866,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.main', {})
|
wf_ex = self.engine.start_workflow('wb.main', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -908,7 +912,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(retry_wb)
|
wb_service.create_workbook_v2(retry_wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -961,7 +965,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
wf_service.create_workflows(retry_wf)
|
wf_service.create_workflows(retry_wf)
|
||||||
wf_ex = self.engine.start_workflow('wf1', {})
|
wf_ex = self.engine.start_workflow('wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -984,7 +988,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(TIMEOUT_WB)
|
wb_service.create_workbook_v2(TIMEOUT_WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -1009,7 +1013,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(TIMEOUT_WB2)
|
wb_service.create_workbook_v2(TIMEOUT_WB2)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -1036,7 +1040,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(TIMEOUT_FROM_VAR)
|
wb_service.create_workbook_v2(TIMEOUT_FROM_VAR)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {'timeout': 1})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {'timeout': 1})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
# Note: We need to reread execution to access related tasks.
|
# Note: We need to reread execution to access related tasks.
|
||||||
@ -1055,7 +1059,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(PAUSE_BEFORE_WB)
|
wb_service.create_workbook_v2(PAUSE_BEFORE_WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -1096,7 +1100,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(PAUSE_BEFORE_DELAY_WB)
|
wb_service.create_workbook_v2(PAUSE_BEFORE_DELAY_WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -1148,7 +1152,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(CONCURRENCY_WB)
|
wb_service.create_workbook_v2(CONCURRENCY_WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1166,7 +1170,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(CONCURRENCY_WB_FROM_VAR)
|
wb_service.create_workbook_v2(CONCURRENCY_WB_FROM_VAR)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {'concurrency': 4})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {'concurrency': 4})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -1194,7 +1198,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(wb)
|
wb_service.create_workbook_v2(wb)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {'wait_before': '1'})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {'wait_before': '1'})
|
||||||
|
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
'Invalid data type in WaitBeforePolicy',
|
'Invalid data type in WaitBeforePolicy',
|
||||||
@ -1219,7 +1223,7 @@ class PoliciesTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_delayed_state)
|
wf_service.create_workflows(wf_delayed_state)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ class EngineProfilerTest(base.EngineTestCase):
|
|||||||
|
|
||||||
self.ctx_serializer.deserialize_context(ctx)
|
self.ctx_serializer.deserialize_context(ctx)
|
||||||
|
|
||||||
wf_ex = self.engine_client.start_workflow('wf', {})
|
wf_ex = self.engine_client.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.assertIsNotNone(wf_ex)
|
self.assertIsNotNone(wf_ex)
|
||||||
self.assertEqual(states.RUNNING, wf_ex['state'])
|
self.assertEqual(states.RUNNING, wf_ex['state'])
|
||||||
@ -87,7 +87,7 @@ class EngineProfilerTest(base.EngineTestCase):
|
|||||||
|
|
||||||
self.ctx_serializer.deserialize_context({})
|
self.ctx_serializer.deserialize_context({})
|
||||||
|
|
||||||
wf_ex = self.engine_client.start_workflow('wf', {})
|
wf_ex = self.engine_client.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.assertIsNotNone(wf_ex)
|
self.assertIsNotNone(wf_ex)
|
||||||
self.assertEqual(states.RUNNING, wf_ex['state'])
|
self.assertEqual(states.RUNNING, wf_ex['state'])
|
||||||
|
@ -141,7 +141,7 @@ class EngineActionRaceConditionTest(base.EngineTestCase):
|
|||||||
|
|
||||||
self.block_action()
|
self.block_action()
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', None)
|
wf_ex = self.engine.start_workflow('wf', '', None)
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -183,7 +183,7 @@ class EngineActionRaceConditionTest(base.EngineTestCase):
|
|||||||
|
|
||||||
self.block_action()
|
self.block_action()
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', None)
|
wf_ex = self.engine.start_workflow('wf', '', None)
|
||||||
|
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
|
|
||||||
|
@ -72,6 +72,7 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'my_wb.wf1',
|
'my_wb.wf1',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
task_name='task1'
|
task_name='task1'
|
||||||
)
|
)
|
||||||
@ -79,7 +80,10 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
# Execution 1.
|
# Execution 1.
|
||||||
self.assertIsNotNone(wf_ex)
|
self.assertIsNotNone(wf_ex)
|
||||||
self.assertDictEqual(wf_input, wf_ex.input)
|
self.assertDictEqual(wf_input, wf_ex.input)
|
||||||
self.assertDictEqual({'task_name': 'task1'}, wf_ex.params)
|
self.assertDictEqual(
|
||||||
|
{'task_name': 'task1', 'namespace': ''},
|
||||||
|
wf_ex.params
|
||||||
|
)
|
||||||
|
|
||||||
# Wait till workflow 'wf1' is completed.
|
# Wait till workflow 'wf1' is completed.
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
@ -105,6 +109,7 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'my_wb.wf1',
|
'my_wb.wf1',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
task_name='task2'
|
task_name='task2'
|
||||||
)
|
)
|
||||||
@ -112,7 +117,10 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
# Execution 1.
|
# Execution 1.
|
||||||
self.assertIsNotNone(wf_ex)
|
self.assertIsNotNone(wf_ex)
|
||||||
self.assertDictEqual(wf_input, wf_ex.input)
|
self.assertDictEqual(wf_input, wf_ex.input)
|
||||||
self.assertDictEqual({'task_name': 'task2'}, wf_ex.params)
|
self.assertDictEqual(
|
||||||
|
{'task_name': 'task2', 'namespace': ''},
|
||||||
|
wf_ex.params
|
||||||
|
)
|
||||||
|
|
||||||
# Wait till workflow 'wf1' is completed.
|
# Wait till workflow 'wf1' is completed.
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
@ -146,6 +154,7 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'my_wb.wf1',
|
'my_wb.wf1',
|
||||||
|
'',
|
||||||
wf_input,
|
wf_input,
|
||||||
task_name='task4'
|
task_name='task4'
|
||||||
)
|
)
|
||||||
|
@ -88,7 +88,7 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {}, task_name='t3')
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {}, task_name='t3')
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -200,6 +200,7 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
|
|||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wb1.wf1',
|
'wb1.wf1',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
task_name='t3',
|
task_name='t3',
|
||||||
env=env
|
env=env
|
||||||
@ -340,7 +341,7 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {}, task_name='t3')
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {}, task_name='t3')
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ class ReverseWorkflowRerunCancelledTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(wb_def)
|
wb_service.create_workbook_v2(wb_def)
|
||||||
|
|
||||||
wf1_ex = self.engine.start_workflow('wb1.wf1', {}, task_name='t3')
|
wf1_ex = self.engine.start_workflow('wb1.wf1', '', {}, task_name='t3')
|
||||||
|
|
||||||
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
||||||
|
|
||||||
|
@ -72,7 +72,7 @@ class TestSafeRerun(base.EngineTestCase):
|
|||||||
# to true.
|
# to true.
|
||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -118,7 +118,7 @@ class TestSafeRerun(base.EngineTestCase):
|
|||||||
# to true.
|
# to true.
|
||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -153,7 +153,7 @@ class TestSafeRerun(base.EngineTestCase):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ class ExecutionStateInfoTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('test_wf', {})
|
wf_ex = self.engine.start_workflow('test_wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -70,7 +70,7 @@ class ExecutionStateInfoTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('test_wf', {})
|
wf_ex = self.engine.start_workflow('test_wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -96,7 +96,7 @@ class ExecutionStateInfoTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('test_wf', {})
|
wf_ex = self.engine.start_workflow('test_wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -131,7 +131,7 @@ class ExecutionStateInfoTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
|
@ -105,7 +105,7 @@ class SubworkflowsTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WB2)
|
wb_service.create_workbook_v2(WB2)
|
||||||
|
|
||||||
def test_subworkflow_success(self):
|
def test_subworkflow_success(self):
|
||||||
wf2_ex = self.engine.start_workflow('wb1.wf2', None)
|
wf2_ex = self.engine.start_workflow('wb1.wf2', '', None)
|
||||||
|
|
||||||
project_id = auth_context.ctx().project_id
|
project_id = auth_context.ctx().project_id
|
||||||
|
|
||||||
@ -113,7 +113,7 @@ class SubworkflowsTest(base.EngineTestCase):
|
|||||||
self.assertEqual(project_id, wf2_ex.project_id)
|
self.assertEqual(project_id, wf2_ex.project_id)
|
||||||
self.assertIsNotNone(wf2_ex)
|
self.assertIsNotNone(wf2_ex)
|
||||||
self.assertDictEqual({}, wf2_ex.input)
|
self.assertDictEqual({}, wf2_ex.input)
|
||||||
self.assertDictEqual({}, wf2_ex.params)
|
self.assertDictEqual({'namespace': ''}, wf2_ex.params)
|
||||||
|
|
||||||
self._await(lambda: len(db_api.get_workflow_executions()) == 2, 0.5, 5)
|
self._await(lambda: len(db_api.get_workflow_executions()) == 2, 0.5, 5)
|
||||||
|
|
||||||
@ -187,7 +187,7 @@ class SubworkflowsTest(base.EngineTestCase):
|
|||||||
@mock.patch.object(std_actions.EchoAction, 'run',
|
@mock.patch.object(std_actions.EchoAction, 'run',
|
||||||
mock.MagicMock(side_effect=exc.ActionException))
|
mock.MagicMock(side_effect=exc.ActionException))
|
||||||
def test_subworkflow_error(self):
|
def test_subworkflow_error(self):
|
||||||
self.engine.start_workflow('wb1.wf2', None)
|
self.engine.start_workflow('wb1.wf2', '', None)
|
||||||
|
|
||||||
self._await(lambda: len(db_api.get_workflow_executions()) == 2, 0.5, 5)
|
self._await(lambda: len(db_api.get_workflow_executions()) == 2, 0.5, 5)
|
||||||
|
|
||||||
@ -205,7 +205,7 @@ class SubworkflowsTest(base.EngineTestCase):
|
|||||||
self.await_workflow_error(wf2_ex.id)
|
self.await_workflow_error(wf2_ex.id)
|
||||||
|
|
||||||
def test_subworkflow_yaql_error(self):
|
def test_subworkflow_yaql_error(self):
|
||||||
wf_ex = self.engine.start_workflow('wb2.wf1', None)
|
wf_ex = self.engine.start_workflow('wb2.wf1', '', None)
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -227,12 +227,15 @@ class SubworkflowsTest(base.EngineTestCase):
|
|||||||
def test_subworkflow_environment_inheritance(self):
|
def test_subworkflow_environment_inheritance(self):
|
||||||
env = {'key1': 'abc'}
|
env = {'key1': 'abc'}
|
||||||
|
|
||||||
wf2_ex = self.engine.start_workflow('wb1.wf2', None, env=env)
|
wf2_ex = self.engine.start_workflow('wb1.wf2', '', None, env=env)
|
||||||
|
|
||||||
# Execution of 'wf2'.
|
# Execution of 'wf2'.
|
||||||
self.assertIsNotNone(wf2_ex)
|
self.assertIsNotNone(wf2_ex)
|
||||||
self.assertDictEqual({}, wf2_ex.input)
|
self.assertDictEqual({}, wf2_ex.input)
|
||||||
self.assertDictEqual({'env': env}, wf2_ex.params)
|
self.assertDictEqual(
|
||||||
|
{'env': env, 'namespace': ''},
|
||||||
|
wf2_ex.params
|
||||||
|
)
|
||||||
|
|
||||||
self._await(lambda: len(db_api.get_workflow_executions()) == 2, 0.5, 5)
|
self._await(lambda: len(db_api.get_workflow_executions()) == 2, 0.5, 5)
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ class TaskCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf_ex.id, states.RUNNING)
|
self.await_workflow_state(wf_ex.id, states.RUNNING)
|
||||||
|
|
||||||
@ -143,7 +143,7 @@ class TaskCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(workbook)
|
wb_service.create_workbook_v2(workbook)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', {})
|
wf_ex = self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf_ex.id, states.RUNNING)
|
self.await_workflow_state(wf_ex.id, states.RUNNING)
|
||||||
|
|
||||||
@ -219,7 +219,7 @@ class TaskCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf_ex.id, states.RUNNING)
|
self.await_workflow_state(wf_ex.id, states.RUNNING)
|
||||||
|
|
||||||
@ -308,7 +308,7 @@ class TaskCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(wb_def)
|
wb_service.create_workbook_v2(wb_def)
|
||||||
|
|
||||||
wf1_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf1_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
self.await_workflow_state(wf1_ex.id, states.RUNNING)
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ class TaskDefaultsDirectWorkflowEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -106,7 +106,7 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {}, task_name='task2')
|
wf_ex = self.engine.start_workflow('wf', '', {}, task_name='task2')
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -150,7 +150,7 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {}, task_name='task2')
|
wf_ex = self.engine.start_workflow('wf', '', {}, task_name='task2')
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -188,7 +188,7 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
time_before = dt.datetime.now()
|
time_before = dt.datetime.now()
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {}, task_name='task1')
|
wf_ex = self.engine.start_workflow('wf', '', {}, task_name='task1')
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -233,7 +233,7 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {}, task_name='task2')
|
wf_ex = self.engine.start_workflow('wf', '', {}, task_name='task2')
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ class TaskPublishTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
wb_service.create_workbook_v2(SIMPLE_WORKBOOK)
|
||||||
|
|
||||||
# Run workflow and fail task.
|
# Run workflow and fail task.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
|
@ -217,11 +217,11 @@ class TasksFunctionTest(base.EngineTestCase):
|
|||||||
def test_tasks_function(self):
|
def test_tasks_function(self):
|
||||||
wb_service.create_workbook_v2(WORKBOOK_WITH_EXPRESSIONS)
|
wb_service.create_workbook_v2(WORKBOOK_WITH_EXPRESSIONS)
|
||||||
# Start helping workflow executions.
|
# Start helping workflow executions.
|
||||||
wf1_ex = self.engine.start_workflow('wb.wf1_top_lvl', {})
|
wf1_ex = self.engine.start_workflow('wb.wf1_top_lvl', '', {})
|
||||||
wf2_ex = self.engine.start_workflow('wb.wf2_top_lvl', {})
|
wf2_ex = self.engine.start_workflow('wb.wf2_top_lvl', '', {})
|
||||||
wf3_ex = self.engine.start_workflow('wb.wf3_top_lvl', {})
|
wf3_ex = self.engine.start_workflow('wb.wf3_top_lvl', '', {})
|
||||||
wf4_ex = self.engine.start_workflow('wb.wf4_top_lvl', {})
|
wf4_ex = self.engine.start_workflow('wb.wf4_top_lvl', '', {})
|
||||||
wf5_ex = self.engine.start_workflow('wb.wf5_top_lvl', {})
|
wf5_ex = self.engine.start_workflow('wb.wf5_top_lvl', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf1_ex.id)
|
self.await_workflow_success(wf1_ex.id)
|
||||||
self.await_workflow_success(wf2_ex.id)
|
self.await_workflow_success(wf2_ex.id)
|
||||||
@ -232,6 +232,7 @@ class TasksFunctionTest(base.EngineTestCase):
|
|||||||
# Start test workflow execution
|
# Start test workflow execution
|
||||||
execution = self.engine.start_workflow(
|
execution = self.engine.start_workflow(
|
||||||
'wb.test_tasks_function',
|
'wb.test_tasks_function',
|
||||||
|
'',
|
||||||
{"wf1_wx_id": wf1_ex.id,
|
{"wf1_wx_id": wf1_ex.id,
|
||||||
"wf2_wx_id": wf2_ex.id,
|
"wf2_wx_id": wf2_ex.id,
|
||||||
"wf3_wx_id": wf3_ex.id,
|
"wf3_wx_id": wf3_ex.id,
|
||||||
|
@ -185,7 +185,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WB)
|
wb_service.create_workbook_v2(WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', WF_INPUT)
|
wf_ex = self.engine.start_workflow('wb.wf', '', WF_INPUT)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -241,7 +241,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -267,7 +267,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -315,7 +315,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(wb_text)
|
wb_service.create_workbook_v2(wb_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf', {})
|
wf_ex = self.engine.start_workflow('wb1.wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -332,7 +332,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_input.update({'greeting': 'Hello'})
|
wf_input.update({'greeting': 'Hello'})
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', wf_input)
|
wf_ex = self.engine.start_workflow('wb.wf', '', wf_input)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -360,7 +360,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_input = {'arrayI': ['a', 'b', 'c'], 'arrayJ': [1, 2, 3]}
|
wf_input = {'arrayI': ['a', 'b', 'c'], 'arrayJ': [1, 2, 3]}
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', wf_input)
|
wf_ex = self.engine.start_workflow('wb.wf', '', wf_input)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -389,7 +389,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WB_ACTION_CONTEXT)
|
wb_service.create_workbook_v2(WB_ACTION_CONTEXT)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', WF_INPUT_URLS)
|
wf_ex = self.engine.start_workflow('wb.wf', '', WF_INPUT_URLS)
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -454,7 +454,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_input = {'names_info': []}
|
wf_input = {'names_info': []}
|
||||||
wf_ex = self.engine.start_workflow('wb1.with_items', wf_input)
|
wf_ex = self.engine.start_workflow('wb1.with_items', '', wf_input)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -490,7 +490,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(wb_text)
|
wb_service.create_workbook_v2(wb_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb1.with_items', {})
|
wf_ex = self.engine.start_workflow('wb1.with_items', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -559,7 +559,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(wb_text)
|
wb_service.create_workbook_v2(wb_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb1.with_items', {})
|
wf_ex = self.engine.start_workflow('wb1.with_items', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -584,7 +584,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WB)
|
wb_service.create_workbook_v2(WB)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', WF_INPUT_ONE_ITEM)
|
wf_ex = self.engine.start_workflow('wb.wf', '', WF_INPUT_ONE_ITEM)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -627,7 +627,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_with_concurrency_1)
|
wf_service.create_workflows(wf_with_concurrency_1)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -720,7 +720,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {'concurrency': 2})
|
wf_ex = self.engine.start_workflow('wf', '', {'concurrency': 2})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -762,7 +762,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_with_concurrency_yaql)
|
wf_service.create_workflows(wf_with_concurrency_yaql)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {'concurrency': '2'})
|
wf_ex = self.engine.start_workflow('wf', '', {'concurrency': '2'})
|
||||||
|
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
'Invalid data type in ConcurrencyPolicy',
|
'Invalid data type in ConcurrencyPolicy',
|
||||||
@ -790,7 +790,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_with_concurrency_2)
|
wf_service.create_workflows(wf_with_concurrency_2)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -902,7 +902,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_with_concurrency_2_fail)
|
wf_service.create_workflows(wf_with_concurrency_2_fail)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('concurrency_test_fail', {})
|
wf_ex = self.engine.start_workflow('concurrency_test_fail', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -943,7 +943,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_with_concurrency_3)
|
wf_service.create_workflows(wf_with_concurrency_3)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('concurrency_test', {})
|
wf_ex = self.engine.start_workflow('concurrency_test', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||||
@ -1037,7 +1037,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_definition)
|
wf_service.create_workflows(wf_definition)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('concurrency_test', {})
|
wf_ex = self.engine.start_workflow('concurrency_test', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1079,7 +1079,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('with_items_retry', {})
|
wf_ex = self.engine.start_workflow('with_items_retry', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1124,7 +1124,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1159,7 +1159,12 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {}, env={'name': 'Mistral'})
|
wf_ex = self.engine.start_workflow(
|
||||||
|
'wf',
|
||||||
|
'',
|
||||||
|
{},
|
||||||
|
env={'name': 'Mistral'}
|
||||||
|
)
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1209,7 +1214,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(wb_text)
|
wb_service.create_workbook_v2(wb_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb1.with_items', {})
|
wf_ex = self.engine.start_workflow('wb1.with_items', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1279,7 +1284,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
names = ["Peter", "Susan", "Edmund", "Lucy", "Aslan", "Caspian"]
|
names = ["Peter", "Susan", "Edmund", "Lucy", "Aslan", "Caspian"]
|
||||||
wf_ex = self.engine.start_workflow('wb1.main', {'names': names})
|
wf_ex = self.engine.start_workflow('wb1.main', '', {'names': names})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -1349,7 +1354,7 @@ class WithItemsEngineTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(wb_text)
|
wb_service.create_workbook_v2(wb_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('test.with_items_default_bug', {})
|
wf_ex = self.engine.start_workflow('test.with_items_default_bug')
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.engine.stop_workflow(
|
self.engine.stop_workflow(
|
||||||
wf_ex.id,
|
wf_ex.id,
|
||||||
@ -85,7 +85,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf = wf_service.create_workflows(workflow)[0]
|
wf = wf_service.create_workflows(workflow)[0]
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
db_api.delete_workflow_definition(wf.id)
|
db_api.delete_workflow_definition(wf.id)
|
||||||
@ -117,7 +117,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.engine.pause_workflow(wf_ex.id)
|
self.engine.pause_workflow(wf_ex.id)
|
||||||
|
|
||||||
@ -168,7 +168,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(workflow)
|
wf_service.create_workflows(workflow)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -218,7 +218,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(workbook)
|
wb_service.create_workbook_v2(workbook)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', {})
|
wf_ex = self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
self.engine.stop_workflow(
|
self.engine.stop_workflow(
|
||||||
wf_ex.id,
|
wf_ex.id,
|
||||||
@ -284,7 +284,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(workbook)
|
wb_service.create_workbook_v2(workbook)
|
||||||
|
|
||||||
self.engine.start_workflow('wb.wf', {})
|
self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_execs = db_api.get_workflow_executions()
|
wf_execs = db_api.get_workflow_executions()
|
||||||
@ -351,7 +351,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
"""
|
"""
|
||||||
wb_service.create_workbook_v2(workbook)
|
wb_service.create_workbook_v2(workbook)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wb.wf', {})
|
wf_ex = self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
self.engine.stop_workflow(
|
self.engine.stop_workflow(
|
||||||
wf_ex.id,
|
wf_ex.id,
|
||||||
@ -421,7 +421,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(workbook)
|
wb_service.create_workbook_v2(workbook)
|
||||||
|
|
||||||
self.engine.start_workflow('wb.wf', {})
|
self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_execs = db_api.get_workflow_executions()
|
wf_execs = db_api.get_workflow_executions()
|
||||||
@ -500,7 +500,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(workbook)
|
wb_service.create_workbook_v2(workbook)
|
||||||
|
|
||||||
self.engine.start_workflow('wb.wf', {})
|
self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_execs = db_api.get_workflow_executions()
|
wf_execs = db_api.get_workflow_executions()
|
||||||
@ -585,7 +585,7 @@ class WorkflowCancelTest(base.EngineTestCase):
|
|||||||
|
|
||||||
wb_service.create_workbook_v2(workbook)
|
wb_service.create_workbook_v2(workbook)
|
||||||
|
|
||||||
self.engine.start_workflow('wb.wf', {})
|
self.engine.start_workflow('wb.wf', '', {})
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
wf_execs = db_api.get_workflow_executions()
|
wf_execs = db_api.get_workflow_executions()
|
||||||
|
@ -195,7 +195,7 @@ class WorkflowResumeTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(RESUME_WORKBOOK)
|
wb_service.create_workbook_v2(RESUME_WORKBOOK)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -230,6 +230,7 @@ class WorkflowResumeTest(base.EngineTestCase):
|
|||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'resume_reverse.wf',
|
'resume_reverse.wf',
|
||||||
|
'',
|
||||||
{},
|
{},
|
||||||
task_name='task2'
|
task_name='task2'
|
||||||
)
|
)
|
||||||
@ -265,7 +266,7 @@ class WorkflowResumeTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK_TWO_BRANCHES)
|
wb_service.create_workbook_v2(WORKBOOK_TWO_BRANCHES)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -295,7 +296,7 @@ class WorkflowResumeTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK_TWO_START_TASKS)
|
wb_service.create_workbook_v2(WORKBOOK_TWO_START_TASKS)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -332,7 +333,7 @@ class WorkflowResumeTest(base.EngineTestCase):
|
|||||||
wb_service.create_workbook_v2(WORKBOOK_DIFFERENT_TASK_STATES)
|
wb_service.create_workbook_v2(WORKBOOK_DIFFERENT_TASK_STATES)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -381,7 +382,7 @@ class WorkflowResumeTest(base.EngineTestCase):
|
|||||||
# Start and pause workflow.
|
# Start and pause workflow.
|
||||||
wb_service.create_workbook_v2(WORKBOOK_DIFFERENT_TASK_STATES)
|
wb_service.create_workbook_v2(WORKBOOK_DIFFERENT_TASK_STATES)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {})
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {})
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
@ -413,7 +414,7 @@ class WorkflowResumeTest(base.EngineTestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wb.wf1', {}, env=env)
|
wf_ex = self.engine.start_workflow('wb.wf1', '', {}, env=env)
|
||||||
|
|
||||||
self.await_workflow_paused(wf_ex.id)
|
self.await_workflow_paused(wf_ex.id)
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ class WorkflowStopTest(base.EngineTestCase):
|
|||||||
"""
|
"""
|
||||||
wf_service.create_workflows(WORKFLOW)
|
wf_service.create_workflows(WORKFLOW)
|
||||||
|
|
||||||
self.exec_id = self.engine.start_workflow('wf', {}).id
|
self.exec_id = self.engine.start_workflow('wf', '', {}).id
|
||||||
|
|
||||||
def test_stop_failed(self):
|
def test_stop_failed(self):
|
||||||
self.engine.stop_workflow(self.exec_id, states.SUCCESS, "Force stop")
|
self.engine.stop_workflow(self.exec_id, states.SUCCESS, "Force stop")
|
||||||
|
@ -51,7 +51,7 @@ class WorkflowVariablesTest(base.EngineTestCase):
|
|||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
# Start workflow.
|
# Start workflow.
|
||||||
wf_ex = self.engine.start_workflow('wf', {'param2': 'Renat'})
|
wf_ex = self.engine.start_workflow('wf', '', {'param2': 'Renat'})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -130,7 +130,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -165,7 +165,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -198,7 +198,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -243,7 +243,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_error(wf_ex.id)
|
self.await_workflow_error(wf_ex.id)
|
||||||
|
|
||||||
@ -275,7 +275,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -300,7 +300,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_service.create_workflows(wf_text)
|
wf_service.create_workflows(wf_text)
|
||||||
|
|
||||||
wf_ex = self.engine.start_workflow('wf', {})
|
wf_ex = self.engine.start_workflow('wf', '', {})
|
||||||
|
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
@ -337,6 +337,7 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
|
|
||||||
wf_ex = self.engine.start_workflow(
|
wf_ex = self.engine.start_workflow(
|
||||||
'wf',
|
'wf',
|
||||||
|
'',
|
||||||
{'k1': 'v1'},
|
{'k1': 'v1'},
|
||||||
param1='blablabla'
|
param1='blablabla'
|
||||||
)
|
)
|
||||||
@ -369,7 +370,10 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
|
|||||||
execution['input']
|
execution['input']
|
||||||
)
|
)
|
||||||
|
|
||||||
self.assertDictEqual({'param1': 'blablabla'}, execution['params'])
|
self.assertDictEqual(
|
||||||
|
{'param1': 'blablabla', 'namespace': ''},
|
||||||
|
execution['params']
|
||||||
|
)
|
||||||
|
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
wf_ex.created_at.isoformat(' '),
|
wf_ex.created_at.isoformat(' '),
|
||||||
|
@ -87,7 +87,7 @@ class LocalExecutorTestCase(base.ExecutorTestCase):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
wb_svc.create_workbook_v2(wb_def)
|
wb_svc.create_workbook_v2(wb_def)
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
@ -144,7 +144,7 @@ class LocalExecutorTestCase(base.ExecutorTestCase):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
wb_svc.create_workbook_v2(wb_def)
|
wb_svc.create_workbook_v2(wb_def)
|
||||||
wf_ex = self.engine.start_workflow('wb1.wf1', {})
|
wf_ex = self.engine.start_workflow('wb1.wf1', '', {})
|
||||||
self.await_workflow_success(wf_ex.id)
|
self.await_workflow_success(wf_ex.id)
|
||||||
|
|
||||||
with db_api.transaction():
|
with db_api.transaction():
|
||||||
|
@ -72,8 +72,8 @@ class MistralClientBase(rest_client.RestClient):
|
|||||||
self.action_executions = []
|
self.action_executions = []
|
||||||
self.event_triggers = []
|
self.event_triggers = []
|
||||||
|
|
||||||
def get_list_obj(self, name):
|
def get_list_obj(self, url_path):
|
||||||
resp, body = self.get(name)
|
resp, body = self.get(url_path)
|
||||||
|
|
||||||
return resp, json.loads(body)
|
return resp, json.loads(body)
|
||||||
|
|
||||||
|
@ -24,21 +24,30 @@ CONF = config.CONF
|
|||||||
|
|
||||||
class MistralClientV2(base.MistralClientBase):
|
class MistralClientV2(base.MistralClientBase):
|
||||||
|
|
||||||
def post_request(self, url, file_name):
|
def post_request(self, url_path, file_name):
|
||||||
headers = {"headers": "Content-Type:text/plain"}
|
headers = {"headers": "Content-Type:text/plain"}
|
||||||
|
|
||||||
return self.post(url, base.get_resource(file_name), headers=headers)
|
return self.post(
|
||||||
|
url_path,
|
||||||
|
base.get_resource(file_name),
|
||||||
|
headers=headers
|
||||||
|
)
|
||||||
|
|
||||||
def post_json(self, url, obj, extra_headers={}):
|
def get_request(self, url_path):
|
||||||
|
headers = {"headers": "Content-Type:application/json"}
|
||||||
|
|
||||||
|
return self.get(url_path, headers=headers)
|
||||||
|
|
||||||
|
def post_json(self, url_path, obj, extra_headers={}):
|
||||||
headers = {"Content-Type": "application/json"}
|
headers = {"Content-Type": "application/json"}
|
||||||
headers = dict(headers, **extra_headers)
|
headers = dict(headers, **extra_headers)
|
||||||
return self.post(url, json.dumps(obj), headers=headers)
|
return self.post(url_path, json.dumps(obj), headers=headers)
|
||||||
|
|
||||||
def update_request(self, url, file_name):
|
def update_request(self, url_path, file_name):
|
||||||
headers = {"headers": "Content-Type:text/plain"}
|
headers = {"headers": "Content-Type:text/plain"}
|
||||||
|
|
||||||
resp, body = self.put(
|
resp, body = self.put(
|
||||||
url,
|
url_path,
|
||||||
base.get_resource(file_name),
|
base.get_resource(file_name),
|
||||||
headers=headers
|
headers=headers
|
||||||
)
|
)
|
||||||
@ -64,26 +73,61 @@ class MistralClientV2(base.MistralClientBase):
|
|||||||
|
|
||||||
return resp, json.loads(body)
|
return resp, json.loads(body)
|
||||||
|
|
||||||
def create_workflow(self, yaml_file, scope=None):
|
def create_workflow(self, yaml_file, scope=None, namespace=None):
|
||||||
|
url_path = 'workflows?'
|
||||||
|
|
||||||
if scope:
|
if scope:
|
||||||
resp, body = self.post_request('workflows?scope=public', yaml_file)
|
url_path += 'scope=public&'
|
||||||
else:
|
|
||||||
resp, body = self.post_request('workflows', yaml_file)
|
if namespace:
|
||||||
|
url_path += 'namespace=' + namespace
|
||||||
|
|
||||||
|
resp, body = self.post_request(url_path, yaml_file)
|
||||||
|
|
||||||
for wf in json.loads(body)['workflows']:
|
for wf in json.loads(body)['workflows']:
|
||||||
self.workflows.append(wf['name'])
|
identifier = wf['id'] if namespace else wf['name']
|
||||||
|
self.workflows.append(identifier)
|
||||||
|
|
||||||
return resp, json.loads(body)
|
return resp, json.loads(body)
|
||||||
|
|
||||||
|
def get_workflow(self, wf_identifier, namespace=None):
|
||||||
|
|
||||||
|
url_path = 'workflows/' + wf_identifier
|
||||||
|
if namespace:
|
||||||
|
url_path += 'namespace=' + namespace
|
||||||
|
|
||||||
|
resp, body = self.get_request(url_path)
|
||||||
|
|
||||||
|
return resp, json.loads(body)
|
||||||
|
|
||||||
|
def update_workflow(self, file_name, namespace=None):
|
||||||
|
url_path = "workflows?"
|
||||||
|
|
||||||
|
if namespace:
|
||||||
|
url_path += 'namespace=' + namespace
|
||||||
|
|
||||||
|
return self.update_request(url_path, file_name=file_name)
|
||||||
|
|
||||||
def get_action_execution(self, action_execution_id):
|
def get_action_execution(self, action_execution_id):
|
||||||
return self.get('action_executions/%s' % action_execution_id)
|
return self.get('action_executions/%s' % action_execution_id)
|
||||||
|
|
||||||
def create_execution(self, identifier, wf_input=None, params=None):
|
def get_action_executions(self, task_id=None):
|
||||||
|
url_path = 'action_executions'
|
||||||
|
if task_id:
|
||||||
|
url_path += '?task_execution_id=%s' % task_id
|
||||||
|
|
||||||
|
return self.get_list_obj(url_path)
|
||||||
|
|
||||||
|
def create_execution(self, identifier, wf_namespace=None, wf_input=None,
|
||||||
|
params=None):
|
||||||
if uuidutils.is_uuid_like(identifier):
|
if uuidutils.is_uuid_like(identifier):
|
||||||
body = {"workflow_id": "%s" % identifier}
|
body = {"workflow_id": "%s" % identifier}
|
||||||
else:
|
else:
|
||||||
body = {"workflow_name": "%s" % identifier}
|
body = {"workflow_name": "%s" % identifier}
|
||||||
|
|
||||||
|
if wf_namespace:
|
||||||
|
body.update({'workflow_namespace': wf_namespace})
|
||||||
|
|
||||||
if wf_input:
|
if wf_input:
|
||||||
body.update({'input': json.dumps(wf_input)})
|
body.update({'input': json.dumps(wf_input)})
|
||||||
if params:
|
if params:
|
||||||
@ -100,6 +144,23 @@ class MistralClientV2(base.MistralClientBase):
|
|||||||
|
|
||||||
return resp, json.loads(body)
|
return resp, json.loads(body)
|
||||||
|
|
||||||
|
def get_execution(self, execution_id):
|
||||||
|
return self.get('executions/%s' % execution_id)
|
||||||
|
|
||||||
|
def get_executions(self, task_id):
|
||||||
|
url_path = 'executions'
|
||||||
|
if task_id:
|
||||||
|
url_path += '?task_execution_id=%s' % task_id
|
||||||
|
|
||||||
|
return self.get_list_obj(url_path)
|
||||||
|
|
||||||
|
def get_tasks(self, execution_id=None):
|
||||||
|
url_path = 'tasks'
|
||||||
|
if execution_id:
|
||||||
|
url_path += '?workflow_execution_id=%s' % execution_id
|
||||||
|
|
||||||
|
return self.get_list_obj(url_path)
|
||||||
|
|
||||||
def create_cron_trigger(self, name, wf_name, wf_input=None, pattern=None,
|
def create_cron_trigger(self, name, wf_name, wf_input=None, pattern=None,
|
||||||
first_time=None, count=None):
|
first_time=None, count=None):
|
||||||
post_body = {
|
post_body = {
|
||||||
@ -133,11 +194,8 @@ class MistralClientV2(base.MistralClientBase):
|
|||||||
return [t for t in all_tasks if t['workflow_name'] == wf_name]
|
return [t for t in all_tasks if t['workflow_name'] == wf_name]
|
||||||
|
|
||||||
def create_action_execution(self, request_body, extra_headers={}):
|
def create_action_execution(self, request_body, extra_headers={}):
|
||||||
resp, body = self.post_json(
|
resp, body = self.post_json('action_executions', request_body,
|
||||||
'action_executions',
|
extra_headers)
|
||||||
request_body,
|
|
||||||
extra_headers
|
|
||||||
)
|
|
||||||
|
|
||||||
params = json.loads(request_body.get('params', '{}'))
|
params = json.loads(request_body.get('params', '{}'))
|
||||||
if params.get('save_result', False):
|
if params.get('save_result', False):
|
||||||
|
@ -226,3 +226,31 @@ class ActionExecutionTestsV2(base.TestCase):
|
|||||||
self.assertEqual(201, resp.status)
|
self.assertEqual(201, resp.status)
|
||||||
output = json.loads(body['output'])
|
output = json.loads(body['output'])
|
||||||
self.assertEqual(200, output['result']['status'])
|
self.assertEqual(200, output['result']['status'])
|
||||||
|
|
||||||
|
@decorators.idempotent_id('9438e195-031c-4502-b216-6d72941ec281')
|
||||||
|
@decorators.attr(type='sanity')
|
||||||
|
def test_action_execution_of_workflow_within_namespace(self):
|
||||||
|
|
||||||
|
resp, body = self.client.create_workflow('wf_v2.yaml', namespace='abc')
|
||||||
|
wf_name = body['workflows'][0]['name']
|
||||||
|
wf_namespace = body['workflows'][0]['namespace']
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
resp, body = self.client.create_execution(
|
||||||
|
wf_name,
|
||||||
|
wf_namespace=wf_namespace
|
||||||
|
)
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
resp, body = self.client.get_list_obj('tasks')
|
||||||
|
self.assertEqual(200, resp.status)
|
||||||
|
task_id = body['tasks'][0]['id']
|
||||||
|
|
||||||
|
resp, body = self.client.get_list_obj(
|
||||||
|
'action_executions?include_output=true&task_execution_id=%s' %
|
||||||
|
task_id)
|
||||||
|
|
||||||
|
self.assertEqual(200, resp.status)
|
||||||
|
action_execution = body['action_executions'][0]
|
||||||
|
|
||||||
|
self.assertEqual(200, resp.status)
|
||||||
|
action_execution = body['action_executions'][0]
|
||||||
|
self.assertEqual(wf_namespace, action_execution['workflow_namespace'])
|
||||||
|
@ -133,9 +133,7 @@ class ActionTestsV2(base.TestCase):
|
|||||||
resp, body = self.client.create_action('action_v2.yaml')
|
resp, body = self.client.create_action('action_v2.yaml')
|
||||||
self.assertEqual(201, resp.status)
|
self.assertEqual(201, resp.status)
|
||||||
|
|
||||||
resp, body = self.client.get_list_obj(
|
resp, body = self.client.get_list_obj('actions?is_system=False')
|
||||||
'actions?is_system=False'
|
|
||||||
)
|
|
||||||
|
|
||||||
self.assertEqual(200, resp.status)
|
self.assertEqual(200, resp.status)
|
||||||
self.assertNotEmpty(body['actions'])
|
self.assertNotEmpty(body['actions'])
|
||||||
@ -149,9 +147,7 @@ class ActionTestsV2(base.TestCase):
|
|||||||
resp, body = self.client.create_action('action_v2.yaml')
|
resp, body = self.client.create_action('action_v2.yaml')
|
||||||
self.assertEqual(201, resp.status)
|
self.assertEqual(201, resp.status)
|
||||||
|
|
||||||
resp, body = self.client.get_list_obj(
|
resp, body = self.client.get_list_obj('actions?is_system=neq:False')
|
||||||
'actions?is_system=neq:False'
|
|
||||||
)
|
|
||||||
|
|
||||||
self.assertEqual(200, resp.status)
|
self.assertEqual(200, resp.status)
|
||||||
self.assertNotEmpty(body['actions'])
|
self.assertNotEmpty(body['actions'])
|
||||||
@ -169,8 +165,7 @@ class ActionTestsV2(base.TestCase):
|
|||||||
_, body = self.client.get_object('actions', created_acts[0])
|
_, body = self.client.get_object('actions', created_acts[0])
|
||||||
time = body['created_at']
|
time = body['created_at']
|
||||||
resp, body = self.client.get_list_obj(
|
resp, body = self.client.get_list_obj(
|
||||||
'actions?created_at=in:' + time.replace(' ', '%20')
|
'actions?created_at=in:' + time.replace(' ', '%20'))
|
||||||
)
|
|
||||||
|
|
||||||
self.assertEqual(200, resp.status)
|
self.assertEqual(200, resp.status)
|
||||||
action_names = [action['name'] for action in body['actions']]
|
action_names = [action['name'] for action in body['actions']]
|
||||||
|
@ -107,7 +107,7 @@ class EventTriggerTestsV2(base.TestCase):
|
|||||||
@decorators.attr(type='negative')
|
@decorators.attr(type='negative')
|
||||||
@decorators.idempotent_id('56b90a90-9ff3-42f8-a9eb-04a77198710e')
|
@decorators.idempotent_id('56b90a90-9ff3-42f8-a9eb-04a77198710e')
|
||||||
def test_get_nonexistent_event_trigger(self):
|
def test_get_nonexistent_event_trigger(self):
|
||||||
fake_id = '123e4567-e89b-12d3-a456-426655440000'
|
fake_id = '3771c152-d1a7-4a82-8a50-c79d122012dc'
|
||||||
|
|
||||||
self.assertRaises(exceptions.NotFound,
|
self.assertRaises(exceptions.NotFound,
|
||||||
self.client.get_object,
|
self.client.get_object,
|
||||||
|
@ -19,6 +19,8 @@ from tempest.lib import exceptions
|
|||||||
from mistral import utils
|
from mistral import utils
|
||||||
from mistral_tempest_tests.tests import base
|
from mistral_tempest_tests.tests import base
|
||||||
|
|
||||||
|
import json
|
||||||
|
|
||||||
|
|
||||||
class ExecutionTestsV2(base.TestCase):
|
class ExecutionTestsV2(base.TestCase):
|
||||||
|
|
||||||
@ -72,8 +74,7 @@ class ExecutionTestsV2(base.TestCase):
|
|||||||
self.assertIn(exec_id_2, [ex['id'] for ex in body['executions']])
|
self.assertIn(exec_id_2, [ex['id'] for ex in body['executions']])
|
||||||
|
|
||||||
resp, body = self.client.get_list_obj(
|
resp, body = self.client.get_list_obj(
|
||||||
'executions?limit=1&sort_keys=workflow_name&sort_dirs=asc'
|
'executions?limit=1&sort_keys=workflow_name&sort_dirs=asc')
|
||||||
)
|
|
||||||
|
|
||||||
self.assertEqual(200, resp.status)
|
self.assertEqual(200, resp.status)
|
||||||
self.assertEqual(1, len(body['executions']))
|
self.assertEqual(1, len(body['executions']))
|
||||||
@ -127,8 +128,8 @@ class ExecutionTestsV2(base.TestCase):
|
|||||||
def test_create_execution_for_reverse_wf(self):
|
def test_create_execution_for_reverse_wf(self):
|
||||||
resp, body = self.client.create_execution(
|
resp, body = self.client.create_execution(
|
||||||
self.reverse_wf['name'],
|
self.reverse_wf['name'],
|
||||||
{self.reverse_wf['input']: "Bye"},
|
wf_input={self.reverse_wf['input']: "Bye"},
|
||||||
{"task_name": "goodbye"})
|
params={"task_name": "goodbye"})
|
||||||
|
|
||||||
exec_id = body['id']
|
exec_id = body['id']
|
||||||
self.assertEqual(201, resp.status)
|
self.assertEqual(201, resp.status)
|
||||||
@ -327,3 +328,91 @@ class ExecutionTestsV2(base.TestCase):
|
|||||||
'executions',
|
'executions',
|
||||||
exec_id
|
exec_id
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@decorators.idempotent_id('a882876b-7565-4f7f-9714-d99032ffaabb')
|
||||||
|
@decorators.attr(type='sanity')
|
||||||
|
def test_workflow_execution_of_nested_workflows_within_namespace(self):
|
||||||
|
low_wf = 'for_wf_namespace/lowest_level_wf.yaml'
|
||||||
|
middle_wf = 'for_wf_namespace/middle_wf.yaml'
|
||||||
|
top_wf = 'for_wf_namespace/top_level_wf.yaml'
|
||||||
|
|
||||||
|
resp, wf = self.client.create_workflow(low_wf)
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
|
||||||
|
namespace = 'abc'
|
||||||
|
resp, wf = self.client.create_workflow(low_wf, namespace=namespace)
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
|
||||||
|
resp, wf = self.client.create_workflow(middle_wf)
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
|
||||||
|
resp, wf = self.client.create_workflow(top_wf)
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
|
||||||
|
resp, wf = self.client.create_workflow(top_wf, namespace=namespace)
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
|
||||||
|
wf_name = wf['workflows'][0]['name']
|
||||||
|
resp, top_execution = self.client.create_execution(wf_name, namespace)
|
||||||
|
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
self.assertEqual('RUNNING', top_execution['state'])
|
||||||
|
self.assertEqual(wf_name, top_execution['workflow_name'])
|
||||||
|
self.assertEqual(wf_name, top_execution['workflow_name'])
|
||||||
|
self.assertEqual(namespace, top_execution['workflow_namespace'])
|
||||||
|
|
||||||
|
self.client.wait_execution(top_execution, target_state='SUCCESS')
|
||||||
|
|
||||||
|
self.assertEqual(
|
||||||
|
namespace,
|
||||||
|
json.loads(top_execution['params'])['namespace']
|
||||||
|
)
|
||||||
|
|
||||||
|
resp, tasks = self.client.get_tasks(top_execution['id'])
|
||||||
|
top_task = tasks['tasks'][0]
|
||||||
|
|
||||||
|
self.assertEqual(wf_name, top_task['workflow_name'])
|
||||||
|
self.assertEqual(namespace, top_task['workflow_namespace'])
|
||||||
|
|
||||||
|
resp, executions = self.client.get_executions(top_task['id'])
|
||||||
|
middle_execution = executions['executions'][0]
|
||||||
|
|
||||||
|
self.assertEqual('middle_wf', middle_execution['workflow_name'])
|
||||||
|
self.assertEqual('', middle_execution['workflow_namespace'])
|
||||||
|
|
||||||
|
self.assertEqual(
|
||||||
|
namespace,
|
||||||
|
json.loads(middle_execution['params'])['namespace']
|
||||||
|
)
|
||||||
|
|
||||||
|
resp, tasks = self.client.get_tasks(middle_execution['id'])
|
||||||
|
middle_task = tasks['tasks'][0]
|
||||||
|
|
||||||
|
self.assertEqual('middle_wf', middle_task['workflow_name'])
|
||||||
|
self.assertEqual('', middle_task['workflow_namespace'])
|
||||||
|
|
||||||
|
resp, executions = self.client.get_executions(middle_task['id'])
|
||||||
|
lowest_execution = executions['executions'][0]
|
||||||
|
|
||||||
|
self.assertEqual('lowest_level_wf', lowest_execution['workflow_name'])
|
||||||
|
self.assertEqual(namespace, lowest_execution['workflow_namespace'])
|
||||||
|
|
||||||
|
self.assertEqual(
|
||||||
|
namespace,
|
||||||
|
json.loads(lowest_execution['params'])['namespace']
|
||||||
|
)
|
||||||
|
|
||||||
|
resp, tasks = self.client.get_tasks(lowest_execution['id'])
|
||||||
|
lowest_task = tasks['tasks'][0]
|
||||||
|
|
||||||
|
self.assertEqual('lowest_level_wf', lowest_task['workflow_name'])
|
||||||
|
self.assertEqual(namespace, lowest_task['workflow_namespace'])
|
||||||
|
|
||||||
|
resp, action_executions = self.client.get_action_executions(
|
||||||
|
lowest_task['id']
|
||||||
|
)
|
||||||
|
|
||||||
|
action_execution = action_executions['action_executions'][0]
|
||||||
|
|
||||||
|
self.assertEqual('lowest_level_wf', action_execution['workflow_name'])
|
||||||
|
self.assertEqual(namespace, action_execution['workflow_namespace'])
|
||||||
|
@ -63,8 +63,7 @@ class TasksTestsV2(base.TestCase):
|
|||||||
@decorators.idempotent_id('3230d694-40fd-4094-ad12-024f40a21b94')
|
@decorators.idempotent_id('3230d694-40fd-4094-ad12-024f40a21b94')
|
||||||
def test_get_tasks_of_execution(self):
|
def test_get_tasks_of_execution(self):
|
||||||
resp, body = self.client.get_list_obj(
|
resp, body = self.client.get_list_obj(
|
||||||
'tasks?workflow_execution_id=%s' % self.execution_id
|
'tasks?workflow_execution_id=%s' % self.execution_id)
|
||||||
)
|
|
||||||
|
|
||||||
self.assertEqual(200, resp.status)
|
self.assertEqual(200, resp.status)
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
|
@ -242,6 +242,58 @@ class WorkflowTestsV2(base.TestCase):
|
|||||||
self.assertEqual(200, resp.status)
|
self.assertEqual(200, resp.status)
|
||||||
self.assertEqual(name, body['workflows'][0]['name'])
|
self.assertEqual(name, body['workflows'][0]['name'])
|
||||||
|
|
||||||
|
@decorators.attr(type='sanity')
|
||||||
|
@decorators.idempotent_id('42f5d135-a2b8-4a31-8135-c5ce8c5f1ed5')
|
||||||
|
def test_workflow_within_namespace(self):
|
||||||
|
self.useFixture(lockutils.LockFixture('mistral-workflow'))
|
||||||
|
|
||||||
|
namespace = 'abc'
|
||||||
|
resp, body = self.client.create_workflow(
|
||||||
|
'single_wf.yaml',
|
||||||
|
namespace=namespace
|
||||||
|
)
|
||||||
|
name = body['workflows'][0]['name']
|
||||||
|
id = body['workflows'][0]['id']
|
||||||
|
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
self.assertEqual(name, body['workflows'][0]['name'])
|
||||||
|
|
||||||
|
resp, body = self.client.get_workflow(
|
||||||
|
id
|
||||||
|
)
|
||||||
|
|
||||||
|
self.assertEqual(namespace, body['namespace'])
|
||||||
|
|
||||||
|
resp, body = self.client.update_workflow('single_wf.yaml', namespace)
|
||||||
|
|
||||||
|
self.assertEqual(200, resp.status)
|
||||||
|
self.assertEqual(name, body['workflows'][0]['name'])
|
||||||
|
self.assertEqual(namespace, body['workflows'][0]['namespace'])
|
||||||
|
|
||||||
|
namespace = 'abc2'
|
||||||
|
resp, body = self.client.create_workflow(
|
||||||
|
'single_wf.yaml',
|
||||||
|
namespace=namespace
|
||||||
|
)
|
||||||
|
name = body['workflows'][0]['name']
|
||||||
|
id = body['workflows'][0]['id']
|
||||||
|
|
||||||
|
self.assertEqual(201, resp.status)
|
||||||
|
self.assertEqual(name, body['workflows'][0]['name'])
|
||||||
|
|
||||||
|
resp, body = self.client.get_workflow(id)
|
||||||
|
|
||||||
|
self.assertEqual(namespace, body['namespace'])
|
||||||
|
|
||||||
|
self.assertRaises(exceptions.NotFound, self.client.get_workflow, name)
|
||||||
|
|
||||||
|
self.client.create_workflow(
|
||||||
|
'single_wf.yaml'
|
||||||
|
)
|
||||||
|
|
||||||
|
resp, body = self.client.get_workflow(id)
|
||||||
|
self.assertEqual(200, resp.status)
|
||||||
|
|
||||||
@decorators.attr(type='sanity')
|
@decorators.attr(type='sanity')
|
||||||
@decorators.idempotent_id('02bc1fc3-c31a-4e37-bb3d-eda46818505c')
|
@decorators.idempotent_id('02bc1fc3-c31a-4e37-bb3d-eda46818505c')
|
||||||
def test_get_workflow_definition(self):
|
def test_get_workflow_definition(self):
|
||||||
@ -280,6 +332,15 @@ class WorkflowTestsV2(base.TestCase):
|
|||||||
self.assertRaises(exceptions.NotFound, self.client.get_object,
|
self.assertRaises(exceptions.NotFound, self.client.get_object,
|
||||||
'workflows', 'nonexist')
|
'workflows', 'nonexist')
|
||||||
|
|
||||||
|
exception = self.assertRaises(
|
||||||
|
exceptions.NotFound,
|
||||||
|
self.client.get_workflow,
|
||||||
|
'nonexist_wf',
|
||||||
|
'nonexist_namespace'
|
||||||
|
)
|
||||||
|
self.assertIn('nonexist_wf', str(exception))
|
||||||
|
self.assertIn('nonexist_namespace', str(exception))
|
||||||
|
|
||||||
@decorators.attr(type='negative')
|
@decorators.attr(type='negative')
|
||||||
@decorators.idempotent_id('6b917213-7f11-423a-8fe0-55795dcf0fb2')
|
@decorators.idempotent_id('6b917213-7f11-423a-8fe0-55795dcf0fb2')
|
||||||
def test_double_create_workflows(self):
|
def test_double_create_workflows(self):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user