// 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); reportCompare(0, 0);