blob: 86b2f4bf10f948e041dcc0751c3500d11c12d1da [file] [log] [blame]
// Copyright (C) 2019 Leo Balter. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-string.prototype.replaceall
description: >
The searchValue is observed before ToString(this value) and ToString(replaceValue)
info: |
String.prototype.replaceAll ( searchValue, replaceValue )
1. Let O be RequireObjectCoercible(this value).
2. If searchValue is neither undefined nor null, then
a. Let isRegExp be ? IsRegExp(searchString).
b. If isRegExp is true, then
i. Let flags be ? Get(searchValue, "flags").
ii. Perform ? RequireObjectCoercible(flags).
iii. If ? ToString(flags) does not contain "g", throw a TypeError exception.
c. Let replacer be ? GetMethod(searchValue, @@replace).
d. If replacer is not undefined, then
i. Return ? Call(replacer, searchValue, « O, replaceValue »).
3. Let string be ? ToString(O).
4. Let searchString be ? ToString(searchValue).
...
features: [String.prototype.replaceAll, Symbol.replace]
---*/
var called = 0;
var searchValue = /./g;
Object.defineProperty(searchValue, Symbol.replace, {
value: function(O, replaceValue) {
assert.sameValue(this, searchValue);
assert.sameValue(O, poison, 'first arg is the this value of replaceAll');
assert.sameValue(replaceValue, poison, 'second arg is the replaceValue');
assert.sameValue(arguments.length, 2);
called += 1;
return 'return from searchValue';
}
});
Object.defineProperty(searchValue, 'toString', {
value: function() {
throw 'Should not call toString on searchValue';
}
});
var poisoned = 0;
var poison = {
toString() {
poisoned += 1;
throw 'Should not call toString on this/replaceValue';
},
};
var returned = ''.replaceAll.call(poison, searchValue, poison);
assert.sameValue(returned, 'return from searchValue');
assert.sameValue(called, 1);
assert.sameValue(poisoned, 0);