File: routines.js

package info (click to toggle)
firefox-esr 140.6.0esr-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,552,424 kB
  • sloc: cpp: 7,430,808; javascript: 6,389,773; ansic: 3,712,263; python: 1,393,776; xml: 628,165; asm: 426,918; java: 184,004; sh: 65,744; makefile: 19,302; objc: 13,059; perl: 12,912; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,226; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (93 lines) | stat: -rw-r--r-- 3,261 bytes parent folder | download | duplicates (16)
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
async function getNextMessage(portOrWorker) {
  return new Promise(resolve => {
    const resolveWithData = event => resolve(event.data);
    const rejectWithData = event => reject(event.data);
    portOrWorker.addEventListener('message', resolveWithData, {once: true});
    portOrWorker.addEventListener('messageerror', rejectWithData, {once: true});
  });
}


async function postMethod(port, method, options) {
  port.postMessage(Object.assign({method}, options));
  return await getNextMessage(port);
}

async function createWorker(script) {
  const worker = new Worker(script);
  const data = await getNextMessage(worker);
  assert_equals(data, "registered");
  return worker;
}

async function createTransform(worker) {
  const channel = new MessageChannel;
  const transform = new RTCRtpScriptTransform(worker, {name:'MockRTCRtpTransform', port: channel.port2}, [channel.port2]);
  transform.port = channel.port1;
  channel.port1.start();
  assert_equals(await getNextMessage(channel.port1), "started");
  return transform;
}

async function createTransforms(script) {
  const worker = await createWorker(script)
  return Promise.all([createTransform(worker), createTransform(worker)]);
}

async function createConnectionWithTransform(test, script, gumOptions) {
  const [senderTransform, receiverTransform] = await createTransforms(script);

  const localStream = await navigator.mediaDevices.getUserMedia(gumOptions);

  let senderPc, receiverPc, sender, receiver;

  await createConnections(test, (firstConnection) => {
      senderPc = firstConnection;
      sender = firstConnection.addTrack(localStream.getTracks()[0], localStream);
      sender.transform = senderTransform;
    }, (secondConnection) => {
      receiverPc = secondConnection;
      secondConnection.ontrack = (trackEvent) => {
        receiver = trackEvent.receiver;
        receiver.transform = receiverTransform;
      };
    });

  assert_true(!!sender, "sender should be set");
  assert_true(!!receiver, "receiver should be set");

  return {sender, receiver, senderPc, receiverPc};
}

async function createConnections(test, setupLocalConnection, setupRemoteConnection, doNotCloseAutmoatically) {
    const localConnection = new RTCPeerConnection();
    const remoteConnection = new RTCPeerConnection();

    remoteConnection.onicecandidate = (event) => { localConnection.addIceCandidate(event.candidate); };
    localConnection.onicecandidate = (event) => { remoteConnection.addIceCandidate(event.candidate); };

    await setupLocalConnection(localConnection);
    await setupRemoteConnection(remoteConnection);

    const offer = await localConnection.createOffer();
    await localConnection.setLocalDescription(offer);
    await remoteConnection.setRemoteDescription(offer);

    const answer = await remoteConnection.createAnswer();
    await remoteConnection.setLocalDescription(answer);
    await localConnection.setRemoteDescription(answer);

    if (!doNotCloseAutmoatically) {
        test.add_cleanup(() => {
            localConnection.close();
            remoteConnection.close();
        });
    }

    return [localConnection, remoteConnection];
}

function waitFor(test, duration)
{
    return new Promise((resolve) => test.step_timeout(resolve, duration));
}