summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/webaudio/the-audio-api/the-mediaelementaudiosourcenode-interface/no-cors.https.html
blob: de2f0b7dd3b680cbb38d1b0546c6656b1e03e1b2 (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
<!DOCTYPE html>
<html>
  <head>
    <title>
      Test if MediaElementAudioSourceNode works for cross-origin redirects with
      "no-cors" request mode.
    </title>
    <script src="/resources/testharness.js"></script>
    <script src="/resources/testharnessreport.js"></script>
    <script src="/webaudio/resources/audit.js"></script>
    <script src="/common/get-host-info.sub.js"></script>
  </head>
  <body>
    <script id="layout-test-code">
      const audit = Audit.createTaskRunner();

      setup(() => {
        const context = new AudioContext();
        context.suspend();

        const host_info = get_host_info();
        const audioElement = document.createElement('audio');
        audioElement.loop = true;
        const wav =
            host_info.HTTPS_ORIGIN + '/webaudio/resources/4ch-440.wav?' +
            'pipe=header(access-control-allow-origin,*)';
        audioElement.src =
            host_info.HTTPS_REMOTE_ORIGIN +
            '/fetch/api/resources/redirect.py?location=' +
            encodeURIComponent(wav);
        let source;
        let workletRecorder;

        audit.define(
            {label: 'setting-up-graph'},
            (task, should) => {
              source = new MediaElementAudioSourceNode(context, {
                mediaElement: audioElement
              });
              workletRecorder = new AudioWorkletNode(
                  context, 'recorder-processor', {channelCount: 4});
              source.connect(workletRecorder).connect(context.destination);
              task.done();
            });

        // The recorded data from MESN must be non-zero. The source file contains
        // 4 channels of sine wave.
        audit.define(
            {label: 'start-playback-and-capture'},
            (task, should) => {
              workletRecorder.port.onmessage = (event) => {
                if (event.data.type === 'recordfinished') {
                  for (let i = 0; i < event.data.recordBuffer.length; ++i) {
                    const channelData = event.data.recordBuffer[i];
                    should(channelData, `Recorded channel #${i}`)
                        .beConstantValueOf(0);
                  }
                }

                task.done();
              };

              context.resume();
              audioElement.play();
            });

        Promise.all([
          context.audioWorklet.addModule('/webaudio/js/worklet-recorder.js')
        ]).then(() => {
          audit.run();
        });
      });
    </script>
  </body>
</html>