2022-10-12 10:19:53 -04:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import unittest
|
|
|
|
import pickle
|
|
|
|
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..', '..', '..'))
|
|
|
|
from .TaskSpecTest import TaskSpecTest
|
2022-11-04 09:33:42 -04:00
|
|
|
from SpiffWorkflow.specs.Celery import Celery
|
|
|
|
from SpiffWorkflow.specs.WorkflowSpec import WorkflowSpec
|
2022-10-12 10:19:53 -04:00
|
|
|
from SpiffWorkflow.operators import Attrib
|
|
|
|
from SpiffWorkflow.serializer.dict import DictionarySerializer
|
|
|
|
from base64 import b64encode
|
|
|
|
|
|
|
|
|
|
|
|
class CeleryTest(TaskSpecTest):
|
|
|
|
CORRELATE = Celery
|
|
|
|
|
|
|
|
def create_instance(self):
|
|
|
|
if 'testtask' in self.wf_spec.task_specs:
|
|
|
|
del self.wf_spec.task_specs['testtask']
|
|
|
|
return Celery(self.wf_spec,
|
|
|
|
'testtask', 'call.name',
|
|
|
|
call_args=[Attrib('the_attribute'), 1],
|
|
|
|
description='foo',
|
|
|
|
named_kw=[],
|
|
|
|
dict_kw={}
|
|
|
|
)
|
|
|
|
|
|
|
|
def testTryFire(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def testRetryFire(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def testSerializationWithoutKwargs(self):
|
|
|
|
new_wf_spec = WorkflowSpec()
|
|
|
|
serializer = DictionarySerializer()
|
|
|
|
nokw = Celery(self.wf_spec, 'testnokw', 'call.name',
|
|
|
|
call_args=[Attrib('the_attribute'), 1])
|
|
|
|
data = nokw.serialize(serializer)
|
|
|
|
nokw2 = Celery.deserialize(serializer, new_wf_spec, data)
|
|
|
|
self.assertDictEqual(nokw.kwargs, nokw2.kwargs)
|
|
|
|
|
|
|
|
kw = Celery(self.wf_spec, 'testkw', 'call.name',
|
|
|
|
call_args=[Attrib('the_attribute'), 1],
|
|
|
|
some_arg={"key": "value"})
|
|
|
|
data = kw.serialize(serializer)
|
|
|
|
kw2 = Celery.deserialize(serializer, new_wf_spec, data)
|
|
|
|
self.assertDictEqual(kw.kwargs, kw2.kwargs)
|
|
|
|
|
|
|
|
# Has kwargs, but they belong to TaskSpec
|
|
|
|
kw_defined = Celery(self.wf_spec, 'testkwdef', 'call.name',
|
|
|
|
call_args=[Attrib('the_attribute'), 1],
|
|
|
|
some_ref=Attrib('value'),
|
|
|
|
defines={"key": "value"})
|
|
|
|
data = kw_defined.serialize(serializer)
|
|
|
|
kw_defined2 = Celery.deserialize(serializer, new_wf_spec, data)
|
|
|
|
self.assertIsInstance(kw_defined2.kwargs['some_ref'], Attrib)
|
|
|
|
|
|
|
|
args = [b64encode(pickle.dumps(v))
|
|
|
|
for v in [Attrib('the_attribute'), 'ip', 'dc455016e2e04a469c01a866f11c0854']]
|
|
|
|
|
|
|
|
data = {'R': b64encode(pickle.dumps('1'))}
|
|
|
|
# Comes from live data. Bug not identified, but there we are...
|
|
|
|
data = {'inputs': ['Wait:1'], 'lookahead': 2, 'description': '',
|
|
|
|
'outputs': [], 'args': args,
|
|
|
|
'manual': False,
|
|
|
|
'data': data, 'locks': [], 'pre_assign': [],
|
|
|
|
'call': 'call.x',
|
|
|
|
'internal': False, 'post_assign': [], 'id': 8,
|
|
|
|
'result_key': None, 'defines': data,
|
|
|
|
'class': 'SpiffWorkflow.specs.Celery.Celery',
|
|
|
|
'name': 'RS1:1'}
|
|
|
|
Celery.deserialize(serializer, new_wf_spec, data)
|
|
|
|
|
|
|
|
|
|
|
|
def suite():
|
|
|
|
try:
|
|
|
|
import celery
|
|
|
|
except ImportError:
|
|
|
|
print("WARNING: Celery not found, not all tests are running!")
|
|
|
|
return lambda x: None
|
|
|
|
else:
|
|
|
|
return unittest.TestLoader().loadTestsFromTestCase(CeleryTest)
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.TextTestRunner(verbosity=2).run(suite())
|