File: MediaRecorder-peerconnection.https.html

package info (click to toggle)
firefox-esr 78.15.0esr-1~deb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 3,301,156 kB
  • sloc: cpp: 5,665,905; javascript: 4,798,386; ansic: 2,878,233; python: 977,004; asm: 270,347; xml: 181,456; java: 111,756; sh: 72,926; makefile: 21,819; perl: 13,380; cs: 4,725; yacc: 4,565; objc: 3,026; pascal: 1,787; lex: 1,720; ada: 1,681; exp: 505; php: 436; lisp: 260; awk: 152; ruby: 103; csh: 80; sed: 53; sql: 45
file content (73 lines) | stat: -rw-r--r-- 3,095 bytes parent folder | download | duplicates (4)
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
<!doctype html>
<html>
<meta name="timeout" content="long">

<head>
  <title>MediaRecorder peer connection</title>
  <link rel="help"
        href="https://w3c.github.io/mediacapture-record/MediaRecorder.html#dom-mediarecorder-mimeType">
  <script src="/resources/testharness.js"></script>
  <script src="/resources/testharnessreport.js"></script>
  <script src="utils/peerconnection.js"></script>
</head>

<body>
  <video id="remote" autoplay width="240" />
  <script>

[{ name: "video", kind: { video: true, audio: false }, mimeType: "" },
 { name: "audio", kind: { video: false, audio: true }, mimeType: "" },
 { name: "audio/video", kind: { video: true, audio: true }, mimeType: "" },
 { name: "audio", kind: { video: false, audio: true }, mimeType: "video/webm;codecs=vp8" },
 { name: "video", kind: { video: true, audio: false }, mimeType: "video/webm;codecs=vp8" },
 { name: "audio/video", kind: { video: true, audio: true }, mimeType: "video/webm;codecs=vp8" },
 { name: "audio", kind: { video: false, audio: true }, mimeType: "video/webm;codecs=vp9" },
 { name: "video", kind: { video: true, audio: false }, mimeType: "video/webm;codecs=vp9" },
 { name: "audio/video", kind: { video: true, audio: true }, mimeType: "video/webm;codecs=vp9" }]
  .forEach(args => {
    const formatString = JSON.stringify(args.kind) +
        " with format " + (args.mimeType ? args.mimeType : "[passthrough]") + ".";
    promise_test(async t => {
      const [localPc, remotePc, stream] = await startConnection(
          t, args.kind.audio, args.kind.video);
      const recorder = new MediaRecorder(stream, { mimeType: args.mimeType });
      let combinedSize = 0;
      const dataPromise = new Promise(r => {
        recorder.onstart = () => {
          recorder.ondataavailable = e => {
            // Wait for an arbitrary amount of data to appear before we resolve.
            combinedSize += e.data.size;
            if (combinedSize > 4711) r();
          }
        }
      });
      recorder.start(100);
      await dataPromise;
      recorder.stop();
    }, "PeerConnection MediaRecorder receives data after onstart, " +
          formatString);

    promise_test(async t => {
      const [localPc, remotePc, stream] = await startConnection(
          t, args.kind.audio, args.kind.video);
      const recorder = new MediaRecorder(stream, { mimeType: args.mimeType });
      const stopPromise = new Promise(r => recorder.onstop = r);
      const dataPromise = new Promise(r => recorder.ondataavailable = r);
      recorder.start();
      await waitForReceivedFrames(
        t, remotePc, args.kind.audio, args.kind.video, 10);
      for (transceiver of remotePc.getTransceivers())
        transceiver.receiver.track.stop();
      // As the tracks ended, we'd like to see data from the recorder.
      // For details:
      // https://www.w3.org/TR/mediastream-recording/#mediarecorder-methods.
      await dataPromise;
      await stopPromise;
    }, "PeerConnection MediaRecorder gets ondata on stopping recorded " +
            "tracks " + formatString);
  });

  </script>
</body>

</html>