Add String.prototype.replace test

This commit is contained in:
Alexey Shvayka 2020-04-06 15:20:47 +03:00 committed by Rick Waldron
parent d8a6a06dcd
commit f21c828965
1 changed files with 34 additions and 0 deletions

View File

@ -0,0 +1,34 @@
// Copyright (C) 2020 Alexey Shvayka. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-string.prototype.replace
description: >
If searchValue's Symbol.replace property is null, no error is thrown.
info: |
String.prototype.replace ( searchValue, replaceValue )
[...]
2. If searchValue is neither undefined nor null, then
a. Let replacer be ? GetMethod(searchValue, @@replace).
b. If replacer is not undefined, then
[...]
[...]
12. Return newString.
GetMethod ( V, P )
[...]
2. Let func be ? GetV(V, P).
3. If func is either undefined or null, return undefined.
features: [Symbol.replace]
---*/
var searchValue = {};
searchValue[Symbol.replace] = null;
searchValue.toString = function() { return "3"; };
searchValue.valueOf = function() { throw new Test262Error("should not be called"); };
var replacer = function() { return "<foo>"; };
assert.sameValue("ab3c".replace(searchValue, replacer), "ab<foo>c");
assert.sameValue("ab3c".replace(searchValue, "<foo>"), "ab<foo>c");