зеркало из https://github.com/mozilla/pjs.git
Tests for bug 381412
This commit is contained in:
Родитель
840dd9f15a
Коммит
801d4e8265
|
@ -0,0 +1,60 @@
|
|||
const charset = "Big5-HKSCS";
|
||||
|
||||
function dumpStrings(inString, outString) {
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
}
|
||||
|
||||
function error(inString, outString, msg){
|
||||
dumpStrings(inString, outString);
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) + converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString, "2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,60 @@
|
|||
const charset = "Big5";
|
||||
|
||||
function dumpStrings(inString, outString) {
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
}
|
||||
|
||||
function error(inString, outString, msg){
|
||||
dumpStrings(inString, outString);
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) + converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString, "2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,56 @@
|
|||
const charset = "windows-936";
|
||||
|
||||
function error(inString, outString, msg){
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) + converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString, "2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,60 @@
|
|||
const charset = "EUC-KR";
|
||||
|
||||
function dumpStrings(inString, outString) {
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
}
|
||||
|
||||
function error(inString, outString, msg){
|
||||
dumpStrings(inString, outString);
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) + converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString, "2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,89 @@
|
|||
const charset = "EUC-JP";
|
||||
const ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
var gConverter;
|
||||
|
||||
function error(inString, outString, msg){
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function test(inString) {
|
||||
var outString = gConverter.ConvertToUnicode(inString) +
|
||||
gConverter.Finish();
|
||||
|
||||
switch (outString.length) {
|
||||
case 0:
|
||||
case 1:
|
||||
case 2:
|
||||
error(inString, outString, "Unexpected error");
|
||||
break;
|
||||
case 3:
|
||||
error(inString, outString, "3 byte sequence eaten");
|
||||
break;
|
||||
case 4:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80 &&
|
||||
outString.charCodeAt(2) < 0x80 &&
|
||||
outString.charCodeAt(3) < 0x80) {
|
||||
error(inString, outString,
|
||||
"3 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 5:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80 &&
|
||||
outString.charCodeAt(2) < 0x80 &&
|
||||
outString.charCodeAt(3) < 0x80 &&
|
||||
outString.charCodeAt(4) < 0x80) {
|
||||
error(inString, outString,
|
||||
"3 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
case 6:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80 &&
|
||||
outString.charCodeAt(2) < 0x80 &&
|
||||
outString.charCodeAt(3) < 0x80 &&
|
||||
outString.charCodeAt(4) < 0x80 &&
|
||||
outString.charCodeAt(5) < 0x80) {
|
||||
error(inString, outString,
|
||||
"3 byte sequence converted to 3 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
gConverter = new ScriptableUnicodeConverter();
|
||||
gConverter.charset = charset;
|
||||
|
||||
var byte1, byte2, byte3;
|
||||
for (byte1 = 1; byte1 < 0x100; ++byte1) {
|
||||
for (byte2 = 1; byte2 < 0x100; ++byte2) {
|
||||
if (byte1 == 0x8f) {
|
||||
for (byte3 = 1; byte3 < 0x100; ++byte3) {
|
||||
test(String.fromCharCode(byte1, byte2, byte3) + "foo");
|
||||
}
|
||||
} else {
|
||||
test(String.fromCharCode(byte1, byte2) + " foo");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,56 @@
|
|||
const charset = "GB2312";
|
||||
|
||||
function error(inString, outString, msg){
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) + converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString, "2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,73 @@
|
|||
const charset = "hz-gb-2312";
|
||||
|
||||
function dumpStrings(inString, outString) {
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
}
|
||||
|
||||
function error(inString, outString, msg){
|
||||
dumpStrings(inString, outString);
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
if (leadByte == 0x7e) {
|
||||
if (trailByte == 0x7b ||
|
||||
trailByte == 0xa ||
|
||||
trailByte == 0x7e) {
|
||||
// ignore escape sequences:
|
||||
// ~{ (sets HZ-GB mode)
|
||||
// ~\n ( ==> \n)
|
||||
// ~~ ( ==> ~)
|
||||
continue;
|
||||
}
|
||||
}
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) +
|
||||
converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,60 @@
|
|||
const charset = "x-johab";
|
||||
|
||||
function dumpStrings(inString, outString) {
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
}
|
||||
|
||||
function error(inString, outString, msg){
|
||||
dumpStrings(inString, outString);
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) + converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString, "2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,56 @@
|
|||
const charset = "Shift_JIS";
|
||||
|
||||
function error(inString, outString, msg){
|
||||
var dispIn = "";
|
||||
var dispOut = "";
|
||||
var i;
|
||||
for (i = 0; i < inString.length; ++i) {
|
||||
dispIn += " x" + inString.charCodeAt(i).toString(16);
|
||||
}
|
||||
if (outString.length == 0) {
|
||||
dispOut = "<empty>";
|
||||
} else {
|
||||
for (i = 0; i < outString.length; ++i) {
|
||||
dispOut += " x" + outString.charCodeAt(i).toString(16);
|
||||
}
|
||||
}
|
||||
dump("\"" + dispIn + "\" ==> \"" + dispOut + "\"\n");
|
||||
do_throw("security risk: " + msg);
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
var ScriptableUnicodeConverter =
|
||||
Components.Constructor("@mozilla.org/intl/scriptableunicodeconverter",
|
||||
"nsIScriptableUnicodeConverter");
|
||||
|
||||
var converter = new ScriptableUnicodeConverter();
|
||||
converter.charset = charset;
|
||||
|
||||
var leadByte, trailByte;
|
||||
var inString;
|
||||
for (leadByte = 1; leadByte < 0x100; ++leadByte) {
|
||||
for (trailByte = 1; trailByte < 0x100; ++trailByte) {
|
||||
inString = String.fromCharCode(leadByte, trailByte, 65);
|
||||
var outString = converter.ConvertToUnicode(inString) + converter.Finish();
|
||||
switch (outString.length) {
|
||||
case 1:
|
||||
error(inString, outString, "2 byte sequence eaten");
|
||||
break;
|
||||
case 2:
|
||||
if (outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString, "2 byte sequence converted to 1 ASCII");
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (outString != inString &&
|
||||
outString.charCodeAt(0) < 0x80 &&
|
||||
outString.charCodeAt(1) < 0x80) {
|
||||
error(inString, outString,
|
||||
"2 byte sequence converted to 2 ASCII");
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Загрузка…
Ссылка в новой задаче