test_annotations.py 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. from __future__ import absolute_import
  2. from celery.app.annotations import MapAnnotation, prepare
  3. from celery.task import task
  4. from celery.utils.imports import qualname
  5. from celery.tests.utils import Case
  6. @task
  7. def add(x, y):
  8. return x + y
  9. @task
  10. def mul(x, y):
  11. return x * y
  12. class MyAnnotation(object):
  13. foo = 65
  14. class test_MapAnnotation(Case):
  15. def test_annotate(self):
  16. x = MapAnnotation({add.name: {"foo": 1}})
  17. self.assertDictEqual(x.annotate(add), {"foo": 1})
  18. self.assertIsNone(x.annotate(mul))
  19. def test_annotate_any(self):
  20. x = MapAnnotation({'*': {"foo": 2}})
  21. self.assertDictEqual(x.annotate_any(), {"foo": 2})
  22. x = MapAnnotation()
  23. self.assertIsNone(x.annotate_any())
  24. class test_prepare(Case):
  25. def test_dict_to_MapAnnotation(self):
  26. x = prepare({add.name: {"foo": 3}})
  27. self.assertIsInstance(x[0], MapAnnotation)
  28. def test_returns_list(self):
  29. self.assertListEqual(prepare(1), [1])
  30. self.assertListEqual(prepare([1]), [1])
  31. self.assertListEqual(prepare((1, )), [1])
  32. self.assertEqual(prepare(None), ())
  33. def test_evalutes_qualnames(self):
  34. self.assertEqual(prepare(qualname(MyAnnotation))[0]().foo, 65)
  35. self.assertEqual(prepare([qualname(MyAnnotation)])[0]().foo, 65)