Skip to content
Snippets Groups Projects
Commit c74e1e4e authored by Daniel Ehrenberg's avatar Daniel Ehrenberg Committed by GitHub
Browse files

Merge pull request #1074 from shvaikalesh/improve-named-groups-coverage

Improve named groups coverage
parents d0ba3251 ce0ba9b2
No related branches found
No related tags found
No related merge requests found
// Copyright 2017 Aleksey Shvayka. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
description: Properties of the groups object are created with CreateDataProperty
includes: [propertyHelper.js]
esid: sec-regexpbuiltinexec
features: [regexp-named-groups]
info: >
Runtime Semantics: RegExpBuiltinExec ( R, S )
24. If R contains any GroupName,
a. Let groups be ObjectCreate(null).
b. Perform ! CreateDataProperty(A, "groups", groups).
---*/
// groups is created with Define, not Set
let counter = 0;
Object.defineProperty(Array.prototype, "groups", {set() { counter++; }});
let match = /(?<x>.)/.exec("a");
assert.sameValue(counter, 0);
// groups is writable, enumerable and configurable
// (from CreateDataProperty)
verifyProperty(match, "groups", {
writable: true,
enumerable: true,
configurable: true,
});
// The '__proto__' property on the groups object is not special,
// and does not affect the [[Prototype]] of the resulting groups object.
let {groups} = /(?<__proto__>.)/.exec("a");
assert.sameValue("a", groups.__proto__);
assert.sameValue(null, Object.getPrototypeOf(groups));
...@@ -31,9 +31,3 @@ assert.sameValue(counter, 0); ...@@ -31,9 +31,3 @@ assert.sameValue(counter, 0);
verifyWritable(groups, "x"); verifyWritable(groups, "x");
verifyEnumerable(groups, "x"); verifyEnumerable(groups, "x");
verifyConfigurable(groups, "x"); verifyConfigurable(groups, "x");
// The '__proto__' property on the groups object is not special,
// and does not affect the [[Prototype]] of the resulting groups object.
groups = /(?<__proto__>a)/u.exec("a").groups;
assert.sameValue("a", groups.__proto__);
assert.sameValue(null, Object.getPrototypeOf(groups));
...@@ -23,6 +23,7 @@ assert(/\k<a/.test("k<a")); ...@@ -23,6 +23,7 @@ assert(/\k<a/.test("k<a"));
assert(/\k/.test("k")); assert(/\k/.test("k"));
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k/")); assert.throws(SyntaxError, () => eval("/(?<a>.)\\k/"));
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<a/")); assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<a/"));
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<>/"));
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<b>/")); assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<b>/"));
assert.throws(SyntaxError, () => eval("/(?<a>a)\\k<ab>/")); assert.throws(SyntaxError, () => eval("/(?<a>a)\\k<ab>/"));
assert.throws(SyntaxError, () => eval("/(?<ab>a)\\k<a>/")); assert.throws(SyntaxError, () => eval("/(?<ab>a)\\k<a>/"));
......
// Copyright 2017 Aleksey Shvayka. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
description: Do not replace $<> preceded with $
esid: sec-getsubstitution
features: [regexp-named-groups]
info: >
Runtime Semantics: GetSubstitution( matched, str, position, captures, namedCaptures, replacement )
12. These $ replacements are done left-to-right, and, once such a replacement is performed,
the new replacement text is not subject to further replacements.
Table: Replacement Text Symbol Substitutions
Unicode Characters: $$
Replacement text: $
---*/
let source = "(?<fst>.)";
for (let flags of ["", "u"]) {
let re = new RegExp(source, flags);
assert.sameValue("$<fst>bc", "abc".replace(re, "$$<fst>"));
}
...@@ -21,4 +21,6 @@ for (let flags of ["", "u", "g", "gu"]) { ...@@ -21,4 +21,6 @@ for (let flags of ["", "u", "g", "gu"]) {
let re = new RegExp(source, flags); let re = new RegExp(source, flags);
assert.throws(SyntaxError, () => "abcd".replace(re, "$<snd"), assert.throws(SyntaxError, () => "abcd".replace(re, "$<snd"),
"unclosed named group in replacement should throw a SyntaxError"); "unclosed named group in replacement should throw a SyntaxError");
assert.throws(SyntaxError, () => "abcd".replace(re, "$<>"),
"empty named group in replacement should throw a SyntaxError");
} }
...@@ -16,9 +16,11 @@ assert.throws(SyntaxError, () => eval("/(?<a>a)(?<a>a)/u"), "Duplicate name"); ...@@ -16,9 +16,11 @@ assert.throws(SyntaxError, () => eval("/(?<a>a)(?<a>a)/u"), "Duplicate name");
assert.throws(SyntaxError, () => eval("/(?<a>a)(?<b>b)(?<a>a)/u"), "Duplicate name"); assert.throws(SyntaxError, () => eval("/(?<a>a)(?<b>b)(?<a>a)/u"), "Duplicate name");
assert.throws(SyntaxError, () => eval("/\\k<a>/u"), "Invalid reference"); assert.throws(SyntaxError, () => eval("/\\k<a>/u"), "Invalid reference");
assert.throws(SyntaxError, () => eval("/\\k<a/u"), "Unterminated reference"); assert.throws(SyntaxError, () => eval("/\\k<a/u"), "Unterminated reference");
assert.throws(SyntaxError, () => eval("/\\k<>/u"), "Empty reference");
assert.throws(SyntaxError, () => eval("/\\k/u"), "Lone \k"); assert.throws(SyntaxError, () => eval("/\\k/u"), "Lone \k");
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k/u"), "Lone \k"); assert.throws(SyntaxError, () => eval("/(?<a>.)\\k/u"), "Lone \k");
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<a/u"), "Unterminated reference"); assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<a/u"), "Unterminated reference");
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<>/u"), "Empty reference");
assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<b>/u"), "Invalid reference"); assert.throws(SyntaxError, () => eval("/(?<a>.)\\k<b>/u"), "Invalid reference");
assert.throws(SyntaxError, () => eval("/(?<a>a)\\k<ab>/u"), "Invalid reference"); assert.throws(SyntaxError, () => eval("/(?<a>a)\\k<ab>/u"), "Invalid reference");
assert.throws(SyntaxError, () => eval("/(?<ab>a)\\k<a>/u"), "Invalid reference"); assert.throws(SyntaxError, () => eval("/(?<ab>a)\\k<a>/u"), "Invalid reference");
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment