diff --git a/django/template/base.py b/django/template/base.py index 85ce3c2abd..b1eec99655 100644 --- a/django/template/base.py +++ b/django/template/base.py @@ -308,7 +308,7 @@ class Token: self.lineno = lineno self.position = position - def __str__(self): + def __repr__(self): token_name = self.token_type.name.capitalize() return ('<%s token: "%s...">' % (token_name, self.contents[:20].replace('\n', ''))) @@ -334,6 +334,13 @@ class Lexer: self.template_string = template_string self.verbatim = False + def __repr__(self): + return '<%s template_string="%s...", verbatim=%s>' % ( + self.__class__.__qualname__, + self.template_string[:20].replace('\n', ''), + self.verbatim, + ) + def tokenize(self): """ Return a list of tokens from a given template_string. @@ -423,6 +430,9 @@ class Parser: self.add_library(builtin) self.origin = origin + def __repr__(self): + return '<%s tokens=%r>' % (self.__class__.__qualname__, self.tokens) + def parse(self, parse_until=None): """ Iterate through the parser tokens and compiles each one into a node. @@ -723,6 +733,9 @@ class FilterExpression: def __str__(self): return self.token + def __repr__(self): + return "<%s %r>" % (self.__class__.__qualname__, self.token) + class Variable: """ diff --git a/tests/template_tests/test_parser.py b/tests/template_tests/test_parser.py index 2370e0263e..6c8b70d16f 100644 --- a/tests/template_tests/test_parser.py +++ b/tests/template_tests/test_parser.py @@ -3,7 +3,7 @@ Testing some internals of the template processing. These are *not* examples to b """ from django.template import Library, TemplateSyntaxError from django.template.base import ( - FilterExpression, Parser, Token, TokenType, Variable, + FilterExpression, Lexer, Parser, Token, TokenType, Variable, ) from django.template.defaultfilters import register as filter_library from django.test import SimpleTestCase @@ -19,6 +19,22 @@ class ParserTests(SimpleTestCase): split = token.split_contents() self.assertEqual(split, ["sometag", '_("Page not found")', 'value|yesno:_("yes,no")']) + def test_repr(self): + token = Token(TokenType.BLOCK, 'some text') + self.assertEqual(repr(token), '') + parser = Parser([token], builtins=[filter_library]) + self.assertEqual( + repr(parser), + ']>', + ) + filter_expression = FilterExpression('news|upper', parser) + self.assertEqual(repr(filter_expression), "") + lexer = Lexer('{% for i in 1 %}{{ a }}\n{% endfor %}') + self.assertEqual( + repr(lexer), + '', + ) + def test_filter_parsing(self): c = {"article": {"section": "News"}} p = Parser("", builtins=[filter_library])