diff options
| author | Andreas Pelme | 2014-03-02 12:40:30 +0100 | 
|---|---|---|
| committer | Andreas Pelme | 2014-03-02 12:40:30 +0100 | 
| commit | 971578ca345c3d3bae7fd93b87c41d43483b6f05 (patch) | |
| tree | 72a6d3d0ced5750a8ba01bedc3a6f8a936e05e2f /tests/test_breadcrumbs.py | |
| parent | 62786a7ad64918022f11f1b95ce84adb8d798830 (diff) | |
| download | django-rest-framework-971578ca345c3d3bae7fd93b87c41d43483b6f05.tar.bz2 | |
Support for running the test suite with py.test
 * Get rid of runtests.py
 * Moved test code  from rest_framework/tests and rest_framework/runtests to tests
 * Invoke py.test from setup.py
 * Invoke py.test from Travis
 * Invoke py.test from tox
 * Changed setUpClass to be just plain setUp in test_permissions.py
 * Updated contribution guideline to show how to invoke py.test
Diffstat (limited to 'tests/test_breadcrumbs.py')
| -rw-r--r-- | tests/test_breadcrumbs.py | 73 | 
1 files changed, 73 insertions, 0 deletions
| diff --git a/tests/test_breadcrumbs.py b/tests/test_breadcrumbs.py new file mode 100644 index 00000000..78edc603 --- /dev/null +++ b/tests/test_breadcrumbs.py @@ -0,0 +1,73 @@ +from __future__ import unicode_literals +from django.test import TestCase +from rest_framework.compat import patterns, url +from rest_framework.utils.breadcrumbs import get_breadcrumbs +from rest_framework.views import APIView + + +class Root(APIView): +    pass + + +class ResourceRoot(APIView): +    pass + + +class ResourceInstance(APIView): +    pass + + +class NestedResourceRoot(APIView): +    pass + + +class NestedResourceInstance(APIView): +    pass + +urlpatterns = patterns('', +    url(r'^$', Root.as_view()), +    url(r'^resource/$', ResourceRoot.as_view()), +    url(r'^resource/(?P<key>[0-9]+)$', ResourceInstance.as_view()), +    url(r'^resource/(?P<key>[0-9]+)/$', NestedResourceRoot.as_view()), +    url(r'^resource/(?P<key>[0-9]+)/(?P<other>[A-Za-z]+)$', NestedResourceInstance.as_view()), +) + + +class BreadcrumbTests(TestCase): +    """Tests the breadcrumb functionality used by the HTML renderer.""" + +    urls = 'tests.test_breadcrumbs' + +    def test_root_breadcrumbs(self): +        url = '/' +        self.assertEqual(get_breadcrumbs(url), [('Root', '/')]) + +    def test_resource_root_breadcrumbs(self): +        url = '/resource/' +        self.assertEqual(get_breadcrumbs(url), [('Root', '/'), +                                            ('Resource Root', '/resource/')]) + +    def test_resource_instance_breadcrumbs(self): +        url = '/resource/123' +        self.assertEqual(get_breadcrumbs(url), [('Root', '/'), +                                            ('Resource Root', '/resource/'), +                                            ('Resource Instance', '/resource/123')]) + +    def test_nested_resource_breadcrumbs(self): +        url = '/resource/123/' +        self.assertEqual(get_breadcrumbs(url), [('Root', '/'), +                                            ('Resource Root', '/resource/'), +                                            ('Resource Instance', '/resource/123'), +                                            ('Nested Resource Root', '/resource/123/')]) + +    def test_nested_resource_instance_breadcrumbs(self): +        url = '/resource/123/abc' +        self.assertEqual(get_breadcrumbs(url), [('Root', '/'), +                                            ('Resource Root', '/resource/'), +                                            ('Resource Instance', '/resource/123'), +                                            ('Nested Resource Root', '/resource/123/'), +                                            ('Nested Resource Instance', '/resource/123/abc')]) + +    def test_broken_url_breadcrumbs_handled_gracefully(self): +        url = '/foobar' +        self.assertEqual(get_breadcrumbs(url), [('Root', '/')]) | 
