summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/webrtc/RTCError.html
blob: bcc5749bf7d5e69fd3d674ac33564403e41e9985 (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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<!doctype html>
<meta charset=utf-8>
<title>RTCError and RTCErrorInit</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="RTCPeerConnection-helper.js"></script>
<script>
'use strict';

test(() => {
  const error = new RTCError({errorDetail:'data-channel-failure'}, 'message');
  assert_equals(error.message, 'message');
  assert_equals(error.errorDetail, 'data-channel-failure');
}, 'RTCError constructor with errorDetail and message');

test(() => {
  const error = new RTCError({errorDetail:'data-channel-failure'});
  assert_equals(error.message, '');
}, 'RTCError constructor\'s message argument is optional');

test(() => {
  assert_throws_js(TypeError, () => {
    new RTCError();
  });
  assert_throws_js(TypeError, () => {
    new RTCError({});  // {errorDetail} is missing.
  });
}, 'RTCError constructor throws TypeError if arguments are missing');

test(() => {
  assert_throws_js(TypeError, () => {
    new RTCError({errorDetail:'invalid-error-detail'}, 'message');
  });
}, 'RTCError constructor throws TypeError if the errorDetail is invalid');

test(() => {
  const error = new RTCError({errorDetail:'data-channel-failure'}, 'message');
  assert_equals(error.name, 'OperationError');
}, 'RTCError.name is \'OperationError\'');

test(() => {
  const error = new RTCError({errorDetail:'data-channel-failure'}, 'message');
  assert_equals(error.code, 0);
}, 'RTCError.code is 0');

test(() => {
  const error = new RTCError({errorDetail:'data-channel-failure'}, 'message');
  assert_throws_js(TypeError, () => {
    error.errorDetail = 'dtls-failure';
  });
}, 'RTCError.errorDetail is readonly.');

test(() => {
  // Infers what are valid RTCErrorInit objects by passing them to the RTCError
  // constructor.
  assert_throws_js(TypeError, () => {
    new RTCError({}, 'message');
  });
  new RTCError({errorDetail:'data-channel-failure'}, 'message');
}, 'RTCErrorInit.errorDetail is the only required attribute');

// All of these are number types (long or unsigned long).
const nullableAttributes = ['sdpLineNumber',
                            'httpRequestStatusCode',
                            'sctpCauseCode',
                            'receivedAlert',
                            'sentAlert'];

nullableAttributes.forEach(attribute => {
  test(() => {
    const error = new RTCError({errorDetail:'data-channel-failure'}, 'message');
    assert_equals(error[attribute], null);
  }, 'RTCError.' + attribute + ' is null by default');

  test(() => {
    const error = new RTCError(
        {errorDetail:'data-channel-failure', [attribute]: 0}, 'message');
    assert_equals(error[attribute], 0);
  }, 'RTCError.' + attribute + ' is settable by constructor');

  test(() => {
    const error = new RTCError({errorDetail:'data-channel-failure'}, 'message');
    assert_throws_js(TypeError, () => {
      error[attribute] = 42;
    });
  }, 'RTCError.' + attribute + ' is readonly');
});

</script>