2 <html xmlns=
"http://www.w3.org/1999/xhtml">
6 <title>Test XHTML serializer with entities and selection
</title>
7 <script src=
"/tests/SimpleTest/SimpleTest.js"></script>
8 <link rel=
"stylesheet" type=
"text/css" href=
"/tests/SimpleTest/test.css" />
11 <a target=
"_blank" href=
"https://bugzilla.mozilla.org/show_bug.cgi?id=422043">Mozilla Bug
</a>
13 <div id=
"content" style=
"display: none">
14 <iframe id=
"testframe" src=
"file_xhtmlserializer_2.xhtml">
18 <script class=
"testbody" type=
"text/javascript">
21 function loadFileContent(aFile, aCharset) {
22 //if(aAsIso == undefined) aAsIso = false;
23 if(aCharset == undefined)
26 var baseUri = SpecialPowers.Cc['@mozilla.org/network/standard-url-mutator;
1']
27 .createInstance(SpecialPowers.Ci.nsIURIMutator)
28 .setSpec(window.location.href)
31 var ios = SpecialPowers.Cc['@mozilla.org/network/io-service;
1']
32 .getService(SpecialPowers.Ci.nsIIOService);
33 var chann = ios.newChannel(aFile,
37 SpecialPowers.Services.scriptSecurityManager.getSystemPrincipal(),
38 null, // aTriggeringPrincipal
39 SpecialPowers.Ci.nsILoadInfo.SEC_ALLOW_CROSS_ORIGIN_SEC_CONTEXT_IS_NULL,
40 SpecialPowers.Ci.nsIContentPolicy.TYPE_OTHER);
42 var cis = SpecialPowers.Ci.nsIConverterInputStream;
44 var inputStream = SpecialPowers.Cc[
"@mozilla.org/intl/converter-input-stream;1"]
46 inputStream.init(chann.open(), aCharset,
1024, cis.DEFAULT_REPLACEMENT_CHARACTER);
47 var str = {}, content = '';
48 while (inputStream.readString(
4096, str) !=
0) {
55 function testHtmlSerializer_1 () {
56 const de = SpecialPowers.Ci.nsIDocumentEncoder
57 var encoder = SpecialPowers.Cu.createDocumentEncoder(
"application/xhtml+xml");
59 var doc = $(
"testframe").contentDocument;
62 // in the following tests, we must use the OutputLFLineBreak flag, to avoid
63 // to have the default line break of the platform in the result, so the test
64 // can pass on all platform
66 //------------ OutputEncodeW3CEntities
67 encoder.init(doc,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputEncodeW3CEntities);
68 out = encoder.encodeToString();
69 expected = loadFileContent(
"file_xhtmlserializer_2_basic.xhtml");
70 is(out, expected,
"test OutputEncodeW3CEntities");
72 //------------ OutputEncodeBasicEntities
73 encoder.init(doc,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputEncodeBasicEntities);
74 out = encoder.encodeToString();
75 expected = loadFileContent(
"file_xhtmlserializer_2_basic.xhtml");
76 is(out, expected,
"test OutputEncodeBasicEntities");
78 //------------ OutputEncodeLatin1Entities
79 encoder.init(doc,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputEncodeLatin1Entities);
80 out = encoder.encodeToString();
81 expected = loadFileContent(
"file_xhtmlserializer_2_basic.xhtml");
82 is(out, expected,
"test OutputEncodeLatin1Entities");
84 //------------ OutputEncodeHTMLEntities
85 encoder.init(doc,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputEncodeHTMLEntities);
86 out = encoder.encodeToString();
87 expected = loadFileContent(
"file_xhtmlserializer_2_basic.xhtml");
88 is(out, expected,
"test OutputEncodeHTMLEntities");
90 // tests on the serialization of selections
92 var node = document.getElementById('draggable');
94 var select = window.getSelection();
95 select.selectAllChildren(node);
97 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
98 encoder.setSelection(select);
99 out = encoder.encodeToString();
100 expected = 'This is a
<em xmlns=\
"http://www.w3.org/1999/xhtml\">draggable
</em> bit of text.';
101 is(out, expected,
"test selection");
103 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
104 encoder.setSelection(null);
105 encoder.setContainerNode(node);
106 out = encoder.encodeToString();
107 expected = 'This is a
<em xmlns=\
"http://www.w3.org/1999/xhtml\">draggable
</em> bit of text.';
108 is(out, expected,
"test container node");
110 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
111 encoder.setNode(node);
112 out = encoder.encodeToString();
113 expected =
"<div xmlns=\"http://www.w3.org/
1999/xhtml\
" id=\"draggable\
" ondragstart=\"doDragStartSelection(event)\
">This is a <em>draggable</em> bit of text.</div>";
114 is(out, expected,
"test node");
116 node = document.getElementById('aList');
118 var select = window.getSelection();
119 select.selectAllChildren(node);
121 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
122 encoder.setSelection(select);
123 out = encoder.encodeToString();
124 expected = '\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">Lorem ipsum dolor
</li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">sit amet,
<strong>consectetuer
</strong> </li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">adipiscing elit
</li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">Nam eu sapien. Sed viverra lacus. Donec quis ipsum. Nunc cursus aliquet lectus. Nunc vitae eros. Class
</li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">aptent taciti
</li>\n';
125 is(out, expected,
"test list selection");
127 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
128 encoder.setSelection(null);
129 encoder.setContainerNode(node);
130 out = encoder.encodeToString();
131 expected = '\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">Lorem ipsum dolor
</li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">sit amet,
<strong>consectetuer
</strong> </li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">adipiscing elit
</li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">Nam eu sapien. Sed viverra lacus. Donec quis ipsum. Nunc cursus aliquet lectus. Nunc vitae eros. Class
</li>\n
<li xmlns=\
"http://www.w3.org/1999/xhtml\">aptent taciti
</li>\n';
132 is(out, expected,
"test list container node");
134 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
135 encoder.setNode(node);
136 out = encoder.encodeToString();
137 expected =
"<ol xmlns=\"http://www.w3.org/
1999/xhtml\
" id=\"aList\
">\n <li>Lorem ipsum dolor</li>\n <li>sit amet, <strong>consectetuer</strong> </li>\n <li>adipiscing elit</li>\n <li>Nam eu sapien. Sed viverra lacus. Donec quis ipsum. Nunc cursus aliquet lectus. Nunc vitae eros. Class</li>\n <li>aptent taciti</li>\n</ol>";
138 is(out, expected,
"test list node");
140 var liList = node.getElementsByTagName(
"li");
141 var range = document.createRange();
143 // selection start at the first child of the ol, and end after the element ol
144 range.setStart(node,
1);
145 range.setEnd(node.parentNode,
2);
146 select.removeAllRanges();
147 select.addRange(range);
148 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
149 encoder.setSelection(select);
150 out = encoder.encodeToString();
151 expected = '
<ol xmlns=\
"http://www.w3.org/1999/xhtml\" id=
"aList"><li>Lorem ipsum dolor
</li>\n
<li>sit amet,
<strong>consectetuer
</strong> </li>\n
<li>adipiscing elit
</li>\n
<li>Nam eu sapien. Sed viverra lacus. Donec quis ipsum. Nunc cursus aliquet lectus. Nunc vitae eros. Class
</li>\n
<li>aptent taciti
</li>\n
</ol>';
152 is(out, expected,
"test list selection with range: selection start at the first child of the ol, and end after the element ol");
154 // selection start at the third child of the ol, and end after the element ol
155 range.setStart(node,
3);
156 range.setEnd(node.parentNode,
2);
157 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
158 encoder.setSelection(select);
159 out = encoder.encodeToString();
160 expected = '
<ol xmlns=\
"http://www.w3.org/1999/xhtml\" id=
"aList"><li>sit amet,
<strong>consectetuer
</strong> </li>\n
<li>adipiscing elit
</li>\n
<li>Nam eu sapien. Sed viverra lacus. Donec quis ipsum. Nunc cursus aliquet lectus. Nunc vitae eros. Class
</li>\n
<li>aptent taciti
</li>\n
</ol>';
161 is(out, expected,
"test list selection with range: selection start at the third child of the ol, and end after the element ol");
164 // selection start at the third child of the ol, and end after the element ol + ol start at the value
5
165 range.setStart(node,
3);
166 range.setEnd(node.parentNode,
2);
167 node.setAttribute(
"start",
"5");
168 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
169 encoder.setSelection(select);
170 out = encoder.encodeToString();
171 expected = '
<ol xmlns=\
"http://www.w3.org/1999/xhtml\" id=
"aList" start=
"5"><li>sit amet,
<strong>consectetuer
</strong> </li>\n
<li>adipiscing elit
</li>\n
<li>Nam eu sapien. Sed viverra lacus. Donec quis ipsum. Nunc cursus aliquet lectus. Nunc vitae eros. Class
</li>\n
<li>aptent taciti
</li>\n
</ol>';
172 is(out, expected,
"test list selection with range: selection start at the third child of the ol, and end after the element ol + ol start at the value 5");
175 // selection contains only some child of the ol
176 node.removeAttribute(
"start");
177 range.setStart(node,
3);
178 range.setEnd(node,
5);
179 encoder.init(document,
"application/xhtml+xml", de.OutputLFLineBreak | de.OutputSelectionOnly);
180 encoder.setSelection(select);
181 out = encoder.encodeToString();
182 expected = '
<li xmlns=\
"http://www.w3.org/1999/xhtml\">sit amet,
<strong>consectetuer
</strong> </li>\n ';
183 is(out, expected,
"test list selection with range: selection contains only some child of the ol");
186 // test on short attributes
188 node = document.getElementById('shortattr1');
189 encoder.init(document,
"application/xhtml+xml",de.OutputSelectionOnly | de.OutputRaw);
190 encoder.setNode(node);
191 out = encoder.encodeToString();
192 expected = '
<input xmlns=
"http://www.w3.org/1999/xhtml" id=
"shortattr1" checked=
"checked" value=
"" disabled=
"disabled" ismap=
"ismap" readonly=
"readonly" foo:
checked=
"" xmlns:
foo=
"http://mozilla.org/ns/any" foo:
disabled=
"" />';
193 is(out, expected,
"test short attr #1");
195 node = document.getElementById('shortattr2');
196 encoder.init(document,
"application/xhtml+xml",de.OutputSelectionOnly | de.OutputRaw);
197 encoder.setNode(node);
198 out = encoder.encodeToString();
199 expected = '
<ol xmlns=
"http://www.w3.org/1999/xhtml" id=
"shortattr2" compact=
"compact"><li></li></ol>';
200 is(out, expected,
"test short attr #2");
202 node = document.getElementById('shortattr3');
203 encoder.init(document,
"application/xhtml+xml",de.OutputSelectionOnly | de.OutputRaw);
204 encoder.setNode(node);
205 out = encoder.encodeToString();
206 expected = '
<object xmlns=
"http://www.w3.org/1999/xhtml" id=
"shortattr3" declare=
"declare"></object>';
207 is(out, expected,
"test short attr #3");
209 node = document.getElementById('shortattr4');
210 encoder.init(document,
"application/xhtml+xml",de.OutputSelectionOnly | de.OutputRaw);
211 encoder.setNode(node);
212 out = encoder.encodeToString();
213 expected = '
<script xmlns=
"http://www.w3.org/1999/xhtml" id=
"shortattr4" defer=
"defer"></script>';
214 is(out, expected,
"test short attr #4");
216 node = document.getElementById('shortattr5');
217 encoder.init(document,
"application/xhtml+xml",de.OutputSelectionOnly | de.OutputRaw);
218 encoder.setNode(node);
219 out = encoder.encodeToString();
220 expected = '
<select xmlns=
"http://www.w3.org/1999/xhtml" id=
"shortattr5" multiple=
"multiple"><option selected=
"selected">aaa
</option></select>';
221 is(out, expected,
"test short attr #5");
223 node = document.getElementById('shortattr6');
224 encoder.init(document,
"application/xhtml+xml",de.OutputSelectionOnly | de.OutputRaw);
225 encoder.setNode(node);
226 out = encoder.encodeToString();
227 expected = '
<hr xmlns=
"http://www.w3.org/1999/xhtml" id=
"shortattr6" noshade=
"noshade" />';
228 is(out, expected,
"test short attr #6");
230 node = document.getElementById('shortattr7');
231 encoder.init(document,
"application/xhtml+xml",de.OutputSelectionOnly | de.OutputRaw);
232 encoder.setNode(node);
233 out = encoder.encodeToString();
234 expected = '
<div xmlns=
"http://www.w3.org/1999/xhtml" id=
"shortattr7"><foo:bar xmlns:
foo=
"http://mozilla.org/ns/any" checked=
"" value=
"" disabled=
"" ismap=
"" readonly=
""/></div>';
235 is(out, expected,
"test short attr #7");
237 // test on _moz and -moz attr
238 node = document.getElementById('mozattr');
239 encoder.init(document,
"text/html", de.OutputLFLineBreak | de.OutputSelectionOnly | de.OutputRaw);
240 encoder.setNode(node);
241 out = encoder.encodeToString();
242 expected = '
<div id=
"mozattr" __moz_b=
"b"> lorem ipsum
</div>';
243 is(out, expected,
"test -moz/_moz attr");
245 node.setAttribute('_moz_c','barc');
246 node.setAttribute('_-moz_d','bard');
247 node.setAttribute('__moz_e','bare');
249 encoder.init(document,
"text/html", de.OutputLFLineBreak | de.OutputSelectionOnly | de.OutputRaw);
250 encoder.setNode(node);
251 out = encoder.encodeToString();
252 expected = '
<div id=
"mozattr" __moz_b=
"b" _-moz_d=
"bard" __moz_e=
"bare"> lorem ipsum
</div>';
253 is(out, expected,
"test -moz/_moz attr #2");
259 SimpleTest.waitForExplicitFinish();
261 addLoadEvent(testHtmlSerializer_1);
265 <div style=
"display: none">
267 <div id=
"draggable" ondragstart=
"doDragStartSelection(event)">This is a
<em>draggable
</em> bit of text.
</div>
270 <div style=
"display: none">
273 <li>Lorem ipsum dolor
</li>
274 <li>sit amet,
<strong>consectetuer
</strong> </li>
275 <li>adipiscing elit
</li>
276 <li>Nam eu sapien. Sed viverra lacus. Donec quis ipsum. Nunc cursus aliquet lectus. Nunc vitae eros. Class
</li>
277 <li>aptent taciti
</li>
280 <!-- test for some short attr -->
281 <div id=
"shortattr" xmlns:
foo=
"http://mozilla.org/ns/any">
282 <input id=
"shortattr1" checked=
"" value=
"" disabled=
"" ismap=
"" readonly=
"" foo:
checked=
"" foo:
disabled=
""/>
283 <ol id=
"shortattr2" compact=
""><li></li></ol>
284 <object id=
"shortattr3" declare=
"" />
285 <script id=
"shortattr4" defer=
"" />
286 <select id=
"shortattr5" multiple=
""><option selected=
"">aaa
</option></select>
287 <hr id=
"shortattr6" noshade=
""/>
288 <div id=
"shortattr7"><foo:bar checked=
"" value=
"" disabled=
"" ismap=
"" readonly=
"" /></div>
289 <div id=
"mozattr" _moz_a=
"a" __moz_b=
"b"> lorem ipsum
</div>