aboutsummaryrefslogtreecommitdiffstats
path: root/tests/panels/test_template.py
blob: 1c439829c3b34979505bc01f3bf27fa6bc832455 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# coding: utf-8

from __future__ import unicode_literals

import django
from django.contrib.auth.models import User
from django.template import Template, Context

from ..base import BaseTestCase
from ..models import NonAsciiRepr


class TemplateDebugPanelTestCase(BaseTestCase):

    def setUp(self):
        super(TemplateDebugPanelTestCase, self).setUp()
        self.panel = self.toolbar.get_panel_by_id('TemplateDebugPanel')
        self.sql_panel = self.toolbar.get_panel_by_id('SQLDebugPanel')
        self.sql_panel.enable_instrumentation()

    def tearDown(self):
        self.sql_panel.disable_instrumentation()
        super(TemplateDebugPanelTestCase, self).tearDown()

    def test_queryset_hook(self):
        t = Template("No context variables here!")
        c = Context({
            'queryset': User.objects.all(),
            'deep_queryset': {
                'queryset': User.objects.all(),
            }
        })
        t.render(c)

        # ensure the query was NOT logged
        self.assertEqual(len(self.sql_panel._queries), 0)

        base_ctx_idx = 1 if django.VERSION[:2] >= (1, 5) else 0
        ctx = self.panel.templates[0]['context'][base_ctx_idx]
        self.assertIn('<<queryset of auth.User>>', ctx)
        self.assertIn('<<triggers database query>>', ctx)

    def test_object_with_non_ascii_repr_in_context(self):
        self.panel.process_request(self.request)
        t = Template("{{ object }}")
        c = Context({'object': NonAsciiRepr()})
        t.render(c)
        self.panel.process_response(self.request, self.response)
        self.assertIn('nôt åscíì', self.panel.content())