From 7b655134655755e1fc97a3720837fa92374bc786 Mon Sep 17 00:00:00 2001 From: "Kacper Kowalik (Xarthisius)" Date: Wed, 29 May 2019 11:04:45 -0500 Subject: [PATCH 1/2] Add a test case for kwargs in chained tasks --- .../integration_test_endpoints/server/raw.py | 23 +++++++++++++++++++ tests/integration/test_celery.py | 11 +++++++++ 2 files changed, 34 insertions(+) diff --git a/tests/integration/integration_test_endpoints/server/raw.py b/tests/integration/integration_test_endpoints/server/raw.py index d08e199b..d38f1728 100644 --- a/tests/integration/integration_test_endpoints/server/raw.py +++ b/tests/integration/integration_test_endpoints/server/raw.py @@ -40,6 +40,8 @@ def __init__(self): self.test_celery_task_revoke_in_queue) self.route('POST', ('test_task_chained', ), self.test_celery_task_chained) + self.route('POST', ('test_task_chained_with_kwargs', ), + self.test_celery_task_chained_with_kwargs) self.route('POST', ('test_task_chained_bad_token_fails', ), self.test_celery_task_chained_bad_token_fails) @@ -212,6 +214,27 @@ def test_celery_task_chained(self, params): return [job_1, job_2, job_3] + @access.token + @filtermodel(model='job', plugin='jobs') + @describeRoute( + Description('Test chained celery tasks with kwargs') + ) + def test_celery_task_chained_with_kwargs(self, params): + jobModel = ModelImporter.model('job', 'jobs') + user = self.getCurrentUser() + # F(F(F(6))) --> F(F(8)) --> F(21) --> 10946 + result = ( + fibonacci.s(6, foo=1, bar=2) | + fibonacci.s(baz=3) | + fibonacci.s(last_but_not_least=4) + ).delay() + result.wait(timeout=10) + job_1 = result.job + job_2 = jobModel.load(job_1['parentId'], user=user) + job_3 = jobModel.load(job_2['parentId'], user=user) + + return [job_1, job_2, job_3] + @access.token @filtermodel(model='job', plugin='jobs') @describeRoute( diff --git a/tests/integration/test_celery.py b/tests/integration/test_celery.py index 67983792..adfde2a1 100644 --- a/tests/integration/test_celery.py +++ b/tests/integration/test_celery.py @@ -128,6 +128,17 @@ def test_celery_chained_tasks(session): assert jobs[0]['parentId'] == jobs[1]['_id'] +def test_celery_chained_tasks_with_kwargs(session): + url = 'integration_tests/celery/test_task_chained_with_kwargs' + r = session.post(url) + assert r.status_code == 200, r.content + jobs = r.json() + # Check if kwargs are correctly set + assert jobs[2]['kwargs'] == dict(foo=1, bar=2) + assert jobs[1]['kwargs'] == dict(baz=3) + assert jobs[0]['kwargs'] == dict(last_but_not_least=4) + + def test_celery_chained_task_bad_token_fails(session): r = session.post('integration_tests/celery/test_task_chained_bad_token_fails') assert r.status_code == 200, r.content From a63529fec4ad9cd3d68689f2d3caa0c0b358901a Mon Sep 17 00:00:00 2001 From: "Kacper Kowalik (Xarthisius)" Date: Wed, 29 May 2019 12:18:24 -0500 Subject: [PATCH 2/2] Properly serialize task kwargs in a nongirder context. Fixes #337 --- girder_worker/context/nongirder_context.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/girder_worker/context/nongirder_context.py b/girder_worker/context/nongirder_context.py index 87aa78ff..8abcf75c 100644 --- a/girder_worker/context/nongirder_context.py +++ b/girder_worker/context/nongirder_context.py @@ -49,7 +49,7 @@ def create_task_job(job_defaults, sender=None, body=None, 'public': headers.pop('girder_job_public', job_defaults.get('girder_job_public', '')), 'args': json.dumps(task_args), - 'kwargs': task_kwargs, + 'kwargs': json.dumps(task_kwargs), 'otherFields': json.dumps( dict(celeryTaskId=headers['id'], celeryParentTaskId=parent_task.request.id,