mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-02-02 20:54:42 +03:00
parent
c7a988eb38
commit
921e4ed2ee
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
from django.test import TestCase
|
from django.test import TestCase
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
from rest_framework.compat import apply_markdown, smart_text
|
from rest_framework.compat import apply_markdown, smart_text
|
||||||
from rest_framework.views import APIView
|
from rest_framework.views import APIView
|
||||||
from rest_framework.tests.description import ViewWithNonASCIICharactersInDocstring
|
from rest_framework.tests.description import ViewWithNonASCIICharactersInDocstring
|
||||||
|
@ -98,6 +99,27 @@ class TestViewNamesAndDescriptions(TestCase):
|
||||||
pass
|
pass
|
||||||
self.assertEqual(MockView().get_view_description(), '')
|
self.assertEqual(MockView().get_view_description(), '')
|
||||||
|
|
||||||
|
def test_view_description_can_be_promise(self):
|
||||||
|
"""
|
||||||
|
Ensure a view may have a docstring that is actually a lazily evaluated
|
||||||
|
class that can be converted to a string.
|
||||||
|
|
||||||
|
See: https://github.com/tomchristie/django-rest-framework/issues/1708
|
||||||
|
"""
|
||||||
|
# use a mock object instead of gettext_lazy to ensure that we can't end
|
||||||
|
# up with a test case string in our l10n catalog
|
||||||
|
@python_2_unicode_compatible
|
||||||
|
class MockLazyStr(object):
|
||||||
|
def __init__(self, string):
|
||||||
|
self.s = string
|
||||||
|
def __str__(self):
|
||||||
|
return self.s
|
||||||
|
|
||||||
|
class MockView(APIView):
|
||||||
|
__doc__ = MockLazyStr("a gettext string")
|
||||||
|
|
||||||
|
self.assertEqual(MockView().get_view_description(), 'a gettext string')
|
||||||
|
|
||||||
def test_markdown(self):
|
def test_markdown(self):
|
||||||
"""
|
"""
|
||||||
Ensure markdown to HTML works as expected.
|
Ensure markdown to HTML works as expected.
|
||||||
|
|
|
@ -6,8 +6,6 @@ from __future__ import unicode_literals
|
||||||
from django.utils.html import escape
|
from django.utils.html import escape
|
||||||
from django.utils.safestring import mark_safe
|
from django.utils.safestring import mark_safe
|
||||||
from rest_framework.compat import apply_markdown
|
from rest_framework.compat import apply_markdown
|
||||||
from rest_framework.settings import api_settings
|
|
||||||
from textwrap import dedent
|
|
||||||
import re
|
import re
|
||||||
|
|
||||||
|
|
||||||
|
@ -36,7 +34,7 @@ def dedent(content):
|
||||||
# unindent the content if needed
|
# unindent the content if needed
|
||||||
if whitespace_counts:
|
if whitespace_counts:
|
||||||
whitespace_pattern = '^' + (' ' * min(whitespace_counts))
|
whitespace_pattern = '^' + (' ' * min(whitespace_counts))
|
||||||
content = re.sub(re.compile(whitespace_pattern, re.MULTILINE), '', content)
|
content = re.sub(re.compile(whitespace_pattern, re.MULTILINE), '', unicode(content))
|
||||||
|
|
||||||
return content.strip()
|
return content.strip()
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user