Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(671)

Side by Side Diff: LayoutTests/webaudio/offlineaudiocontext-suspend-resume-basic.html

Issue 1140723003: Implement suspend() and resume() for OfflineAudioContext (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Restructured the resolution of suspend promise Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 <!doctype html>
2 <html>
3 <head>
4 <script src="../resources/js-test.js"></script>
5 <script src="resources/compatibility.js"></script>
6 <script src="resources/audio-testing.js"></script>
7 </head>
8
9 <body>
10 <script>
11 description('Suspending OfflineAudioContext at the same rendering block bo undary.');
12 window.jsTestIsAsync = true;
13
14 var sampleRate = 44100;
15 var renderDuration = 1;
16 var renderQuantum = 128;
17
18 var audit = Audit.createTaskRunner();
19
20 // Task: Calling suspend with no argument should reject the promise.
21 audit.defineTask('suspend-no-argument', function (done) {
22 var context = new OfflineAudioContext(1, sampleRate * renderDuration, sa mpleRate);
23
24 Should('context.suspend()', context.suspend()).beRejected().then(done);
25 });
26
27 // Task: Calling multiple suspends at the same rendering quantum should re ject
28 // the promise.
29 audit.defineTask('identical-suspend-time', function (done) {
30 var context = new OfflineAudioContext(1, sampleRate * renderDuration, sa mpleRate);
31 var suspendTime1 = renderQuantum / sampleRate;
32 var suspendTime2 = (renderQuantum + renderQuantum * 0.5) / sampleRate;
33
34 context.suspend(suspendTime1);
35
36 Should('Calling multiple suspends at the same rendering quantum',
37 context.suspend(suspendTime2)).beRejected().then(done);
38 });
39
40 // Task: Resuming the context before the actual suspension happens.
41 audit.defineTask('resume-before-suspend', function (done) {
42 var context = new OfflineAudioContext(1, sampleRate * renderDuration, sa mpleRate);
43
44 // Note that suspend is scheduled at 0.5 (after quantizing), but the res ume()
45 // in the next will be executed immediately after.
46 context.suspend(0.5);
47
48 Should('Resuming before suspend', context.resume()).beRejected().then(do ne);
49 });
50
51 // Task: Calling resume on non-suspended context should reject the promise .
52 audit.defineTask('resume-without-suspend', function (done) {
53 var context = new OfflineAudioContext(1, sampleRate * renderDuration, sa mpleRate);
54
55 Should('Calling resume on non-suspended context', context.resume())
56 .beRejected().then(done);
57 });
58
59 audit.defineTask('finish', function (done) {
60 finishJSTest();
61 done();
62 });
63
64 audit.runTasks(
65 'suspend-no-argument',
66 'identical-suspend-time',
67 'resume-before-suspend',
68 'resume-without-suspend',
69 'finish'
70 );
71
72 successfullyParsed = true;
73 </script>
74
75 </body>
76 </html>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698