Kaydet (Commit) 4e400dcb authored tarafından Tim Graham's avatar Tim Graham

Refs #22384 -- Readded RegexURLResolver.reverse().

It was removed in 785cc71d only because
it was untested and unused in Django itself, however, some third-party
apps use it.
üst 2eb7cb2f
......@@ -323,6 +323,9 @@ class RegexURLResolver(LocaleRegexProvider):
callback = getattr(urls, 'handler%s' % view_type)
return get_callable(callback), {}
def reverse(self, lookup_view, *args, **kwargs):
return self._reverse_with_prefix(lookup_view, '', *args, **kwargs)
def _reverse_with_prefix(self, lookup_view, _prefix, *args, **kwargs):
if args and kwargs:
raise ValueError("Don't mix *args and **kwargs in call to reverse()!")
......
......@@ -364,6 +364,12 @@ class ResolverTests(unittest.TestCase):
except TypeError:
self.fail('Failed to coerce lazy object to text')
def test_resolver_reverse(self):
resolver = get_resolver('urlpatterns_reverse.named_urls')
self.assertEqual(resolver.reverse('named-url1'), '')
self.assertEqual(resolver.reverse('named-url2', 'arg'), 'extra/arg/')
self.assertEqual(resolver.reverse('named-url2', extra='arg'), 'extra/arg/')
def test_non_regex(self):
"""
Verifies that we raise a Resolver404 if what we are resolving doesn't
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment