Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
GraceDB Server
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Container Registry
Model registry
Operate
Environments
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
IGWN Computing and Software
GraceDB
GraceDB Server
Commits
75453786
Commit
75453786
authored
6 years ago
by
Tanner Prestegard
Committed by
GraceDB
6 years ago
Browse files
Options
Downloads
Patches
Plain Diff
Unit tests for custom api_reverse function
parent
1d57437e
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
gracedb/api/tests/test_utils.py
+138
-0
138 additions, 0 deletions
gracedb/api/tests/test_utils.py
with
138 additions
and
0 deletions
gracedb/api/tests/test_utils.py
0 → 100644
+
138
−
0
View file @
75453786
from
django.urls
import
reverse
as
django_reverse
from
rest_framework.test
import
APIRequestFactory
,
APISimpleTestCase
from
api.utils
import
api_reverse
class
TestApiReverse
(
APISimpleTestCase
):
"""
Test behavior of custom api_reverse function
"""
@classmethod
def
setUpClass
(
cls
):
super
(
TestApiReverse
,
cls
).
setUpClass
()
cls
.
api_version
=
'
v1
'
cls
.
api_url
=
django_reverse
(
'
api:{version}:root
'
.
format
(
version
=
cls
.
api_version
))
cls
.
non_api_url
=
django_reverse
(
'
home
'
)
def
setUp
(
self
):
super
(
TestApiReverse
,
self
).
setUp
()
self
.
factory
=
APIRequestFactory
()
# Create requests
self
.
api_request
=
self
.
factory
.
get
(
self
.
api_url
)
self
.
non_api_request
=
self
.
factory
.
get
(
self
.
non_api_url
)
# Simulate version checking that is done in an API view's
# initial() method
self
.
api_request
.
version
=
self
.
api_version
def
test_full_viewname_with_request_to_api
(
self
):
"""
Reverse a fully namespaced viewname, including a request to the API
"""
url
=
api_reverse
(
'
api:v1:root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_full_viewname_with_request_to_api_different_version
(
self
):
"""
Reverse a fully namespaced viewname with a different version than
the corresponding request to the API
"""
url
=
api_reverse
(
'
api:v2:root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v2:root
'
))
def
test_full_viewname_with_request_to_non_api
(
self
):
"""
Reverse a fully namespaced viewname, including a request to a non-API
page
"""
url
=
api_reverse
(
'
api:v1:root
'
,
request
=
self
.
non_api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_full_viewname_with_no_request
(
self
):
"""
Reverse a fully namespaced viewname, with no associated request
"""
url
=
api_reverse
(
'
api:v1:root
'
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_versioned_viewname_with_request_to_api
(
self
):
"""
Reverse a versioned viewname, including a request to the API
"""
url
=
api_reverse
(
'
v1:root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_versioned_viewname_with_request_to_api_different_version
(
self
):
"""
Reverse a versioned viewname with a different version than
the corresponding request to the API
"""
url
=
api_reverse
(
'
v2:root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v2:root
'
))
def
test_versioned_viewname_with_request_to_non_api
(
self
):
"""
Reverse a versioned viewname, including a request to a non-API page
"""
url
=
api_reverse
(
'
v1:root
'
,
request
=
self
.
non_api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_versioned_viewname_with_no_request
(
self
):
"""
Reverse a versioned viewname, with no associated request
"""
url
=
api_reverse
(
'
v1:root
'
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_api_unversioned_viewname_with_request_to_api
(
self
):
"""
Reverse an api-namespaced but unversioned viewname, including a request
to the API
"""
url
=
api_reverse
(
'
api:root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_api_unversioned_viewname_with_request_to_non_api
(
self
):
"""
Reverse an api-namespaced but unversioned viewname, including a request
to a non-API page
"""
url
=
api_reverse
(
'
api:root
'
,
request
=
self
.
non_api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:default:root
'
))
def
test_api_unversioned_viewname_with_no_request
(
self
):
"""
Reverse an api-namespaced bu unversioned viewname, with no associated
request
"""
url
=
api_reverse
(
'
api:root
'
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:default:root
'
))
def
test_relative_viewname_with_request_to_api
(
self
):
url
=
api_reverse
(
'
root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_relative_viewname_with_request_to_non_api
(
self
):
url
=
api_reverse
(
'
root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_relative_viewname_with_no_request
(
self
):
url
=
api_reverse
(
'
root
'
,
request
=
self
.
api_request
,
absolute_path
=
False
)
self
.
assertEqual
(
url
,
django_reverse
(
'
api:v1:root
'
))
def
test_reverse_non_api_url
(
self
):
pass
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment