summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/Date/prototype/Symbol.toPrimitive/hint-invalid.js
blob: 243a4ef2062dd2f2c7fbae7c0d37a4cf5111a4b7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
// Copyright (C) 2015 the V8 project authors. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-date.prototype-@@toprimitive
description: Behavior when an invalid `hint` argument is specified
info: |
    1. Let O be the this value.
    2. If Type(O) is not Object, throw a TypeError exception.
    3. If hint is the String value "string" or the String value "default", then
       a. Let tryFirst be "string".
    4. Else if hint is the String value "number", then
       a. Let tryFirst be "number".
    5. Else, throw a TypeError exception.
features: [Symbol.toPrimitive]
---*/

var d = new Date();

assert.sameValue(typeof d[Symbol.toPrimitive], 'function');

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive]();
});

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive](undefined);
});

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive](null);
});

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive]('');
});

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive]('String');
});

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive]('defaultnumber');
});

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive](new String('number'));
});

assert.throws(TypeError, function() {
  d[Symbol.toPrimitive]({
    toString: function() {
      'number';
    }
  });
});

reportCompare(0, 0);