Bug 1472550 - Add a little regression test. r=karlt

A more involved test exists as a web-platform-tests, but we can't run it because
it makes use of AudioListener AudioParam, that we don't have right now.

MozReview-Commit-ID: 8QJ12cGVRbQ

--HG--
extra : rebase_source : 6161e33d7d8ef83eb5e16a4570a770401dd672cd
This commit is contained in:
Paul Adenot 2018-07-06 18:58:21 +02:00
Родитель 284eb8630d
Коммит b752303705
2 изменённых файлов: 44 добавлений и 0 удалений

Просмотреть файл

@ -198,6 +198,7 @@ skip-if = toolkit == 'android' # bug 1091965
[test_oscillatorTypeChange.html]
[test_pannerNode.html]
[test_pannerNode_equalPower.html]
[test_pannerNode_audioparam_distance.html]
[test_pannerNodeAbove.html]
[test_pannerNodeAtZeroDistance.html]
[test_pannerNodeChannelCount.html]

Просмотреть файл

@ -0,0 +1,43 @@
<!DOCTYPE HTML>
<html>
<head>
<title>Distance effect of a PannerNode with the position set via AudioParams (Bug 1472550)</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();
var o = new OfflineAudioContext(2, 256, 44100);
// We want a stereo constant source.
var b = o.createBuffer(2, 1, 44100);
b.getChannelData(0)[0] = 1;
b.getChannelData(1)[0] = 1;
var c = o.createBufferSource();
c.buffer = b;
c.loop = true;
var p = o.createPanner();
p.positionY.setValueAtTime(1, 0);
p.positionX.setValueAtTime(1, 0);
p.positionZ.setValueAtTime(1, 0);
// Set the listener somewhere far
o.listener.setPosition(20, 2, 20);
c.start();
c.connect(p).connect(o.destination);
o.startRendering().then((ab) => {
// Check that the distance attenuates the sound.
ok(ab.getChannelData(0)[0] < 0.1, "left channel must be very quiet");
ok(ab.getChannelData(1)[0] < 0.1, "right channel must be very quiet");
SimpleTest.finish();
});
</script>
</pre>
</body>
</html>