From b0b4aac555711ae9116f9b54c24ec7e43a0971e9 Mon Sep 17 00:00:00 2001 From: Eric Brandwein Date: Thu, 20 Sep 2018 15:24:36 -0300 Subject: [PATCH] Fixed #29775 -- Fixed URL converters in a nested namespaced path. When using include() without namespaces of some urlpatterns that have an include() with namespace, the converters of the parent include() weren't being used to convert the arguments of reverse(). --- AUTHORS | 1 + django/urls/resolvers.py | 2 ++ tests/urlpatterns/path_base64_urls.py | 8 ++++++++ tests/urlpatterns/tests.py | 7 +++++++ 4 files changed, 18 insertions(+) diff --git a/AUTHORS b/AUTHORS index 75c894021fe..ac4ab8410ea 100644 --- a/AUTHORS +++ b/AUTHORS @@ -255,6 +255,7 @@ answer newbie questions, and generally made Django that much better: enlight Enrico Eric Boersma + Eric Brandwein Eric Floehr Eric Florenzano Eric Holscher diff --git a/django/urls/resolvers.py b/django/urls/resolvers.py index 91d21c9da99..4f2aefc9b0d 100644 --- a/django/urls/resolvers.py +++ b/django/urls/resolvers.py @@ -469,6 +469,8 @@ class URLResolver: ) ) for namespace, (prefix, sub_pattern) in url_pattern.namespace_dict.items(): + current_converters = url_pattern.pattern.converters + sub_pattern.pattern.converters.update(current_converters) namespaces[namespace] = (p_pattern + prefix, sub_pattern) for app_name, namespace_list in url_pattern.app_dict.items(): apps.setdefault(app_name, []).extend(namespace_list) diff --git a/tests/urlpatterns/path_base64_urls.py b/tests/urlpatterns/path_base64_urls.py index 9b69f929fe5..afd11ac9f60 100644 --- a/tests/urlpatterns/path_base64_urls.py +++ b/tests/urlpatterns/path_base64_urls.py @@ -4,8 +4,16 @@ from . import converters, views register_converter(converters.Base64Converter, 'base64') +subsubpatterns = [ + path('/', views.empty_view, name='subsubpattern-base64'), +] + subpatterns = [ path('/', views.empty_view, name='subpattern-base64'), + path( + '/', + include((subsubpatterns, 'second-layer-namespaced-base64'), 'instance-ns-base64') + ), ] urlpatterns = [ diff --git a/tests/urlpatterns/tests.py b/tests/urlpatterns/tests.py index b3d97ec5b9a..299258e56f8 100644 --- a/tests/urlpatterns/tests.py +++ b/tests/urlpatterns/tests.py @@ -70,6 +70,13 @@ class SimplifiedURLTests(SimpleTestCase): url = reverse(url_name, kwargs=kwargs) self.assertEqual(url, expected) + @override_settings(ROOT_URLCONF='urlpatterns.path_base64_urls') + def test_converter_reverse_with_second_layer_instance_namespace(self): + kwargs = included_kwargs.copy() + kwargs['last_value'] = b'world' + url = reverse('instance-ns-base64:subsubpattern-base64', kwargs=kwargs) + self.assertEqual(url, '/base64/aGVsbG8=/subpatterns/d29ybGQ=/d29ybGQ=/') + def test_path_inclusion_is_matchable(self): match = resolve('/included_urls/extra/something/') self.assertEqual(match.url_name, 'inner-extra')