Files
deb-python-taskflow/taskflow/tests/unit/test_task.py
Ivan A. Melnikov 1bfed651ae Allow to specify default provides at task definition
It is now possible to specify what task provides when task class
(deriving from taskflow.task.Task) is defined, using 'default_provides'
class attribute or property. This specification may still be overridden
when task instance is created via 'provides' constructor parameter.

Change-Id: If300c3a35807422d06c0196e84891faebde83c02
2013-09-19 11:09:05 +04:00

169 lines
5.0 KiB
Python

# -*- coding: utf-8 -*-
# vim: tabstop=4 shiftwidth=4 softtabstop=4
# Copyright (C) 2013 Yahoo! Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from taskflow import task
from taskflow import test
class MyTask(task.Task):
def execute(self, context, spam, eggs):
pass
class KwargsTask(task.Task):
def execute(self, spam, **kwargs):
pass
class DefaultProvidesTask(task.Task):
default_provides = 'def'
def execute(self):
return None
class TaskTestCase(test.TestCase):
def test_passed_name(self):
my_task = MyTask(name='my name')
self.assertEquals(my_task.name, 'my name')
def test_generated_name(self):
my_task = MyTask()
self.assertEquals(my_task.name,
'%s.%s' % (__name__, 'MyTask'))
def test_no_provides(self):
my_task = MyTask()
self.assertEquals(my_task.save_as, {})
def test_provides(self):
my_task = MyTask(provides='food')
self.assertEquals(my_task.save_as, {'food': None})
def test_multi_provides(self):
my_task = MyTask(provides=('food', 'water'))
self.assertEquals(my_task.save_as, {'food': 0, 'water': 1})
def test_unpack(self):
my_task = MyTask(provides=('food',))
self.assertEquals(my_task.save_as, {'food': 0})
def test_bad_provides(self):
with self.assertRaisesRegexp(TypeError, '^Task provides'):
MyTask(provides=object())
def test_requires_by_default(self):
my_task = MyTask()
self.assertEquals(my_task.rebind, {
'spam': 'spam',
'eggs': 'eggs',
'context': 'context'
})
def test_requires_amended(self):
my_task = MyTask(requires=('spam', 'eggs'))
self.assertEquals(my_task.rebind, {
'spam': 'spam',
'eggs': 'eggs',
'context': 'context'
})
def test_requires_explicit(self):
my_task = MyTask(auto_extract=False,
requires=('spam', 'eggs', 'context'))
self.assertEquals(my_task.rebind, {
'spam': 'spam',
'eggs': 'eggs',
'context': 'context'
})
def test_requires_explicit_not_enough(self):
with self.assertRaisesRegexp(ValueError, '^Missing arguments'):
MyTask(auto_extract=False, requires=('spam', 'eggs'))
def test_rebind_all_args(self):
my_task = MyTask(rebind={'spam': 'a', 'eggs': 'b', 'context': 'c'})
self.assertEquals(my_task.rebind, {
'spam': 'a',
'eggs': 'b',
'context': 'c'
})
def test_rebind_partial(self):
my_task = MyTask(rebind={'spam': 'a', 'eggs': 'b'})
self.assertEquals(my_task.rebind, {
'spam': 'a',
'eggs': 'b',
'context': 'context'
})
def test_rebind_unknown(self):
with self.assertRaisesRegexp(ValueError, '^Extra arguments'):
MyTask(rebind={'foo': 'bar'})
def test_rebind_unknown_kwargs(self):
task = KwargsTask(rebind={'foo': 'bar'})
self.assertEquals(task.rebind, {
'foo': 'bar',
'spam': 'spam'
})
def test_rebind_list_all(self):
my_task = MyTask(rebind=('a', 'b', 'c'))
self.assertEquals(my_task.rebind, {
'context': 'a',
'spam': 'b',
'eggs': 'c'
})
def test_rebind_list_partial(self):
my_task = MyTask(rebind=('a', 'b'))
self.assertEquals(my_task.rebind, {
'context': 'a',
'spam': 'b',
'eggs': 'eggs'
})
def test_rebind_list_more(self):
with self.assertRaisesRegexp(ValueError, '^Extra arguments'):
MyTask(rebind=('a', 'b', 'c', 'd'))
def test_rebind_list_more_kwargs(self):
task = KwargsTask(rebind=('a', 'b', 'c'))
self.assertEquals(task.rebind, {
'spam': 'a',
'b': 'b',
'c': 'c'
})
def test_rebind_list_bad_value(self):
with self.assertRaisesRegexp(TypeError, '^Invalid rebind value:'):
MyTask(rebind=object())
def test_default_provides(self):
task = DefaultProvidesTask()
self.assertEquals(task.provides, set(['def']))
self.assertEquals(task.save_as, {'def': None})
def test_default_provides_can_be_overridden(self):
task = DefaultProvidesTask(provides=('spam', 'eggs'))
self.assertEquals(task.provides, set(['spam', 'eggs']))
self.assertEquals(task.save_as, {'spam': 0, 'eggs': 1})