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
50
|
from mu4web.html_render import render_fragment, render_document
def test_html_basic() -> None:
assert render_fragment(('dl',)) == "<dl></dl>"
def test_html_nested() -> None:
assert render_fragment(('dl',
('dt', 'Key'),
('dd', 'Val'))) \
== "<dl><dt>Key</dt><dd>Val</dd></dl>"
def test_html_list() -> None:
assert render_fragment(('dl',
[('dt', 'Key'),
('dd', 'Val')])) \
== "<dl><dt>Key</dt><dd>Val</dd></dl>"
def test_html_attributes() -> None:
assert render_fragment(('a', {'href': '#'}, 'pretty')) \
== '<a href="#">pretty</a>'
def test_html_standalone() -> None:
assert render_fragment(('hr',)) == '<hr>'
def test_html_none() -> None:
assert render_fragment(None) == ''
def test_html_callable() -> None:
# <hr/> can never appear, since ``('hr',)`` is rendered as "<hr>".
# This shows that functions return contents verbatim.
assert render_fragment(lambda: '<hr/>') == '<hr/>'
def test_complete_document() -> None:
"""
Render complete document.
render_document is currently only render_fragment, but with a a
doctype prepended. Test this, through rendeering the samething
twicie.
"""
assert render_fragment(('hr',)) == '<hr>'
assert render_document(('hr',)) == '<!doctype html>\n<hr>'
|