#29068 closed Bug (needsinfo)
Django urlpatterns has limit of allowed urls with namespace?
Description ¶
I'm currently working on a huge site with a huge number of distinct urlpatterns, that are categorized in a tree pattern, starting with the project's urls.py and then going down the tree with include statements (sometimes namespaced), which in turn have their own include statements, untill we are about 4 branches away.
Next to that many urlpatterns are conditional (if settings.DEBUG ... if 'app_x' in installed_apps... etc).
I have had issues with one of the last urlpatterns in the project's urls.py a lot on my production environment, on apache + wsgi ('No reverse found'), which I couldn't reproduce on my development machine with runserver . It has a namespace set. It was not a user facing endpoint so I forgot about it.
Now I have added another urlpattern to the project's urls.py with a namespace and it too gives 'No reverse found' (it is reversed in a middleware, so the app does not start at all, making it easier to test).
When I place the last urlpattern up in the projects urls.py that it comes as the second urlpattern, the app does start, so it looks like the urlpatterns are going into some kind of limit.
For your reference this is the code that works when placed after the first urlpatterns definition, but not when placed at the bottom (I think nothing special).
if 'silk' in settings.INSTALLED_APPS: urlpatterns += [url(r'^silk/', include('silk.urls', namespace='silk'))]
Change History (2)
comment:1 by , 7 years ago
Resolution: | → needsinfo |
---|---|
Status: | new → closed |
comment:2 by , 7 years ago
I have found the issue.
I had an url of type:
url(r'^aboutus/$', RedirectView.as_view(url=reverse('aboutus'), permanent=True)) in my urls.py. Where the 'aboutus' url was defined somewhere above in an included sub urls.py.
With the Django testserver this works fine, but in production (Apache + WSGI) it gives a lot of seemingly strange errors, such as unexpected 404s and (after including the package silk) unexpected 500 errors. The strange thing was, that it did work on the test server (also Apache + WSGI), but not on the live server. It gave me some pulled out grey hair, so I hope someone finds this anwers when the need is there.
You should debug your code and confirm that Django is at fault before creating a ticket. We can't triage the issue without a sample project to reproduce it. Please reopen the ticket if you can do one of those things. Thanks.