v8/test/mjsunit/es6/pattern-brand-check.js
adamk 0fdf32556c String.prototype.{match,search} should do only one RegExp brand check
Previously, they would check for Symbol.match/Symbol.search, and then
do another check for Symbol.match in the RegExp constructor. This patch
avoids the second one by skipping the RegExp constructor, as the spec does.

Review URL: https://codereview.chromium.org/1840723002

Cr-Commit-Position: refs/heads/master@{#35085}
2016-03-28 18:53:39 +00:00

55 lines
1.3 KiB
JavaScript

// 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.
// Flags: --harmony-regexp-subclass
function createNonRegExp(calls) {
return {
get [Symbol.match]() {
calls.push("@@match");
return undefined;
},
get [Symbol.replace]() {
calls.push("@@replace");
return undefined;
},
get [Symbol.search]() {
calls.push("@@search");
return undefined;
},
get [Symbol.split]() {
calls.push("@@split");
return undefined;
},
[Symbol.toPrimitive]() {
calls.push("@@toPrimitive");
return "";
}
};
}
(function testStringMatchBrandCheck() {
var calls = [];
"".match(createNonRegExp(calls));
assertEquals(["@@match", "@@toPrimitive"], calls);
})();
(function testStringSearchBrandCheck() {
var calls = [];
"".search(createNonRegExp(calls));
assertEquals(["@@search", "@@toPrimitive"], calls);
})();
(function testStringSplitBrandCheck() {
var calls = [];
"".split(createNonRegExp(calls));
assertEquals(["@@split", "@@toPrimitive"], calls);
})();
(function testStringReplaceBrandCheck() {
var calls = [];
"".replace(createNonRegExp(calls), "");
assertEquals(["@@replace", "@@toPrimitive"], calls);
})();