mirror of
https://github.com/tc39/test262.git
synced 2025-04-08 19:35:28 +02:00
Merge pull request #1097 from lyzadanger/esid-builtins-encodeuri
Add `esid` to built-ins/encodeURI
This commit is contained in:
commit
1319061ff7
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: If string.charAt(k) in [0xDC00 - 0xDFFF], throw URIError
|
||||
es5id: 15.1.3.3_A1.1_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -14,31 +16,31 @@ var indexP;
|
||||
var indexO = 0;
|
||||
|
||||
for (var index = 0xDC00; index <= 0xDFFF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var hex = decimalToHexString(index);
|
||||
try {
|
||||
encodeURI(String.fromCharCode(index));
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
}
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -49,6 +51,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: If string.charAt(k) in [0xDC00 - 0xDFFF], throw URIError
|
||||
es5id: 15.1.3.3_A1.1_T2
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -14,31 +16,31 @@ var indexP;
|
||||
var indexO = 0;
|
||||
|
||||
for (var index = 0xDC00; index <= 0xDFFF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var hex = decimalToHexString(index);
|
||||
try {
|
||||
encodeURI(String.fromCharCode(index, 0x0041));
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
}
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -49,6 +51,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,6 +6,8 @@ info: >
|
||||
If string.charAt(k) in [0xD800 - 0xDBFF] and string.length = k + 1, throw
|
||||
URIError
|
||||
es5id: 15.1.3.3_A1.2_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -16,31 +18,31 @@ var indexP;
|
||||
var indexO = 0;
|
||||
|
||||
for (var index = 0xD800; index <= 0xDBFF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var hex = decimalToHexString(index);
|
||||
try {
|
||||
encodeURI(String.fromCharCode(index));
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
}
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -51,6 +53,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,6 +6,8 @@ info: >
|
||||
If string.charAt(k) in [0xD800 - 0xDBFF] and string.length = k + 1, throw
|
||||
URIError
|
||||
es5id: 15.1.3.3_A1.2_T2
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -16,31 +18,31 @@ var indexP;
|
||||
var indexO = 0;
|
||||
|
||||
for (var index = 0xD800; index <= 0xDBFF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var hex = decimalToHexString(index);
|
||||
try {
|
||||
encodeURI(String.fromCharCode(0x0041, index));
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
}
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -51,6 +53,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,6 +6,8 @@ info: >
|
||||
If string.charAt(k) in [0xD800 - 0xDBFF] and string.charAt(k+1) not in
|
||||
[0xDC00 - 0xDFFF], throw URIError
|
||||
es5id: 15.1.3.3_A1.3_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: >
|
||||
Complex tests, string.charAt(k+1) in [0x0000, 0xD7FF, 0xD800,
|
||||
0xDBFE, 0xDBFF, 0xE000, 0xFFFF]
|
||||
@ -19,37 +21,37 @@ var indexP;
|
||||
var indexO = 0;
|
||||
|
||||
for (var index = 0xD800; index <= 0xDBFF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var res = true;
|
||||
for (var indexC = 0; indexC < chars.length; indexC++) {
|
||||
var hex = decimalToHexString(index);
|
||||
try {
|
||||
encodeURI(String.fromCharCode(index, chars[indexC]));
|
||||
} catch (e) {
|
||||
encodeURI(String.fromCharCode(index, chars[indexC]));
|
||||
} catch (e) {
|
||||
if ((e instanceof URIError) === true) continue;
|
||||
}
|
||||
res = false;
|
||||
}
|
||||
if (res !== true) {
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
}
|
||||
errorCount++;
|
||||
}
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -60,6 +62,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,6 +6,8 @@ info: >
|
||||
If string.charAt(k) in [0x0000 - 0x007F]\[uriReserved, uriUnescaped, #],
|
||||
return 1 octet (00000000 0zzzzzzz -> 0zzzzzzz)
|
||||
es5id: 15.1.3.3_A2.1_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests, use RFC 3629
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -17,7 +19,7 @@ var count = 0;
|
||||
var indexP;
|
||||
var indexO = 0;
|
||||
|
||||
l :
|
||||
l :
|
||||
for (var index = 0x0000; index <= 0x007F; index++) {
|
||||
count++;
|
||||
var str = String.fromCharCode(index);
|
||||
@ -26,28 +28,28 @@ for (var index = 0x0000; index <= 0x007F; index++) {
|
||||
}
|
||||
for (indexC = 0; indexC < uriUnescaped.length; indexC++) {
|
||||
if (uriUnescaped[indexC] === str) continue l;
|
||||
}
|
||||
if ("#" === str) continue l;
|
||||
}
|
||||
if ("#" === str) continue l;
|
||||
if (encodeURI(str).toUpperCase() === decimalToPercentHexString(index)) continue l;
|
||||
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -58,6 +60,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,6 +6,8 @@ info: >
|
||||
If string.charAt(k) in [0x0080 - 0x07FF], return 2 octets (00000yyy
|
||||
yyzzzzzz -> 110yyyyy 10zzzzzz)
|
||||
es5id: 15.1.3.3_A2.2_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests, use RFC 3629
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -13,33 +15,33 @@ includes: [decimalToHexString.js]
|
||||
var errorCount = 0;
|
||||
var count = 0;
|
||||
var indexP;
|
||||
var indexO = 0;
|
||||
var indexO = 0;
|
||||
l:
|
||||
for (var index = 0x0080; index <= 0x07FF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var hex1 = decimalToPercentHexString(0x0080 + (index & 0x003F));
|
||||
var hex2 = decimalToPercentHexString(0x00C0 + (index & 0x07C0) / 0x0040);
|
||||
var str = String.fromCharCode(index);
|
||||
if (encodeURI(str).toUpperCase() === hex2 + hex1) continue;
|
||||
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -50,6 +52,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,6 +6,8 @@ info: >
|
||||
If string.charAt(k) in [0x0800 - 0xD7FF], return 3 octets (xxxxyyyy
|
||||
yyzzzzzz -> 1110xxxx 10yyyyyy 10zzzzzz)
|
||||
es5id: 15.1.3.3_A2.3_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests, use RFC 3629
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -13,34 +15,34 @@ includes: [decimalToHexString.js]
|
||||
var errorCount = 0;
|
||||
var count = 0;
|
||||
var indexP;
|
||||
var indexO = 0;
|
||||
var indexO = 0;
|
||||
for (var index = 0x0800; index <= 0xD7FF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var hex1 = decimalToPercentHexString(0x0080 + (index & 0x003F));
|
||||
var hex2 = decimalToPercentHexString(0x0080 + (index & 0x0FC0) / 0x0040);
|
||||
var hex3 = decimalToPercentHexString(0x00E0 + (index & 0xF000) / 0x1000);
|
||||
var str = String.fromCharCode(index);
|
||||
if (encodeURI(str).toUpperCase() === hex3 + hex2 + hex1) continue;
|
||||
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
}
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
@ -50,6 +52,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -7,6 +7,8 @@ info: >
|
||||
[0xDC00 <EFBFBD> 0xDFFF], return 4 octets (000wwwxx xxxxyyyy yyzzzzzz ->
|
||||
11110www 10xxxxxx 10yyyyyy 10zzzzzz)
|
||||
es5id: 15.1.3.3_A2.4_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: >
|
||||
Complex tests, use RFC 3629, string.charAt(k+1) in [0xDC00,
|
||||
0xDDFF, 0xDFFF]
|
||||
@ -17,7 +19,7 @@ var chars = [0xDC00, 0xDDFF, 0xDFFF];
|
||||
var errorCount = 0;
|
||||
var count = 0;
|
||||
var indexP;
|
||||
var indexO = 0;
|
||||
var indexO = 0;
|
||||
for (var index = 0xD800; index <= 0xDBFF; index++) {
|
||||
var res = true;
|
||||
for (var indexC = 0; indexC < chars.length; indexC++) {
|
||||
@ -31,27 +33,27 @@ for (var index = 0xD800; index <= 0xDBFF; index++) {
|
||||
|
||||
res = false;
|
||||
}
|
||||
if (res !== true) {
|
||||
if (indexO === 0) {
|
||||
if (res !== true) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
count++;
|
||||
count++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -62,6 +64,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -7,6 +7,8 @@ info: >
|
||||
[0xDC00 <EFBFBD> 0xDFFF], return 4 octets (000wwwxx xxxxyyyy yyzzzzzz ->
|
||||
11110www 10xxxxxx 10yyyyyy 10zzzzzz)
|
||||
es5id: 15.1.3.3_A2.4_T2
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: >
|
||||
Complex tests, use RFC 3629, string.charAt(k) in [0xD800, 0xDBFF,
|
||||
0xD9FF]
|
||||
@ -17,7 +19,7 @@ var chars = [0xD800, 0xDBFF, 0xD9FF];
|
||||
var errorCount = 0;
|
||||
var count = 0;
|
||||
var indexP;
|
||||
var indexO = 0;
|
||||
var indexO = 0;
|
||||
for (var index = 0xDC00; index <= 0xDFFF; index++) {
|
||||
var res = true;
|
||||
for (var indexC = 0; indexC < chars.length; indexC++) {
|
||||
@ -31,27 +33,27 @@ for (var index = 0xDC00; index <= 0xDFFF; index++) {
|
||||
|
||||
res = false;
|
||||
}
|
||||
if (res !== true) {
|
||||
if (indexO === 0) {
|
||||
if (res !== true) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
count++;
|
||||
count++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -62,6 +64,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,6 +6,8 @@ info: >
|
||||
If string.charAt(k) in [0xE000 - 0xFFFF], return 3 octets (xxxxyyyy
|
||||
yyzzzzzz -> 1110xxxx 10yyyyyy 10zzzzzz)
|
||||
es5id: 15.1.3.3_A2.5_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests, use RFC 3629
|
||||
includes: [decimalToHexString.js]
|
||||
---*/
|
||||
@ -13,33 +15,33 @@ includes: [decimalToHexString.js]
|
||||
var errorCount = 0;
|
||||
var count = 0;
|
||||
var indexP;
|
||||
var indexO = 0;
|
||||
var indexO = 0;
|
||||
for (var index = 0xE000; index <= 0xFFFF; index++) {
|
||||
count++;
|
||||
count++;
|
||||
var hex1 = decimalToPercentHexString(0x0080 + (index & 0x003F));
|
||||
var hex2 = decimalToPercentHexString(0x0080 + (index & 0x0FC0) / 0x0040);
|
||||
var hex3 = decimalToPercentHexString(0x00E0 + (index & 0xF000) / 0x1000);
|
||||
var str = String.fromCharCode(index);
|
||||
if (encodeURI(str).toUpperCase() === hex3 + hex2 + hex1) continue;
|
||||
|
||||
if (indexO === 0) {
|
||||
if (indexO === 0) {
|
||||
indexO = index;
|
||||
} else {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((index - indexP) !== 1) {
|
||||
if ((indexP - indexO) !== 0) {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
var hexO = decimalToHexString(indexO);
|
||||
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
indexO = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
indexP = index;
|
||||
errorCount++;
|
||||
errorCount++;
|
||||
}
|
||||
|
||||
if (errorCount > 0) {
|
||||
@ -50,6 +52,6 @@ if (errorCount > 0) {
|
||||
} else {
|
||||
var hexP = decimalToHexString(indexP);
|
||||
$ERROR('#' + hexP + ' ');
|
||||
}
|
||||
}
|
||||
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||||
}
|
||||
|
@ -6,13 +6,15 @@ info: >
|
||||
unescapedURISet containing one instance of each character valid in
|
||||
uriReserved
|
||||
es5id: 15.1.3.3_A3.1_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Complex tests
|
||||
---*/
|
||||
|
||||
var uriReserved = [";", "/", "?", ":", "@", "&", "=", "+", "$", ","];
|
||||
for (var indexC = 0; indexC < uriReserved.length; indexC++) {
|
||||
var str = uriReserved[indexC];
|
||||
var str = uriReserved[indexC];
|
||||
if (encodeURI(str) !== str) {
|
||||
$ERROR('#' + (indexC + 1) + ': unescapedURISet containing' + str);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -6,13 +6,15 @@ info: >
|
||||
unescapedURISet containing one instance of each character valid in
|
||||
uriUnescaped
|
||||
es5id: 15.1.3.3_A3.2_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: "Complex tests, uriUnescaped :: uriAlpha"
|
||||
---*/
|
||||
|
||||
var uriAlpha = ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"];
|
||||
for (var indexC = 0; indexC < uriAlpha.length; indexC++) {
|
||||
var str = uriAlpha[indexC];
|
||||
var str = uriAlpha[indexC];
|
||||
if (encodeURI(str) !== str) {
|
||||
$ERROR('#' + (indexC + 1) + ': unescapedURISet containing ' + str);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -6,13 +6,15 @@ info: >
|
||||
unescapedURISet containing one instance of each character valid in
|
||||
uriUnescaped
|
||||
es5id: 15.1.3.3_A3.2_T2
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: "Complex tests, uriUnescaped :: DecimalDigit"
|
||||
---*/
|
||||
|
||||
var DecimalDigit = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"];
|
||||
for (var indexC = 0; indexC < DecimalDigit.length; indexC++) {
|
||||
var str = DecimalDigit[indexC];
|
||||
var str = DecimalDigit[indexC];
|
||||
if (encodeURI(str) !== str) {
|
||||
$ERROR('#' + (indexC + 1) + ': unescapedURISet containing' + str);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -6,13 +6,15 @@ info: >
|
||||
unescapedURISet containing one instance of each character valid in
|
||||
uriUnescaped
|
||||
es5id: 15.1.3.3_A3.2_T3
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: "Complex tests, uriUnescaped :: uriMark"
|
||||
---*/
|
||||
|
||||
var uriMark = ["-", "_", ".", "!", "~", "*", "'", "(", ")"];
|
||||
for (var indexC = 0; indexC < uriMark.length; indexC++) {
|
||||
var str = uriMark[indexC];
|
||||
var str = uriMark[indexC];
|
||||
if (encodeURI(str) !== str) {
|
||||
$ERROR('#' + (indexC + 1) + ': unescapedURISet containing' + str);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: unescapedURISet containing "#"
|
||||
es5id: 15.1.3.3_A3.3_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: encodeURI("#") === "#"
|
||||
---*/
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: URI tests
|
||||
es5id: 15.1.3.3_A4_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking ENGLISH ALPHABET
|
||||
---*/
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: URI tests
|
||||
es5id: 15.1.3.3_A4_T2
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking RUSSIAN ALPHABET
|
||||
---*/
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: URI tests
|
||||
es5id: 15.1.3.3_A4_T3
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking URL with Line Terminator
|
||||
---*/
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: URI tests
|
||||
es5id: 15.1.3.3_A4_T4
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Test some url
|
||||
---*/
|
||||
|
||||
@ -20,7 +22,7 @@ if (encodeURI("http://unipro.ru") !== "http://unipro.ru") {
|
||||
//CHECK#3
|
||||
if (encodeURI("http://www.google.ru/support/jobs/bin/static.py?page=why-ru.html&sid=liveandwork") !== "http://www.google.ru/support/jobs/bin/static.py?page=why-ru.html&sid=liveandwork") {
|
||||
$ERROR('#3: http://www.google.ru/support/jobs/bin/static.py?page=why-ru.html&sid=liveandwork"');
|
||||
}
|
||||
}
|
||||
|
||||
//CHECK#4
|
||||
if (encodeURI("http://en.wikipedia.org/wiki/UTF-8#Description") !== "http://en.wikipedia.org/wiki/UTF-8#Description") {
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: The length property of encodeURI has the attribute DontEnum
|
||||
es5id: 15.1.3.3_A5.1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking use propertyIsEnumerable, for-in
|
||||
---*/
|
||||
|
||||
@ -17,7 +19,7 @@ var result = true;
|
||||
for (var p in encodeURI){
|
||||
if (p === "length") {
|
||||
result = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (result !== true) {
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: The length property of encodeURI does not have the attribute DontDelete
|
||||
es5id: 15.1.3.3_A5.2
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking use hasOwnProperty, delete
|
||||
---*/
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: The length property of encodeURI has the attribute ReadOnly
|
||||
es5id: 15.1.3.3_A5.3
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking if varying the length property fails
|
||||
includes: [propertyHelper.js]
|
||||
---*/
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: The length property of encodeURI is 1
|
||||
es5id: 15.1.3.3_A5.4
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: encodeURI.length === 1
|
||||
---*/
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: The encodeURI property has the attribute DontEnum
|
||||
es5id: 15.1.3.3_A5.5
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking use propertyIsEnumerable, for-in
|
||||
---*/
|
||||
|
||||
@ -17,7 +19,7 @@ var result = true;
|
||||
for (var p in this){
|
||||
if (p === "encodeURI") {
|
||||
result = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (result !== true) {
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: The encodeURI property has not prototype property
|
||||
es5id: 15.1.3.3_A5.6
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: Checking encodeURI.prototype
|
||||
---*/
|
||||
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: The encodeURI property can't be used as constructor
|
||||
es5id: 15.1.3.3_A5.7
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: >
|
||||
If property does not implement the internal [[Construct]] method,
|
||||
throw a TypeError exception
|
||||
|
@ -4,6 +4,8 @@
|
||||
/*---
|
||||
info: Operator use ToString
|
||||
es5id: 15.1.3.3_A6_T1
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: If Type(value) is Object, evaluate ToPrimitive(value, String)
|
||||
---*/
|
||||
|
||||
@ -17,7 +19,7 @@ if (encodeURI(object) !== "%5Bobject%20Object%5D") {
|
||||
var object = {valueOf: function() {return ""}, toString: function() {return "^"}};
|
||||
if (encodeURI(object) !== "%5E") {
|
||||
$ERROR('#2: var object = {valueOf: function() {return ""}, toString: function() {return "^"}}; encodeURI(object) === "%5E". Actual: ' + (encodeURI(object)));
|
||||
}
|
||||
}
|
||||
|
||||
//CHECK#3
|
||||
var object = {valueOf: function() {return "^"}, toString: function() {return {}}};
|
||||
@ -57,11 +59,11 @@ try {
|
||||
var object = {valueOf: function() {return "^"}, toString: function() {throw "error"}};
|
||||
encodeURI(object);
|
||||
$ERROR('#7.1: var object = {valueOf: function() {return "^"}, toString: function() {throw "error"}}; encodeURI(object) throw "error". Actual: ' + (encodeURI(object)));
|
||||
}
|
||||
}
|
||||
catch (e) {
|
||||
if (e !== "error") {
|
||||
$ERROR('#7.2: var object = {valueOf: function() {return "^"}, toString: function() {throw "error"}}; encodeURI(object) throw "error". Actual: ' + (e));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
//CHECK#8
|
||||
@ -69,9 +71,9 @@ try {
|
||||
var object = {valueOf: function() {return {}}, toString: function() {return {}}};
|
||||
encodeURI(object);
|
||||
$ERROR('#8.1: var object = {valueOf: function() {return {}}, toString: function() {return {}}}; encodeURI(object) throw TypeError. Actual: ' + (encodeURI(object)));
|
||||
}
|
||||
}
|
||||
catch (e) {
|
||||
if ((e instanceof TypeError) !== true) {
|
||||
$ERROR('#8.2: var object = {valueOf: function() {return {}}, toString: function() {return {}}}; encodeURI(object) throw TypeError. Actual: ' + (e));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -3,6 +3,7 @@
|
||||
|
||||
/*---
|
||||
es6id: 18.2.6.4
|
||||
esid: sec-encodeuri-uri
|
||||
description: >
|
||||
encodeURI.name is "encodeURI".
|
||||
info: >
|
||||
|
Loading…
x
Reference in New Issue
Block a user