1
0
mirror of https://github.com/django/django.git synced 2025-01-03 06:55:47 +00:00

Fixed #30453 -- Fixed crash of simple_tag() and inclusion_tag() when function is wrapped.

getfullargspec() doesn't work with wrapped functions.
This commit is contained in:
Batuhan Taşkaya 2019-05-07 05:02:08 +03:00 committed by Mariusz Felisiak
parent 8d010f3986
commit 5c19274643
3 changed files with 24 additions and 3 deletions

View File

@ -107,6 +107,7 @@ answer newbie questions, and generally made Django that much better:
Bastian Kleineidam <calvin@debian.org> Bastian Kleineidam <calvin@debian.org>
Batiste Bieler <batiste.bieler@gmail.com> Batiste Bieler <batiste.bieler@gmail.com>
Batman Batman
Batuhan Taskaya <batuhanosmantaskaya@gmail.com>
Baurzhan Ismagulov <ibr@radix50.net> Baurzhan Ismagulov <ibr@radix50.net>
Ben Dean Kawamura <ben.dean.kawamura@gmail.com> Ben Dean Kawamura <ben.dean.kawamura@gmail.com>
Ben Firshman <ben@firshman.co.uk> Ben Firshman <ben@firshman.co.uk>

View File

@ -1,6 +1,6 @@
import functools import functools
from importlib import import_module from importlib import import_module
from inspect import getfullargspec from inspect import getfullargspec, unwrap
from django.utils.html import conditional_escape from django.utils.html import conditional_escape
from django.utils.itercompat import is_iterable from django.utils.itercompat import is_iterable
@ -106,7 +106,7 @@ class Library:
return 'world' return 'world'
""" """
def dec(func): def dec(func):
params, varargs, varkw, defaults, kwonly, kwonly_defaults, _ = getfullargspec(func) params, varargs, varkw, defaults, kwonly, kwonly_defaults, _ = getfullargspec(unwrap(func))
function_name = (name or getattr(func, '_decorated_function', func).__name__) function_name = (name or getattr(func, '_decorated_function', func).__name__)
@functools.wraps(func) @functools.wraps(func)
@ -143,7 +143,7 @@ class Library:
return {'choices': choices} return {'choices': choices}
""" """
def dec(func): def dec(func):
params, varargs, varkw, defaults, kwonly, kwonly_defaults, _ = getfullargspec(func) params, varargs, varkw, defaults, kwonly, kwonly_defaults, _ = getfullargspec(unwrap(func))
function_name = (name or getattr(func, '_decorated_function', func).__name__) function_name = (name or getattr(func, '_decorated_function', func).__name__)
@functools.wraps(func) @functools.wraps(func)

View File

@ -1,3 +1,5 @@
import functools
from django.template import Library from django.template import Library
from django.template.base import Node from django.template.base import Node
from django.test import SimpleTestCase from django.test import SimpleTestCase
@ -61,6 +63,15 @@ class InclusionTagRegistrationTests(SimpleTestCase):
return '' return ''
self.assertIn('name', self.library.tags) self.assertIn('name', self.library.tags)
def test_inclusion_tag_wrapped(self):
@self.library.inclusion_tag('template.html')
@functools.lru_cache(maxsize=32)
def func():
return ''
func_wrapped = self.library.tags['func'].__wrapped__
self.assertIs(func_wrapped, func)
self.assertTrue(hasattr(func_wrapped, 'cache_info'))
class SimpleTagRegistrationTests(SimpleTestCase): class SimpleTagRegistrationTests(SimpleTestCase):
@ -90,6 +101,15 @@ class SimpleTagRegistrationTests(SimpleTestCase):
with self.assertRaisesMessage(ValueError, msg): with self.assertRaisesMessage(ValueError, msg):
self.library.simple_tag('invalid') self.library.simple_tag('invalid')
def test_simple_tag_wrapped(self):
@self.library.simple_tag
@functools.lru_cache(maxsize=32)
def func():
return ''
func_wrapped = self.library.tags['func'].__wrapped__
self.assertIs(func_wrapped, func)
self.assertTrue(hasattr(func_wrapped, 'cache_info'))
class TagRegistrationTests(SimpleTestCase): class TagRegistrationTests(SimpleTestCase):