quickjs-done/tests/test262.patch

72 lines
2.2 KiB
Diff
Raw Normal View History

2020-09-06 16:53:08 +00:00
diff --git a/harness/atomicsHelper.js b/harness/atomicsHelper.js
2024-10-24 19:25:35 +00:00
index 9c1217351e..3c24755558 100644
2020-09-06 16:53:08 +00:00
--- a/harness/atomicsHelper.js
+++ b/harness/atomicsHelper.js
2024-10-24 19:25:35 +00:00
@@ -227,10 +227,14 @@ $262.agent.waitUntil = function(typedArray, index, expected) {
2020-09-06 16:53:08 +00:00
* }
*/
$262.agent.timeouts = {
- yield: 100,
- small: 200,
- long: 1000,
- huge: 10000,
+// yield: 100,
+// small: 200,
+// long: 1000,
+// huge: 10000,
+ yield: 20,
+ small: 20,
+ long: 100,
+ huge: 1000,
};
/**
diff --git a/harness/regExpUtils.js b/harness/regExpUtils.js
2024-10-24 19:25:35 +00:00
index be7039fda0..7b38abf8df 100644
2020-09-06 16:53:08 +00:00
--- a/harness/regExpUtils.js
+++ b/harness/regExpUtils.js
2024-10-24 19:25:35 +00:00
@@ -6,24 +6,27 @@ description: |
defines: [buildString, testPropertyEscapes, matchValidator]
2020-09-06 16:53:08 +00:00
---*/
2024-05-30 13:49:31 +00:00
2020-09-06 16:53:08 +00:00
+if ($262 && typeof $262.codePointRange === "function") {
+ /* use C function to build the codePointRange (much faster with
+ slow JS engines) */
+ codePointRange = $262.codePointRange;
+} else {
+ codePointRange = function codePointRange(start, end) {
+ const codePoints = [];
+ let length = 0;
+ for (codePoint = start; codePoint < end; codePoint++) {
+ codePoints[length++] = codePoint;
+ }
+ return String.fromCodePoint.apply(null, codePoints);
+ }
+}
+
2024-10-24 19:25:35 +00:00
function buildString({ loneCodePoints, ranges }) {
2020-09-06 16:53:08 +00:00
- const CHUNK_SIZE = 10000;
- let result = Reflect.apply(String.fromCodePoint, null, loneCodePoints);
- for (let i = 0; i < ranges.length; i++) {
- const range = ranges[i];
- const start = range[0];
- const end = range[1];
- const codePoints = [];
- for (let length = 0, codePoint = start; codePoint <= end; codePoint++) {
- codePoints[length++] = codePoint;
- if (length === CHUNK_SIZE) {
- result += Reflect.apply(String.fromCodePoint, null, codePoints);
- codePoints.length = length = 0;
- }
2024-10-24 19:25:35 +00:00
+ let result = String.fromCodePoint.apply(null, loneCodePoints);
+ for (const [start, end] of ranges) {
+ result += codePointRange(start, end + 1);
}
2020-09-06 16:53:08 +00:00
- result += Reflect.apply(String.fromCodePoint, null, codePoints);
2024-10-24 19:25:35 +00:00
- }
- return result;
+ return result;
2020-09-06 16:53:08 +00:00
}
2024-10-24 19:25:35 +00:00
function testPropertyEscapes(regex, string, expression) {