diff options
Diffstat (limited to 'intl/uconv/tests/unit/test_bug563618.js')
-rw-r--r-- | intl/uconv/tests/unit/test_bug563618.js | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/intl/uconv/tests/unit/test_bug563618.js b/intl/uconv/tests/unit/test_bug563618.js new file mode 100644 index 000000000..a3052a9cb --- /dev/null +++ b/intl/uconv/tests/unit/test_bug563618.js @@ -0,0 +1,79 @@ +/* Test case for bug 563618 + * + * Uses nsIConverterInputStream to decode invalid EUC-JP text + * + */ + +var Ci = Components.interfaces; +var Cu = Components.utils; + +Cu.import("resource://gre/modules/NetUtil.jsm"); + +const test = [ +// 0: 0x8e followed by hi byte, not valid JIS X 0201 + ["abcdefghijklmnopqrstuvwxyz12test00%8e%80foobar", +// expected: one replacement character, invalid byte eaten + "abcdefghijklmnopqrstuvwxyz12test00\uFFFDfoobar"], +// 1: 0x8e followed by ASCII + ["abcdefghijklmnopqrstuvwxyz12test01%8efoobar", +// expected: one replacement character, invalid byte not eaten + "abcdefghijklmnopqrstuvwxyz12test01\uFFFDfoobar"], +// 2: JIS X 0208 lead byte followed by invalid hi byte + ["abcdefghijklmnopqrstuvwxyz12test02%bf%80foobar", +// expected: one replacement character, invalid byte eaten + "abcdefghijklmnopqrstuvwxyz12test02\uFFFDfoobar"], +// 3: JIS X 0208 lead byte followed by ASCII + ["abcdefghijklmnopqrstuvwxyz12test03%bffoobar", +// expected: one replacement character, invalid byte not eaten + "abcdefghijklmnopqrstuvwxyz12test03\uFFFDfoobar"]]; + +const ConverterInputStream = + Components.Constructor("@mozilla.org/intl/converter-input-stream;1", + "nsIConverterInputStream", + "init"); + +function testCase(testText, expectedText, bufferLength, charset) +{ + var dataURI = "data:text/plain;charset=" + charset + "," + testText; + var channel = NetUtil.newChannel({uri: dataURI, loadUsingSystemPrincipal: true}); + var testInputStream = channel.open2(); + var testConverter = new ConverterInputStream(testInputStream, + charset, + bufferLength, + 0xFFFD); + + if (!(testConverter instanceof Ci.nsIUnicharLineInputStream)) + throw "not line input stream"; + + var outStr = ""; + var more; + do { + // read the line and check for eof + var line = {}; + more = testConverter.readLine(line); + outStr += line.value; + } while (more); + + if (outStr != expectedText) { + dump("Failed with bufferLength = " + bufferLength + "\n"); + if (outStr.length == expectedText.length) { + for (i = 0; i < outStr.length; ++i) { + if (outStr.charCodeAt(i) != expectedText.charCodeAt(i)) { + dump(i + ": " + outStr.charCodeAt(i).toString(16) + " != " + expectedText.charCodeAt(i).toString(16) + "\n"); + } + } + } + } + + // escape the strings before comparing for better readability + do_check_eq(escape(outStr), escape(expectedText)); +} + +function run_test() +{ + for (var i = 0; i < test.length; ++i) { + for (var bufferLength = 32; bufferLength < 40; ++ bufferLength) { + testCase(test[i][0], test[i][1], bufferLength, "EUC-JP"); + } + } +} |