summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/webaudio/the-audio-api/the-audiobuffersourcenode-interface/note-grain-on-timing.html
blob: 0db297b42cca3de45cdd212af1373fdc553729a5 (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
<!DOCTYPE html>
<html>
  <head>
    <title>
      note-grain-on-timing.html
    </title>
    <script src="/resources/testharness.js"></script>
    <script src="/resources/testharnessreport.js"></script>
    <script src="/webaudio/resources/audit-util.js"></script>
    <script src="/webaudio/resources/audit.js"></script>
    <script src="/webaudio/resources/note-grain-on-testing.js"></script>
  </head>
  <body>
    <script id="layout-test-code">
      let audit = Audit.createTaskRunner();

      let squarePulseBuffer;

      function checkResult(buffer, should) {
        renderedData = buffer.getChannelData(0);
        let nSamples = renderedData.length;
        let startEndFrames = findStartAndEndSamples(renderedData);

        verifyStartAndEndFrames(startEndFrames, should);
      }

      audit.define('Test timing of noteGrainOn', function(task, should) {
        // Create offline audio context.
        context =
            new OfflineAudioContext(2, sampleRate * renderTime, sampleRate);

        squarePulseBuffer = createSignalBuffer(context, function(k) {
          return 1
        });

        playAllGrains(context, squarePulseBuffer, numberOfTests);

        context.startRendering().then(function(audioBuffer) {
          checkResult(audioBuffer, should);
          task.done();
        });
      });

      audit.run();
    </script>
  </body>
</html>