Refactoring: Pull all fullscreen code out of Document and into its own helper class
[WebKit-https.git] / LayoutTests / webaudio / audionode-connect-order.html
1 <!DOCTYPE html>
2
3 <html>
4 <head>
5 <script src="../resources/js-test.js"></script>
6 <script src="resources/audio-testing.js"></script>
7 </head>
8
9 <body>
10
11 <div id="description"></div>
12 <div id="console"></div>
13
14 <script>
15 description("This tests that we don't trigger an assertion failure due to AudioNode connection order.");
16
17 var sampleRate = 44100.0;
18 var renderLengthSeconds = 0.125;
19 var delayTimeSeconds = 0.1;
20
21 function createSinWaveBuffer(context, lengthInSeconds, frequency) {
22     var audioBuffer = context.createBuffer(1, lengthInSeconds * sampleRate, sampleRate);
23
24     var n = audioBuffer.length;
25     var data = audioBuffer.getChannelData(0);
26
27     for (var i = 0; i < n; ++i) {
28         data[i] = Math.sin(frequency * 2 * Math.PI * i / sampleRate);
29     }
30
31     return audioBuffer;
32 }
33
34 function runTest() {
35     window.jsTestIsAsync = true;
36         
37     // Create offline audio context.
38     var context = new webkitOfflineAudioContext(1, sampleRate * renderLengthSeconds, sampleRate);
39     var toneBuffer = createSinWaveBuffer(context, renderLengthSeconds, 880);
40     
41     var bufferSource = context.createBufferSource();
42     bufferSource.buffer = toneBuffer;
43     bufferSource.connect(context.destination);
44
45     var delay = context.createDelay();
46     delay.delayTime.value = delayTimeSeconds;
47
48     // We connect delay node to gain node before anything is connected to delay node itself.
49     // We do this because we try to trigger the ASSERT which might be fired due to AudioNode connection order,
50     // especially when gain node and delay node is involved e.g. https://bugs.webkit.org/show_bug.cgi?id=76685.
51
52     var gain = context.createGain();
53     gain.connect(context.destination);
54     delay.connect(gain);
55
56     bufferSource.start(0);
57
58     context.oncomplete = finishJSTest;
59     context.startRendering();
60 }
61
62 runTest();
63
64 </script>
65 </body>
66 </html>