2016-05-24 14:06:34 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from __future__ import absolute_import
|
|
|
|
|
2016-06-04 20:28:02 +02:00
|
|
|
from typing import Any, Dict, Iterable
|
2016-05-24 14:06:34 +02:00
|
|
|
import logging
|
|
|
|
|
2016-05-11 19:29:29 +02:00
|
|
|
from django.conf import settings
|
|
|
|
from django.test import override_settings
|
2016-05-11 19:01:53 +02:00
|
|
|
from django.template import Template, Context
|
2016-05-24 14:06:34 +02:00
|
|
|
from django.template.loader import get_template
|
|
|
|
|
|
|
|
from zerver.models import get_user_profile_by_email
|
2016-11-10 19:30:09 +01:00
|
|
|
from zerver.lib.test_helpers import get_all_templates
|
|
|
|
from zerver.lib.test_classes import (
|
|
|
|
ZulipTestCase,
|
|
|
|
)
|
2016-11-15 13:41:12 +01:00
|
|
|
from zerver.context_processors import common_context
|
|
|
|
|
2016-05-24 14:06:34 +02:00
|
|
|
|
|
|
|
class get_form_value(object):
|
|
|
|
def __init__(self, value):
|
2016-06-04 20:28:02 +02:00
|
|
|
# type: (Any) -> None
|
2016-05-24 14:06:34 +02:00
|
|
|
self._value = value
|
|
|
|
|
|
|
|
def value(self):
|
2016-06-04 20:28:02 +02:00
|
|
|
# type: () -> Any
|
2016-05-24 14:06:34 +02:00
|
|
|
return self._value
|
|
|
|
|
|
|
|
|
|
|
|
class DummyForm(dict):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2016-08-23 02:08:42 +02:00
|
|
|
class TemplateTestCase(ZulipTestCase):
|
2016-05-24 14:06:34 +02:00
|
|
|
"""
|
|
|
|
Tests that backend template rendering doesn't crash.
|
|
|
|
|
|
|
|
This renders all the Zulip backend templates, passing dummy data
|
|
|
|
as the context, which allows us to verify whether any of the
|
|
|
|
templates are broken enough to not render at all (no verification
|
|
|
|
is done that the output looks right). Please see `get_context`
|
|
|
|
function documentation for more information.
|
|
|
|
"""
|
2016-05-11 19:29:29 +02:00
|
|
|
@override_settings(TERMS_OF_SERVICE=None)
|
2016-05-24 14:06:34 +02:00
|
|
|
def test_templates(self):
|
2016-06-04 20:28:02 +02:00
|
|
|
# type: () -> None
|
|
|
|
|
2016-05-24 14:06:34 +02:00
|
|
|
# Just add the templates whose context has a conflict with other
|
2016-05-11 19:01:53 +02:00
|
|
|
# templates' context in `defer`.
|
|
|
|
defer = ['analytics/activity.html']
|
2016-11-15 13:41:12 +01:00
|
|
|
email = [
|
|
|
|
'zerver/emails/invitation/invitation_reminder_email.html',
|
|
|
|
'zerver/emails/invitation/invitation_reminder_email.subject',
|
|
|
|
'zerver/emails/invitation/invitation_reminder_email.text',
|
|
|
|
]
|
|
|
|
logged_out = [
|
|
|
|
'404.html',
|
|
|
|
'500.html',
|
|
|
|
'confirmation/confirm.html',
|
|
|
|
'confirmation/confirm_mituser.html',
|
|
|
|
'zerver/reset_confirm.html',
|
|
|
|
'zerver/reset_done.html',
|
|
|
|
'zerver/reset_emailed.html',
|
|
|
|
'zerver/reset.html',
|
|
|
|
'zerver/unsubscribe_link_error.html',
|
|
|
|
'zerver/portico.html',
|
|
|
|
'zerver/portico_signup.html',
|
|
|
|
'zerver/register.html',
|
|
|
|
]
|
|
|
|
logged_in = [
|
|
|
|
'zerver/home.html',
|
|
|
|
'zerver/invite_user.html',
|
|
|
|
'zerver/keyboard_shortcuts.html',
|
|
|
|
'zerver/left-sidebar.html',
|
|
|
|
'zerver/logout.html',
|
|
|
|
'zerver/markdown_help.html',
|
|
|
|
'zerver/navbar.html',
|
|
|
|
'zerver/right-sidebar.html',
|
|
|
|
'zerver/search_operators.html',
|
|
|
|
'zerver/stream_creation_prompt.html',
|
|
|
|
'zerver/subscriptions.html',
|
|
|
|
'zerver/tutorial_finale.html',
|
|
|
|
]
|
|
|
|
unusual = [
|
|
|
|
'confirmation/mituser_confirmation_email_body.txt',
|
|
|
|
'confirmation/mituser_confirmation_email_subject.txt',
|
|
|
|
'confirmation/mituser_invite_email_body.txt',
|
|
|
|
'confirmation/mituser_invite_email_subject.txt',
|
|
|
|
'corporate/mit.html',
|
|
|
|
'corporate/privacy.html',
|
|
|
|
'corporate/terms-enterprise.html',
|
|
|
|
'corporate/zephyr.html',
|
|
|
|
'corporate/zephyr-mirror.html',
|
|
|
|
'pipeline/css.jinja',
|
|
|
|
'pipeline/inline_js.jinja',
|
|
|
|
'pipeline/js.jinja',
|
|
|
|
'zilencer/enterprise_tos_accept_body.txt',
|
|
|
|
'zerver/zulipchat_migration_tos.html',
|
|
|
|
'zilencer/enterprise_tos_accept_body.txt',
|
|
|
|
'zerver/closed_realm.html',
|
|
|
|
'zerver/topic_is_muted.html',
|
|
|
|
'zerver/bankruptcy.html',
|
|
|
|
'zerver/image-overlay.html',
|
|
|
|
'zerver/invalid_realm.html',
|
|
|
|
'zerver/compose.html',
|
|
|
|
'zerver/debug.html',
|
|
|
|
'zerver/base.html',
|
|
|
|
'zerver/api_content.json',
|
|
|
|
]
|
|
|
|
skip = defer + email + logged_out + logged_in + unusual + ['tests/test_markdown.html', 'zerver/terms.html']
|
2016-05-11 19:01:53 +02:00
|
|
|
templates = [t for t in get_all_templates() if t not in skip]
|
2016-05-24 14:06:34 +02:00
|
|
|
self.render_templates(templates, self.get_context())
|
|
|
|
|
2016-05-11 19:01:53 +02:00
|
|
|
# Test the deferred templates with updated context.
|
2016-05-24 14:06:34 +02:00
|
|
|
update = {'data': [('one', 'two')]}
|
2016-05-11 19:01:53 +02:00
|
|
|
self.render_templates(defer, self.get_context(**update))
|
2016-05-24 14:06:34 +02:00
|
|
|
|
|
|
|
def render_templates(self, templates, context):
|
2016-11-15 13:41:12 +01:00
|
|
|
# type: (Iterable[str], Dict[str, Any]) -> None
|
|
|
|
for template_name in templates:
|
|
|
|
template = get_template(template_name)
|
2016-05-24 14:06:34 +02:00
|
|
|
try:
|
|
|
|
template.render(context)
|
|
|
|
except Exception:
|
2016-08-09 18:53:41 +02:00
|
|
|
logging.error("Exception while rendering '{}'".format(template.template.name))
|
|
|
|
raise
|
2016-05-24 14:06:34 +02:00
|
|
|
|
|
|
|
def get_context(self, **kwargs):
|
2016-06-04 20:28:02 +02:00
|
|
|
# type: (**Any) -> Dict[str, Any]
|
2016-05-24 14:06:34 +02:00
|
|
|
"""Get the dummy context for shallow testing.
|
|
|
|
|
|
|
|
The context returned will always contain a parameter called
|
|
|
|
`shallow_tested`, which tells the signal receiver that the
|
|
|
|
test was not rendered in an actual logical test (so we can
|
|
|
|
still do coverage reporting on which templates have a logical
|
|
|
|
test).
|
|
|
|
|
|
|
|
Note: `context` just holds dummy values used to make the test
|
|
|
|
pass. This context only ensures that the templates do not
|
|
|
|
throw a 500 error when rendered using dummy data. If new
|
|
|
|
required parameters are added to a template, this test will
|
|
|
|
fail; the usual fix is to just update the context below to add
|
|
|
|
the new parameter to the dummy data.
|
|
|
|
|
|
|
|
:param kwargs: Keyword arguments can be used to update the base
|
|
|
|
context.
|
|
|
|
|
|
|
|
"""
|
|
|
|
email = "hamlet@zulip.com"
|
|
|
|
user_profile = get_user_profile_by_email(email)
|
|
|
|
|
|
|
|
context = dict(
|
2016-11-09 01:45:36 +01:00
|
|
|
article="templates/zerver/help/index.md",
|
2016-05-24 14:06:34 +02:00
|
|
|
shallow_tested=True,
|
|
|
|
user_profile=user_profile,
|
2016-08-21 08:19:25 +02:00
|
|
|
user=user_profile,
|
2016-05-24 14:06:34 +02:00
|
|
|
product_name='testing',
|
|
|
|
form=DummyForm(
|
|
|
|
full_name=get_form_value('John Doe'),
|
|
|
|
terms=get_form_value(True),
|
|
|
|
email=get_form_value(email),
|
|
|
|
),
|
|
|
|
current_url=lambda: 'www.zulip.com',
|
2016-11-27 01:19:35 +01:00
|
|
|
hubot_lozenges_dict={},
|
2016-08-09 18:53:57 +02:00
|
|
|
integrations_dict={},
|
2016-05-24 14:06:34 +02:00
|
|
|
referrer=dict(
|
|
|
|
full_name='John Doe',
|
|
|
|
realm=dict(name='zulip.com'),
|
|
|
|
),
|
|
|
|
uid='uid',
|
|
|
|
token='token',
|
|
|
|
message_count=0,
|
|
|
|
messages=[dict(header='Header')],
|
|
|
|
new_streams=dict(html=''),
|
|
|
|
data=dict(title='Title'),
|
|
|
|
)
|
|
|
|
|
|
|
|
context.update(kwargs)
|
|
|
|
return context
|
2016-05-11 19:01:53 +02:00
|
|
|
|
|
|
|
def test_markdown_in_template(self):
|
|
|
|
# type: () -> None
|
|
|
|
template = get_template("tests/test_markdown.html")
|
|
|
|
context = {
|
|
|
|
'markdown_test_file': "zerver/tests/markdown/test_markdown.md"
|
|
|
|
}
|
|
|
|
content = template.render(context)
|
|
|
|
|
|
|
|
content_sans_whitespace = content.replace(" ", "").replace('\n', '')
|
|
|
|
self.assertEqual(content_sans_whitespace,
|
2016-11-09 21:52:42 +01:00
|
|
|
'header<h1id="hello">Hello!</h1><p>Thisissome<em>boldtext</em>.</p>footer')
|
2016-05-11 19:29:29 +02:00
|
|
|
|
|
|
|
def test_custom_tos_template(self):
|
|
|
|
# type: () -> None
|
|
|
|
response = self.client_get("/terms/")
|
2016-11-19 21:54:00 +01:00
|
|
|
|
|
|
|
self.assert_in_success_response([u"Thanks for using our products and services (\"Services\"). ",
|
|
|
|
u"By using our Services, you are agreeing to these terms"],
|
|
|
|
response)
|