import pytest
from webob.util import html_escape, text_
class t_esc_HTML:
def __html__(self):
return "
hello
"
class t_esc_Unicode:
def __str__(self):
return "\xe9"
class t_esc_UnsafeAttrs:
attr = "value"
def __getattr__(self, k):
return self.attr
def __repr__(self):
return ""
class t_esc_SuperMoose:
def __str__(self):
return "m\xf8ose"
@pytest.mark.parametrize(
"input,expected",
[
('these chars: < > & "', "these chars: < > & ""),
(" ", " "),
("è", "è"),
# The apostrophe is *not* escaped, which some might consider to be
# a serious bug (see, e.g. http://www.cvedetails.com/cve/CVE-2010-2480/)
pytest.param("'", "'"),
("the majestic m\xf8ose", "the majestic møose"),
# 8-bit strings are passed through
("\xe9", "é"),
# ``None`` is treated specially, and returns the empty string.
(None, ""),
# Objects that define a ``__html__`` method handle their own escaping
(t_esc_HTML(), "hello
"),
# Things that are not strings are converted to strings and then escaped
(42, "42"),
(t_esc_SuperMoose(), "møose"),
(t_esc_Unicode(), "é"),
(t_esc_UnsafeAttrs(), "<UnsafeAttrs>"),
pytest.param(Exception("expected a '<'."), "expected a '<'."),
],
)
def test_html_escape(input, expected):
assert expected == html_escape(input)