gecko-dev/content/media/webaudio/test/test_delayNodeTailIncrease.html
Karl Tomlinson 45cc079f92 b=938450 rename compareBuffers to compareChannels & add compareBuffers f=ehsan
--HG--
extra : transplant_source : %93W%BC%84%FF%10%9B%F5%CD5%98%0E%F0/%F2R%B9W%1E%94
2013-12-03 12:13:15 +13:00

72 lines
2.0 KiB
HTML

<!DOCTYPE HTML>
<html>
<head>
<title>Test increasing delay of DelayNode after input finishes</title>
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
<script type="text/javascript" src="webaudio.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body>
<pre id="test">
<script class="testbody" type="text/javascript">
SimpleTest.waitForExplicitFinish();
const signalLength = 100;
const bufferSize = 1024;
// Delay should be long enough to allow CC to run
const delayBufferCount = 50;
const delayLength = delayBufferCount * bufferSize + 700;
var count = 0;
function applySignal(buffer, offset) {
for (var i = 0; i < signalLength; ++i) {
buffer.getChannelData(0)[offset + i] = Math.cos(Math.PI * i / signalLength);
}
}
function onAudioProcess(e) {
switch(count) {
case 5:
SpecialPowers.forceGC();
SpecialPowers.forceCC();
break;
case delayBufferCount:
var offset = delayLength - count * bufferSize;
var ctx = e.target.context;
var expected = ctx.createBuffer(1, bufferSize, ctx.sampleRate);
applySignal(expected, offset);
compareBuffers(e.inputBuffer, expected);
SimpleTest.finish();
}
count++;
}
function startTest() {
var ctx = new AudioContext();
var processor = ctx.createScriptProcessor(bufferSize, 1, 0);
processor.onaudioprocess = onAudioProcess;
// Switch on delay at a time in the future.
var delayDuration = delayLength / ctx.sampleRate;
var delayStartTime = (delayLength - bufferSize) / ctx.sampleRate;
var delay = ctx.createDelay(delayDuration);
delay.delayTime.setValueAtTime(delayDuration, delayStartTime);
delay.connect(processor);
// Short signal that finishes before switching to long delay
var buffer = ctx.createBuffer(1, signalLength, ctx.sampleRate);
applySignal(buffer, 0);
var source = ctx.createBufferSource();
source.buffer = buffer;
source.start();
source.connect(delay);
};
startTest();
</script>
</pre>
</body>
</html>