Index: test/mjsunit/regexp-lastIndex.js |
diff --git a/test/mjsunit/regexp-lastIndex.js b/test/mjsunit/regexp-lastIndex.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..1445b9b2ae610e3ad5ce4d8db0e473e496830488 |
--- /dev/null |
+++ b/test/mjsunit/regexp-lastIndex.js |
@@ -0,0 +1,18 @@ |
+// Copyright 2016 the V8 project authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+// lastIndex is set according to funny rules. It is typically set only |
+// for global or sticky RegExps, but on a failure to find a match, it is |
+// set unconditionally. If a set fails, then it acts as if in strict mode |
Yang
2016/03/15 06:56:36
I wonder whether it makes sense to discuss these f
|
+// and throws. |
+ |
+var re = /x/; |
+Object.defineProperty(re, 'lastIndex', {writable: false}); |
+assertThrows(() => re.exec(""), TypeError); |
+assertEquals(["x"], re.exec("x")); |
+ |
+var re = /x/y; |
+Object.defineProperty(re, 'lastIndex', {writable: false}); |
+assertThrows(() => re.exec(""), TypeError); |
+assertThrows(() => re.exec("x"), TypeError); |