summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/NativeErrors/AggregateError/message-tostring-abrupt-symbol.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/built-ins/NativeErrors/AggregateError/message-tostring-abrupt-symbol.js')
-rw-r--r--js/src/tests/test262/built-ins/NativeErrors/AggregateError/message-tostring-abrupt-symbol.js41
1 files changed, 41 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/NativeErrors/AggregateError/message-tostring-abrupt-symbol.js b/js/src/tests/test262/built-ins/NativeErrors/AggregateError/message-tostring-abrupt-symbol.js
new file mode 100644
index 0000000000..fff1b0051c
--- /dev/null
+++ b/js/src/tests/test262/built-ins/NativeErrors/AggregateError/message-tostring-abrupt-symbol.js
@@ -0,0 +1,41 @@
+// Copyright (C) 2019 Leo Balter. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-aggregate-error
+description: >
+ Abrupt completions of ToString(Symbol message)
+info: |
+ AggregateError ( errors, message )
+
+ ...
+ 5. If message is not undefined, then
+ a. Let msg be ? ToString(message).
+ b. Perform ! CreateMethodProperty(O, "message", msg).
+ 6. Return O.
+features: [AggregateError, Symbol, Symbol.toPrimitive]
+---*/
+
+var case1 = Symbol();
+
+assert.throws(TypeError, () => {
+ new AggregateError([], case1);
+}, 'toPrimitive');
+
+var case2 = {
+ [Symbol.toPrimitive]() {
+ return Symbol();
+ },
+ toString() {
+ throw new Test262Error();
+ },
+ valueOf() {
+ throw new Test262Error();
+ }
+};
+
+assert.throws(TypeError, () => {
+ new AggregateError([], case2);
+}, 'from ToPrimitive');
+
+reportCompare(0, 0);