summaryrefslogtreecommitdiffstats
path: root/dom/media/tests/mochitest/test_peerConnection_restartIceLocalAndRemoteRollback.html
blob: e9261716447879e5fbdf83c416c3d4849588da80 (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
90
91
92
93
94
95
96
97
98
<!DOCTYPE HTML>
<html>
<head>
  <script type="application/javascript" src="pc.js"></script>
</head>
<body>
<pre id="test">
<script type="application/javascript">
  createHTML({
    bug: "906986",
    title: "Renegotiation: restart ice, local and remote rollback"
  });

  var test;
  runNetworkTest(function (options) {
    test = new PeerConnectionTest(options);

    addRenegotiation(test.chain,
      [
        // causes a full, normal ice restart
        function PC_LOCAL_SET_OFFER_OPTION(test) {
          test.setOfferOptions({ iceRestart: true });
        }
      ]
    );

    test.chain.replaceAfter('PC_REMOTE_CREATE_ANSWER',
      [
        function PC_LOCAL_SETUP_ICE_HANDLER(test) {
          test.pcLocal.setupIceCandidateHandler(test);
          if (test.testOptions.steeplechase) {
            test.pcLocal.endOfTrickleIce.then(() => {
              send_message({"type": "end_of_trickle_ice"});
            });
          }
        },
        function PC_REMOTE_SETUP_ICE_HANDLER(test) {
          test.pcRemote.setupIceCandidateHandler(test);
          if (test.testOptions.steeplechase) {
            test.pcRemote.endOfTrickleIce.then(() => {
              send_message({"type": "end_of_trickle_ice"});
            });
          }
        },

        function PC_LOCAL_EXPECT_ICE_CONNECTED(test) {
          test.pcLocal.iceCheckingIceRollbackExpected = true;
        },
        function PC_REMOTE_EXPECT_ICE_CONNECTED(test) {
          test.pcRemote.iceCheckingIceRollbackExpected = true;
        },

        function PC_REMOTE_ROLLBACK(test) {
          return test.setRemoteDescription(
              test.pcRemote,
              new RTCSessionDescription({ type: "rollback" }),
              STABLE);
        },

        function PC_LOCAL_ROLLBACK(test) {
          // We haven't negotiated the new stream yet.
          test.pcLocal.expectNegotiationNeeded();
          return test.setLocalDescription(
              test.pcLocal,
              new RTCSessionDescription({ type: "rollback", sdp: ""}),
              STABLE);
        },

        // Rolling back should shut down gathering
        function PC_LOCAL_WAIT_FOR_END_OF_TRICKLE(test) {
          return test.pcLocal.endOfTrickleIce;
        },
        function PC_REMOTE_WAIT_FOR_END_OF_TRICKLE(test) {
          return test.pcRemote.endOfTrickleIce;
        },

        function PC_LOCAL_EXPECT_ICE_CHECKING(test) {
          test.pcLocal.expectIceChecking();
        },
        function PC_REMOTE_EXPECT_ICE_CHECKING(test) {
          test.pcRemote.expectIceChecking();
        }
      ],
      1 // Replaces after second PC_REMOTE_CREATE_ANSWER
    );
    test.chain.append(commandsPeerConnectionOfferAnswer);

    // for now, only use one stream, because rollback doesn't seem to
    // like multiple streams.  See bug 1259465.
    test.setMediaConstraints([{audio: true}],
                             [{audio: true}]);
    test.run();
  });

</script>
</pre>
</body>
</html>