diff options
Diffstat (limited to 'js/src/tests/test262/built-ins/String/prototype/replaceAll/searchValue-tostring-abrupt.js')
-rw-r--r-- | js/src/tests/test262/built-ins/String/prototype/replaceAll/searchValue-tostring-abrupt.js | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/String/prototype/replaceAll/searchValue-tostring-abrupt.js b/js/src/tests/test262/built-ins/String/prototype/replaceAll/searchValue-tostring-abrupt.js new file mode 100644 index 0000000000..fa7926c90a --- /dev/null +++ b/js/src/tests/test262/built-ins/String/prototype/replaceAll/searchValue-tostring-abrupt.js @@ -0,0 +1,76 @@ +// 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: > + Returns abrupt completions from ToString(searchValue) +info: | + String.prototype.replaceAll ( searchValue, replaceValue ) + + 1. Let O be RequireObjectCoercible(this value). + 2. If searchValue is neither undefined nor null, then + ... + 3. Let string be ? ToString(O). + 4. Let searchString be ? ToString(searchValue). + 5. Let functionalReplace be IsCallable(replaceValue). + 6. If functionalReplace is false, then + a. Let replaceValue be ? ToString(replaceValue). + ... +features: [String.prototype.replaceAll, Symbol] +---*/ + +assert.sameValue( + typeof String.prototype.replaceAll, + 'function', + 'function must exist' +); + +var poisoned = 0; +var poison = { + toString() { + poisoned += 1; + throw 'Should not call toString on replaceValue'; + }, +}; + +var thisValueCalled = 0; +var thisValue = { + toString() { + thisValueCalled += 1; + return ''; + } +}; + +var called = 0; +var searchValue = { + toString() { + called += 1; + throw new Test262Error(); + } +}; + +assert.throws(Test262Error, function() { + ''.replaceAll.call(thisValue, searchValue, poison); +}, 'custom'); +assert.sameValue(called, 1); +assert.sameValue(thisValueCalled, 1); + +thisValueCalled = 0; +called = 0; +searchValue = { + toString() { + called += 1; + return Symbol(); + } +}; + +assert.throws(TypeError, function() { + ''.replaceAll.call(thisValue, searchValue, poison); +}, 'Symbol'); +assert.sameValue(called, 1); +assert.sameValue(thisValueCalled, 1); + +assert.sameValue(poisoned, 0); + +reportCompare(0, 0); |