Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
D
django-rest-framework
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
django-rest-framework
Commits
5e1ed0aa
Commit
5e1ed0aa
authored
Oct 31, 2014
by
Tom Christie
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1922 from JonesChi/fix_follow
Fix follow does not work on get of APIRequestFactory
parents
0b864acd
2dfe75c2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
93 additions
and
0 deletions
+93
-0
rest_framework/test.py
+46
-0
tests/test_testing.py
+47
-0
No files found.
rest_framework/test.py
View file @
5e1ed0aa
...
...
@@ -156,6 +156,52 @@ class APIClient(APIRequestFactory, DjangoClient):
kwargs
.
update
(
self
.
_credentials
)
return
super
(
APIClient
,
self
)
.
request
(
**
kwargs
)
def
get
(
self
,
path
,
data
=
None
,
follow
=
False
,
**
extra
):
response
=
super
(
APIClient
,
self
)
.
get
(
path
,
data
=
data
,
**
extra
)
if
follow
:
response
=
self
.
_handle_redirects
(
response
,
**
extra
)
return
response
def
post
(
self
,
path
,
data
=
None
,
format
=
None
,
content_type
=
None
,
follow
=
False
,
**
extra
):
response
=
super
(
APIClient
,
self
)
.
post
(
path
,
data
=
data
,
format
=
format
,
content_type
=
content_type
,
**
extra
)
if
follow
:
response
=
self
.
_handle_redirects
(
response
,
**
extra
)
return
response
def
put
(
self
,
path
,
data
=
None
,
format
=
None
,
content_type
=
None
,
follow
=
False
,
**
extra
):
response
=
super
(
APIClient
,
self
)
.
put
(
path
,
data
=
data
,
format
=
format
,
content_type
=
content_type
,
**
extra
)
if
follow
:
response
=
self
.
_handle_redirects
(
response
,
**
extra
)
return
response
def
patch
(
self
,
path
,
data
=
None
,
format
=
None
,
content_type
=
None
,
follow
=
False
,
**
extra
):
response
=
super
(
APIClient
,
self
)
.
patch
(
path
,
data
=
data
,
format
=
format
,
content_type
=
content_type
,
**
extra
)
if
follow
:
response
=
self
.
_handle_redirects
(
response
,
**
extra
)
return
response
def
delete
(
self
,
path
,
data
=
None
,
format
=
None
,
content_type
=
None
,
follow
=
False
,
**
extra
):
response
=
super
(
APIClient
,
self
)
.
delete
(
path
,
data
=
data
,
format
=
format
,
content_type
=
content_type
,
**
extra
)
if
follow
:
response
=
self
.
_handle_redirects
(
response
,
**
extra
)
return
response
def
options
(
self
,
path
,
data
=
None
,
format
=
None
,
content_type
=
None
,
follow
=
False
,
**
extra
):
response
=
super
(
APIClient
,
self
)
.
options
(
path
,
data
=
data
,
format
=
format
,
content_type
=
content_type
,
**
extra
)
if
follow
:
response
=
self
.
_handle_redirects
(
response
,
**
extra
)
return
response
def
logout
(
self
):
self
.
_credentials
=
{}
return
super
(
APIClient
,
self
)
.
logout
()
...
...
tests/test_testing.py
View file @
5e1ed0aa
...
...
@@ -5,6 +5,7 @@ from django.conf.urls import patterns, url
from
io
import
BytesIO
from
django.contrib.auth.models
import
User
from
django.shortcuts
import
redirect
from
django.test
import
TestCase
from
rest_framework.decorators
import
api_view
from
rest_framework.response
import
Response
...
...
@@ -28,10 +29,16 @@ def session_view(request):
})
@api_view
([
'GET'
,
'POST'
,
'PUT'
,
'PATCH'
,
'DELETE'
,
'OPTIONS'
])
def
redirect_view
(
request
):
return
redirect
(
'/view/'
)
urlpatterns
=
patterns
(
''
,
url
(
r'^view/$'
,
view
),
url
(
r'^session-view/$'
,
session_view
),
url
(
r'^redirect-view/$'
,
redirect_view
),
)
...
...
@@ -111,6 +118,46 @@ class TestAPITestClient(TestCase):
response
=
self
.
client
.
get
(
'/view/'
)
self
.
assertEqual
(
response
.
data
[
'auth'
],
b
''
)
def
test_follow_redirect
(
self
):
"""
Follow redirect by setting follow argument.
"""
response
=
self
.
client
.
get
(
'/redirect-view/'
)
self
.
assertEqual
(
response
.
status_code
,
302
)
response
=
self
.
client
.
get
(
'/redirect-view/'
,
follow
=
True
)
self
.
assertIsNotNone
(
response
.
redirect_chain
)
self
.
assertEqual
(
response
.
status_code
,
200
)
response
=
self
.
client
.
post
(
'/redirect-view/'
)
self
.
assertEqual
(
response
.
status_code
,
302
)
response
=
self
.
client
.
post
(
'/redirect-view/'
,
follow
=
True
)
self
.
assertIsNotNone
(
response
.
redirect_chain
)
self
.
assertEqual
(
response
.
status_code
,
200
)
response
=
self
.
client
.
put
(
'/redirect-view/'
)
self
.
assertEqual
(
response
.
status_code
,
302
)
response
=
self
.
client
.
put
(
'/redirect-view/'
,
follow
=
True
)
self
.
assertIsNotNone
(
response
.
redirect_chain
)
self
.
assertEqual
(
response
.
status_code
,
200
)
response
=
self
.
client
.
patch
(
'/redirect-view/'
)
self
.
assertEqual
(
response
.
status_code
,
302
)
response
=
self
.
client
.
patch
(
'/redirect-view/'
,
follow
=
True
)
self
.
assertIsNotNone
(
response
.
redirect_chain
)
self
.
assertEqual
(
response
.
status_code
,
200
)
response
=
self
.
client
.
delete
(
'/redirect-view/'
)
self
.
assertEqual
(
response
.
status_code
,
302
)
response
=
self
.
client
.
delete
(
'/redirect-view/'
,
follow
=
True
)
self
.
assertIsNotNone
(
response
.
redirect_chain
)
self
.
assertEqual
(
response
.
status_code
,
200
)
response
=
self
.
client
.
options
(
'/redirect-view/'
)
self
.
assertEqual
(
response
.
status_code
,
302
)
response
=
self
.
client
.
options
(
'/redirect-view/'
,
follow
=
True
)
self
.
assertIsNotNone
(
response
.
redirect_chain
)
self
.
assertEqual
(
response
.
status_code
,
200
)
class
TestAPIRequestFactory
(
TestCase
):
def
test_csrf_exempt_by_default
(
self
):
...
...
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