You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The celery task did still work, but logs contained a background exception:
Traceback (most recent call last):
File "/openedx/venv/lib/python3.8/site-packages/celery/utils/dispatch/signal.py", line 276, in send
response = receiver(signal=self, sender=sender, **named)
File "/openedx/venv/lib/python3.8/site-packages/user_tasks/signals.py", line 215, in start_user_task
sender.status.start()
File "/openedx/venv/lib/python3.8/site-packages/user_tasks/tasks.py", line 84, in status
name = self.generate_name(arguments_dict)
File "/openedx/edx-platform/openedx/core/djangoapps/content_libraries/tasks.py", line 274, in generate_name
key = arguments_dict['dest_block_key']
KeyError: 'dest_block_key'
Digging in, I found that this key is missing because the django-user-tasks-defined function arguments_as_dict was not properly returning a dictionary. The underlying failure seems to be that in the call inspect.getcallargs(cls.run, ...), cls.run does not always actually equal the function defining the celery task (update_children_task), but rather the stub method Task.run. I imagine that this has to do with @set_code_owner_attribute iterfering with the introspection that @shared_task and/or django-user-tasks relies upon.
I am not exactly sure what the react or impact of this bug is. I do know for sure that developers should not use @set_code_owner_attribute on any Django user task function.
The text was updated successfully, but these errors were encountered:
kdmccormick
changed the title
@set_code_owner_attribute clashes with user tasks
@set_code_owner_attribute clashes with django-user-tasks
Oct 5, 2023
(I'm not sure whether this is an issue with edx-django-utils, with django-user-tasks, or both...)
Adding
@set_code_owner_attribute
and@shared_task
to the same function causes errors when that function is an instance ofUserTask
.For this reason, the import_olx and export_olx tasks in edx-platform do not use
@set_code_owner_attribute
: https://github.com/openedx/edx-platform/blob/db252978f3f315c896b07443f70febdc043faee4/cms/djangoapps/contentstore/tasks.py#L310-L311I recently (accidentally) confirmed this issue... I was working on
update_children_task
in the content_libraries djangoapp, and had this:The celery task did still work, but logs contained a background exception:
Digging in, I found that this key is missing because the django-user-tasks-defined function
arguments_as_dict
was not properly returning a dictionary. The underlying failure seems to be that in the callinspect.getcallargs(cls.run, ...)
,cls.run
does not always actually equal the function defining the celery task (update_children_task
), but rather the stub methodTask.run
. I imagine that this has to do with@set_code_owner_attribute
iterfering with the introspection that@shared_task
and/or django-user-tasks relies upon.I am not exactly sure what the react or impact of this bug is. I do know for sure that developers should not use
@set_code_owner_attribute
on any Django user task function.The text was updated successfully, but these errors were encountered: