Change namings in functor_task and add docs to its __init__
Change-Id: If260cfbeeee60e177c832a143f8ddc9f6fc71600
This commit is contained in:
@@ -3,6 +3,7 @@
|
|||||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||||
|
|
||||||
# Copyright (C) 2012-2013 Yahoo! Inc. All Rights Reserved.
|
# Copyright (C) 2012-2013 Yahoo! Inc. All Rights Reserved.
|
||||||
|
# Copyright (C) 2013 AT&T Labs Inc. All Rights Reserved.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
# 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
|
# not use this file except in compliance with the License. You may obtain
|
||||||
@@ -17,6 +18,7 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import inspect
|
import inspect
|
||||||
|
|
||||||
from taskflow import task as base
|
from taskflow import task as base
|
||||||
|
|
||||||
# These arguments are ones that we will skip when parsing for requirements
|
# These arguments are ones that we will skip when parsing for requirements
|
||||||
@@ -24,12 +26,12 @@ from taskflow import task as base
|
|||||||
AUTO_ARGS = ('self', 'context', 'cls')
|
AUTO_ARGS = ('self', 'context', 'cls')
|
||||||
|
|
||||||
|
|
||||||
def _take_arg(a):
|
def _filter_arg(arg):
|
||||||
if a in AUTO_ARGS:
|
if arg in AUTO_ARGS:
|
||||||
return False
|
return False
|
||||||
# In certain decorator cases it seems like we get the function to be
|
# In certain decorator cases it seems like we get the function to be
|
||||||
# decorated as an argument, we don't want to take that as a real argument.
|
# decorated as an argument, we don't want to take that as a real argument.
|
||||||
if not isinstance(a, basestring):
|
if not isinstance(arg, basestring):
|
||||||
return False
|
return False
|
||||||
return True
|
return True
|
||||||
|
|
||||||
@@ -40,31 +42,45 @@ class FunctorTask(base.Task):
|
|||||||
Take any callable and make a task from it.
|
Take any callable and make a task from it.
|
||||||
"""
|
"""
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _callable_name(function):
|
def _get_callable_name(execute_with):
|
||||||
"""Generate a name from callable"""
|
"""Generate a name from callable"""
|
||||||
im_class = getattr(function, 'im_class', None)
|
im_class = getattr(execute_with, 'im_class', None)
|
||||||
if im_class is not None:
|
if im_class is not None:
|
||||||
parts = (im_class.__module__, im_class.__name__, function.__name__)
|
parts = (im_class.__module__, im_class.__name__,
|
||||||
|
execute_with.__name__)
|
||||||
else:
|
else:
|
||||||
parts = (function.__module__, function.__name__)
|
parts = (execute_with.__module__, execute_with.__name__)
|
||||||
return '.'.join(parts)
|
return '.'.join(parts)
|
||||||
|
|
||||||
def __init__(self, execute_with, **kwargs):
|
def __init__(self, execute_with, **kwargs):
|
||||||
|
"""Initialize FunctorTask instance with given callable and kwargs
|
||||||
|
|
||||||
|
:param execute_with: the callable
|
||||||
|
:param kwargs: reserved keywords (all optional) are
|
||||||
|
name: name of the task, default None (auto generate)
|
||||||
|
task_id: id of the task, default None (auto generate)
|
||||||
|
revert_with: the callable to revert, default None
|
||||||
|
version: version of the task, default Task's version 1.0
|
||||||
|
optionals: optionals of the task, default ()
|
||||||
|
provides: provides of the task, default ()
|
||||||
|
requires: requires of the task, default ()
|
||||||
|
auto_extract: auto extract execute_with's args and put it into
|
||||||
|
requires, default True
|
||||||
|
"""
|
||||||
name = kwargs.pop('name', None)
|
name = kwargs.pop('name', None)
|
||||||
|
task_id = kwargs.pop('task_id', None)
|
||||||
if name is None:
|
if name is None:
|
||||||
name = self._callable_name(execute_with)
|
name = self._get_callable_name(execute_with)
|
||||||
super(FunctorTask, self).__init__(name, kwargs.pop('task_id', None))
|
super(FunctorTask, self).__init__(name, task_id)
|
||||||
self._execute_with = execute_with
|
self._execute_with = execute_with
|
||||||
self._revert_with = kwargs.pop('revert_with', None)
|
self._revert_with = kwargs.pop('revert_with', None)
|
||||||
self.version = kwargs.pop('version', self.version)
|
self.version = kwargs.pop('version', self.version)
|
||||||
|
self.optional.update(kwargs.pop('optional', ()))
|
||||||
|
self.provides.update(kwargs.pop('provides', ()))
|
||||||
self.requires.update(kwargs.pop('requires', ()))
|
self.requires.update(kwargs.pop('requires', ()))
|
||||||
if kwargs.pop('auto_extract', True):
|
if kwargs.pop('auto_extract', True):
|
||||||
f_args = inspect.getargspec(execute_with).args
|
f_args = inspect.getargspec(execute_with).args
|
||||||
self.requires.update([a for a in f_args if _take_arg(a)])
|
self.requires.update([arg for arg in f_args if _filter_arg(arg)])
|
||||||
|
|
||||||
self.optional.update(kwargs.pop('optional', ()))
|
|
||||||
self.provides.update(kwargs.pop('provides', ()))
|
|
||||||
if kwargs:
|
if kwargs:
|
||||||
raise TypeError('__init__() got an unexpected keyword argument %r'
|
raise TypeError('__init__() got an unexpected keyword argument %r'
|
||||||
% kwargs.keys[0])
|
% kwargs.keys[0])
|
||||||
|
|||||||
Reference in New Issue
Block a user