Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
D
django
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
django
Commits
7f76251f
Kaydet (Commit)
7f76251f
authored
Haz 22, 2014
tarafından
Anubhav Joshi
Kaydeden (comit)
Tim Graham
Haz 23, 2014
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Refactored common code in handlers/base.py and urlresolvers.py
üst
bcd2e6c6
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
21 additions
and
42 deletions
+21
-42
base.py
django/core/handlers/base.py
+14
-23
urlresolvers.py
django/core/urlresolvers.py
+1
-13
tests.py
tests/urlpatterns_reverse/tests.py
+6
-6
No files found.
django/core/handlers/base.py
Dosyayı görüntüle @
7f76251f
...
...
@@ -70,6 +70,16 @@ class BaseHandler(object):
view
=
transaction
.
atomic
(
using
=
db
.
alias
)(
view
)
return
view
def
get_exception_response
(
self
,
request
,
resolver
,
status_code
):
try
:
callback
,
param_dict
=
resolver
.
resolve_error_handler
(
status_code
)
response
=
callback
(
request
,
**
param_dict
)
except
:
signals
.
got_request_exception
.
send
(
sender
=
self
.
__class__
,
request
=
request
)
response
=
self
.
handle_uncaught_exception
(
request
,
resolver
,
sys
.
exc_info
())
return
response
def
get_response
(
self
,
request
):
"Returns an HttpResponse object for the given HttpRequest"
...
...
@@ -151,12 +161,7 @@ class BaseHandler(object):
if
settings
.
DEBUG
:
response
=
debug
.
technical_404_response
(
request
,
e
)
else
:
try
:
callback
,
param_dict
=
resolver
.
resolve404
()
response
=
callback
(
request
,
**
param_dict
)
except
:
signals
.
got_request_exception
.
send
(
sender
=
self
.
__class__
,
request
=
request
)
response
=
self
.
handle_uncaught_exception
(
request
,
resolver
,
sys
.
exc_info
())
response
=
self
.
get_exception_response
(
request
,
resolver
,
404
)
except
PermissionDenied
:
logger
.
warning
(
...
...
@@ -165,14 +170,7 @@ class BaseHandler(object):
'status_code'
:
403
,
'request'
:
request
})
try
:
callback
,
param_dict
=
resolver
.
resolve403
()
response
=
callback
(
request
,
**
param_dict
)
except
:
signals
.
got_request_exception
.
send
(
sender
=
self
.
__class__
,
request
=
request
)
response
=
self
.
handle_uncaught_exception
(
request
,
resolver
,
sys
.
exc_info
())
response
=
self
.
get_exception_response
(
request
,
resolver
,
403
)
except
SuspiciousOperation
as
e
:
# The request logger receives events for any problematic request
...
...
@@ -186,14 +184,7 @@ class BaseHandler(object):
'request'
:
request
})
try
:
callback
,
param_dict
=
resolver
.
resolve400
()
response
=
callback
(
request
,
**
param_dict
)
except
:
signals
.
got_request_exception
.
send
(
sender
=
self
.
__class__
,
request
=
request
)
response
=
self
.
handle_uncaught_exception
(
request
,
resolver
,
sys
.
exc_info
())
response
=
self
.
get_exception_response
(
request
,
resolver
,
400
)
except
SystemExit
:
# Allow sys.exit() to actually exit. See tickets #1023 and #4701
...
...
@@ -251,7 +242,7 @@ class BaseHandler(object):
if
resolver
.
urlconf_module
is
None
:
six
.
reraise
(
*
exc_info
)
# Return an HttpResponse that displays a friendly error message.
callback
,
param_dict
=
resolver
.
resolve
500
(
)
callback
,
param_dict
=
resolver
.
resolve
_error_handler
(
500
)
return
callback
(
request
,
**
param_dict
)
def
apply_response_fixes
(
self
,
request
,
response
):
...
...
django/core/urlresolvers.py
Dosyayı görüntüle @
7f76251f
...
...
@@ -393,7 +393,7 @@ class RegexURLResolver(LocaleRegexProvider):
raise
ImproperlyConfigured
(
msg
.
format
(
name
=
self
.
urlconf_name
))
return
patterns
def
_resolve_special
(
self
,
view_type
):
def
resolve_error_handler
(
self
,
view_type
):
callback
=
getattr
(
self
.
urlconf_module
,
'handler
%
s'
%
view_type
,
None
)
if
not
callback
:
# No handler specified in file; use default
...
...
@@ -402,18 +402,6 @@ class RegexURLResolver(LocaleRegexProvider):
callback
=
getattr
(
urls
,
'handler
%
s'
%
view_type
)
return
get_callable
(
callback
),
{}
def
resolve400
(
self
):
return
self
.
_resolve_special
(
'400'
)
def
resolve403
(
self
):
return
self
.
_resolve_special
(
'403'
)
def
resolve404
(
self
):
return
self
.
_resolve_special
(
'404'
)
def
resolve500
(
self
):
return
self
.
_resolve_special
(
'500'
)
def
reverse
(
self
,
lookup_view
,
*
args
,
**
kwargs
):
return
self
.
_reverse_with_prefix
(
lookup_view
,
''
,
*
args
,
**
kwargs
)
...
...
tests/urlpatterns_reverse/tests.py
Dosyayı görüntüle @
7f76251f
...
...
@@ -614,15 +614,15 @@ class ErrorHandlerResolutionTests(TestCase):
def
test_named_handlers
(
self
):
handler
=
(
empty_view
,
{})
self
.
assertEqual
(
self
.
resolver
.
resolve
400
(
),
handler
)
self
.
assertEqual
(
self
.
resolver
.
resolve
404
(
),
handler
)
self
.
assertEqual
(
self
.
resolver
.
resolve
500
(
),
handler
)
self
.
assertEqual
(
self
.
resolver
.
resolve
_error_handler
(
400
),
handler
)
self
.
assertEqual
(
self
.
resolver
.
resolve
_error_handler
(
404
),
handler
)
self
.
assertEqual
(
self
.
resolver
.
resolve
_error_handler
(
500
),
handler
)
def
test_callable_handers
(
self
):
handler
=
(
empty_view
,
{})
self
.
assertEqual
(
self
.
callable_resolver
.
resolve
400
(
),
handler
)
self
.
assertEqual
(
self
.
callable_resolver
.
resolve
404
(
),
handler
)
self
.
assertEqual
(
self
.
callable_resolver
.
resolve
500
(
),
handler
)
self
.
assertEqual
(
self
.
callable_resolver
.
resolve
_error_handler
(
400
),
handler
)
self
.
assertEqual
(
self
.
callable_resolver
.
resolve
_error_handler
(
404
),
handler
)
self
.
assertEqual
(
self
.
callable_resolver
.
resolve
_error_handler
(
500
),
handler
)
@override_settings
(
ROOT_URLCONF
=
'urlpatterns_reverse.urls_without_full_import'
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment