mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-30 05:35:31 +00:00
a25701a3f7
find /files/mozilla/build/d/_tests/testing/mochitest/tests/ | egrep "\.(xhtml|html|xml|js)$" | grep -v SimpleTest | grep -vi mochikit | grep -v simpleThread | grep -v test_ipc_messagemanager_blob.html | grep -v "indexedDB/test" | xargs grep -l Components | xargs grep -L enablePrivilege | perl -pe 's#.*mochitest/tests/##' | xargs perl -p -i.bakkk -e 's/Components\.interfaces(\s|;|\.|\[)/SpecialPowers\.Ci$1/g, s/SpecialPowers\.wrap\(Components\)\.(.)(lasses|tils|nterfaces|esults)/SpecialPowers.C$1/g, s/(?<![\.a-zA-Z])Components/SpecialPowers\.Components/g, s/window\.Components/window\.SpecialPowers\.Components/g'
197 lines
7.3 KiB
HTML
197 lines
7.3 KiB
HTML
<!DOCTYPE HTML>
|
|
<html>
|
|
<!--
|
|
-->
|
|
<head>
|
|
<title>Test for XHTML serializer</title>
|
|
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
|
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
|
|
</head>
|
|
<body>
|
|
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=422043">Mozilla Bug </a>
|
|
<p id="display"></p>
|
|
<div id="content" style="display: none">
|
|
<iframe id="testframe" src="file_xhtmlserializer_1.xhtml">
|
|
</iframe>
|
|
</div>
|
|
<pre id="test">
|
|
<script class="testbody" type="text/javascript">
|
|
|
|
|
|
function loadFileContent(aFile, aCharset) {
|
|
//if(aAsIso == undefined) aAsIso = false;
|
|
if(aCharset == undefined)
|
|
aCharset = 'UTF-8';
|
|
|
|
var baseUri = SpecialPowers.Cc['@mozilla.org/network/standard-url;1']
|
|
.createInstance(SpecialPowers.Ci.nsIURI);
|
|
baseUri.spec = window.location.href;
|
|
|
|
var ios = SpecialPowers.Cc['@mozilla.org/network/io-service;1']
|
|
.getService(SpecialPowers.Ci.nsIIOService);
|
|
var chann = ios.newChannel(aFile, aCharset, baseUri);
|
|
|
|
var cis = SpecialPowers.Ci.nsIConverterInputStream;
|
|
|
|
var inputStream = SpecialPowers.Cc["@mozilla.org/intl/converter-input-stream;1"]
|
|
.createInstance(cis);
|
|
inputStream.init(chann.open(), aCharset, 1024, cis.DEFAULT_REPLACEMENT_CHARACTER);
|
|
var str = {}, content = '';
|
|
while (inputStream.readString(4096, str) != 0) {
|
|
content += str.value;
|
|
}
|
|
return content;
|
|
}
|
|
|
|
|
|
function testHtmlSerializer_1 () {
|
|
const de = SpecialPowers.Ci.nsIDocumentEncoder
|
|
var encoder = SpecialPowers.Cc["@mozilla.org/layout/documentEncoder;1?type=application/xhtml+xml"]
|
|
.createInstance(SpecialPowers.Ci.nsIDocumentEncoder);
|
|
|
|
var doc = SpecialPowers.wrap($("testframe")).contentDocument;
|
|
var out, expected;
|
|
|
|
// in the following tests, we must use the OutputLFLineBreak flag, to avoid
|
|
// to have the default line break of the platform in the result, so the test
|
|
// can pass on all platform
|
|
|
|
//------------ no flags
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak);
|
|
encoder.setCharset("UTF-8");
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_noflag.xhtml");
|
|
is(out, expected, "test no flags");
|
|
|
|
//------------- unsupported flags
|
|
// since the following flags are not supported, we should
|
|
// have a result like the one without flag
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputPreformatted);
|
|
out = encoder.encodeToString();
|
|
is(out, expected, "test OutputPreformatted");
|
|
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputFormatFlowed);
|
|
out = encoder.encodeToString();
|
|
is(out, expected, "test OutputFormatFlowed");
|
|
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputNoScriptContent);
|
|
out = encoder.encodeToString();
|
|
is(out, expected, "test OutputNoScriptContent");
|
|
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputNoFramesContent);
|
|
out = encoder.encodeToString();
|
|
is(out, expected, "test OutputNoFramesContent");
|
|
|
|
|
|
//------------ OutputWrap
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputWrap);
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_wrap.xhtml");
|
|
is(out, expected, "test OutputWrap");
|
|
|
|
//------------ OutputFormatted
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputFormatted);
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_format.xhtml");
|
|
is(out, expected, "test OutputFormatted");
|
|
|
|
//------------ OutputRaw
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputRaw);
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_raw.xhtml");
|
|
is(out, expected, "test OutputRaw");
|
|
|
|
//------------ OutputBodyOnly
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputBodyOnly);
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_bodyonly.xhtml");
|
|
is(out, expected, "test OutputBodyOnly");
|
|
|
|
|
|
//------------ OutputAbsoluteLinks
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputAbsoluteLinks);
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_links.xhtml").trim('\n');
|
|
is(out, expected, "test OutputAbsoluteLinks");
|
|
|
|
//------------ OutputLFLineBreak
|
|
encoder.init(doc, "application/xhtml+xml",de.OutputLFLineBreak);
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_linebreak.xhtml");
|
|
is(out, expected, "test OutputLFLineBreak");
|
|
|
|
//------------ OutputCRLineBreak
|
|
encoder.init(doc, "application/xhtml+xml",de.OutputCRLineBreak);
|
|
out = encoder.encodeToString();
|
|
expected = expected.replace(/\n/mg, "\r");
|
|
is(out, expected, "test OutputCRLineBreak");
|
|
|
|
//------------ OutputLFLineBreak + OutputCRLineBreak
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputCRLineBreak);
|
|
out = encoder.encodeToString();
|
|
expected = expected.replace(/\r/mg, "\r\n");
|
|
is(out, expected, "test OutputLFLineBreak + OutputCRLineBreak");
|
|
|
|
//------------ OutputNoFormattingInPre
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputNoFormattingInPre);
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_noformatpre.xhtml");
|
|
is(out, expected, "test OutputNoFormattingInPre");
|
|
|
|
// ------------- nested body elements
|
|
var body2 = doc.createElement('body');
|
|
var p = doc.createElement('p');
|
|
p.appendChild(doc.createTextNode("this is an other body element"));
|
|
body2.appendChild(p);
|
|
var body = doc.getElementsByTagName('body')[0];
|
|
body.appendChild(body2);
|
|
|
|
is(doc.getElementsByTagName('body').length, 2); // to be sure we have two body elements
|
|
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak);
|
|
encoder.setCharset("UTF-8");
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_nested_body.xhtml");
|
|
is(out, expected, "test with two nested body elements");
|
|
|
|
// ------------- two body elements
|
|
body.parentNode.insertBefore(body2, body);
|
|
|
|
is(doc.getElementsByTagName('body').length, 2); // to be sure we have two body elements
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak);
|
|
encoder.setCharset("UTF-8");
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_sibling_body.xhtml");
|
|
is(out, expected, "test with two body elements");
|
|
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak | de.OutputBodyOnly);
|
|
encoder.setCharset("UTF-8");
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_sibling_body_only_body.xhtml");
|
|
is(out, expected, "test with two body elements, and output body only");
|
|
|
|
// --------------- no body element
|
|
doc.documentElement.removeChild(body);
|
|
doc.documentElement.removeChild(body2);
|
|
|
|
encoder.init(doc, "application/xhtml+xml", de.OutputLFLineBreak);
|
|
encoder.setCharset("UTF-8");
|
|
out = encoder.encodeToString();
|
|
expected = loadFileContent("file_xhtmlserializer_1_no_body.xhtml");
|
|
is(out, expected, "test with no body element");
|
|
|
|
SimpleTest.finish();
|
|
}
|
|
|
|
|
|
SimpleTest.waitForExplicitFinish();
|
|
|
|
addLoadEvent(testHtmlSerializer_1);
|
|
|
|
</script>
|
|
</pre>
|
|
</body>
|
|
</html>
|
|
|
|
|