#25624: Autoreload fails if jinja2.ModuleLoader used
----------------------------+----------------------------------------------
     Reporter:  svartalf    |      Owner:  nobody
         Type:  Bug         |     Status:  new
    Component:  Utilities   |    Version:  1.8
     Severity:  Normal      |   Keywords:  autoreload, jinja2, ModuleLoader
 Triage Stage:  Unreviewed  |  Has patch:  0
Easy pickings:  0           |      UI/UX:  0
----------------------------+----------------------------------------------
 It happens because `jinja2.ModuleLoader` injects a weakref to a fake
 module into a sys.modules:
 
https://github.com/mitsuhiko/jinja2/blob/f6b654de615de61a9ca79e7ccecf7b4a8bf90ec0/jinja2/loaders.py#L439-L449

 So, because weakref is not a hashable object, autoreload fails.

 {{{
 Traceback (most recent call last):
   File "bug/manage.py", line 10, in <module>
     execute_from_command_line(sys.argv)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-
 packages/django/core/management/__init__.py", line 351, in
 execute_from_command_line
     utility.execute()
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-
 packages/django/core/management/__init__.py", line 343, in execute
     self.fetch_command(subcommand).run_from_argv(self.argv)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-
 packages/django/core/management/base.py", line 394, in run_from_argv
     self.execute(*args, **cmd_options)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-
 packages/django/core/management/commands/runserver.py", line 49, in
 execute
     super(Command, self).execute(*args, **options)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-
 packages/django/core/management/base.py", line 445, in execute
     output = self.handle(*args, **options)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-
 packages/django/core/management/commands/runserver.py", line 88, in handle
     self.run(**options)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-
 packages/django/core/management/commands/runserver.py", line 97, in run
     autoreload.main(self.inner_run, None, options)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-packages/django/utils/autoreload.py",
 line 336, in main
     reloader(wrapped_main_func, args, kwargs)
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-packages/django/utils/autoreload.py",
 line 302, in python_reloader
     reloader_thread()
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-packages/django/utils/autoreload.py",
 line 278, in reloader_thread
     change = fn()
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-packages/django/utils/autoreload.py",
 line 207, in code_changed
     for filename in gen_filenames():
   File "/home/svartalf/projects/dj-module-loader-
 bug/.env/local/lib/python2.7/site-packages/django/utils/autoreload.py",
 line 94, in gen_filenames
     module_values = set(sys.modules.values())
 TypeError: unhashable type: 'weakproxy'
 }}}

 I had reproduced this bug with a clean project and following environment:
 {{{
 Python 2.7.6

 $ pip freeze
 Django==1.8.5
 Jinja2==2.7.3
 MarkupSafe==0.23
 argparse==1.2.1
 wsgiref==0.1.2
 }}}

 Template settings:
 {{{
 template_loader = jinja2.ModuleLoader('compiled_templates')
 TEMPLATES = [
     {
         'BACKEND': 'django.template.backends.jinja2.Jinja2',
         'DIRS': [os.path.join(BASE_DIR, 'templates')],
         'APP_DIRS': True,
         'OPTIONS': {
             'loader': template_loader,
         },
     },
 ]
 }}}

 P.S. Not sure if it is an "Utilities" or a "Template system" component.

--
Ticket URL: <https://code.djangoproject.com/ticket/25624>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.

-- 
You received this message because you are subscribed to the Google Groups 
"Django updates" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To post to this group, send email to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/django-updates/051.ca9b9550e670d7a2223416be7d504fbf%40djangoproject.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to