add groups object tests

This commit is contained in:
Aleksey Shvayka 2017-06-23 22:59:57 +03:00
parent a2f44c7151
commit c38f1d12b0
2 changed files with 34 additions and 6 deletions

View File

@ -0,0 +1,34 @@
// 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));

View File

@ -31,9 +31,3 @@ assert.sameValue(counter, 0);
verifyWritable(groups, "x");
verifyEnumerable(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));