зеркало из https://github.com/mozilla/gecko-dev.git
51 строка
1.6 KiB
HTML
51 строка
1.6 KiB
HTML
<!--
|
|
Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/
|
|
-->
|
|
<!DOCTYPE HTML>
|
|
<html>
|
|
<head>
|
|
<title>Bug 484305 - Load workers as UTF-8</title>
|
|
<meta http-equiv="content-type" content="text/html; charset=KOI8-R">
|
|
<script 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=484305">Bug 484305 - Load workers as UTF-8</a>
|
|
<p id="display"></p>
|
|
<div id="content" style="display: none">
|
|
|
|
</div>
|
|
<pre id="test">
|
|
<script class="testbody" type="text/javascript">
|
|
|
|
SimpleTest.waitForExplicitFinish();
|
|
|
|
var canonical = String.fromCharCode(0x41F, 0x440, 0x438, 0x432, 0x435, 0x442);
|
|
ok(document.inputEncoding === "KOI8-R", "Document encoding is KOI8-R");
|
|
|
|
// Worker sends two strings, one with `canonical` encoded in KOI8-R and one as UTF-8.
|
|
// Since Worker scripts should always be decoded using UTF-8, even if the owning document's charset is different, the UTF-8 decode should match, while KOI8-R should fail.
|
|
var counter = 0;
|
|
var worker = new Worker("loadEncoding_worker.js");
|
|
worker.onmessage = function(e) {
|
|
if (e.data.encoding === "KOI8-R") {
|
|
ok(e.data.text !== canonical, "KOI8-R decoded text should not match");
|
|
} else if (e.data.encoding === "UTF-8") {
|
|
ok(e.data.text === canonical, "UTF-8 decoded text should match");
|
|
}
|
|
counter++;
|
|
if (counter === 2)
|
|
SimpleTest.finish();
|
|
}
|
|
|
|
worker.onerror = function(e) {
|
|
ok(false, "Worker error");
|
|
SimpleTest.finish();
|
|
}
|
|
</script>
|
|
|
|
</pre>
|
|
</body>
|
|
</html>
|