diff options
| author | Xavier Ordoquy | 2014-04-17 09:53:44 +0200 | 
|---|---|---|
| committer | Xavier Ordoquy | 2014-04-17 09:53:44 +0200 | 
| commit | 1797a74e828c9fdfbfb46bb4de049100b18db875 (patch) | |
| tree | a91e8f4ff22e8eb63a990a439995632e9198d1c3 /tests/test_breadcrumbs.py | |
| parent | 1d404874b3f0f5b16f3b38ba322f31a18c41aad6 (diff) | |
| parent | 971578ca345c3d3bae7fd93b87c41d43483b6f05 (diff) | |
| download | django-rest-framework-1797a74e828c9fdfbfb46bb4de049100b18db875.tar.bz2 | |
Merge remote-tracking branch 'pelme/pytest' into feature/pytest
Conflicts:
	.travis.yml
	rest_framework/runtests/runtests.py
	tests/test_filters.py
	tests/test_pagination.py
	tox.ini
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', '/')]) | 
