<!--
  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 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=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>