| OLD | NEW |
| 1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
| 2 | |
| 3 <!-- | 2 <!-- |
| 4 Test AudioBufferSourceNode supports 5.1 channel. | 3 Test AudioBufferSourceNode supports 5.1 channel. |
| 5 --> | 4 --> |
| 5 <html> |
| 6 <head> |
| 7 <title> |
| 8 audiobuffersource-multi-channels.html |
| 9 </title> |
| 10 <script src="../../resources/testharness.js"></script> |
| 11 <script src="../../resources/testharnessreport.js"></script> |
| 12 <script src="../resources/audit-util.js"></script> |
| 13 <script src="../resources/audit.js"></script> |
| 14 <script src="../resources/mix-testing.js"></script> |
| 15 </head> |
| 16 <body> |
| 17 <script id="layout-test-code"> |
| 18 let audit = Audit.createTaskRunner(); |
| 19 let context; |
| 20 let expectedAudio; |
| 6 | 21 |
| 7 <html> | 22 audit.define('initialize', (task, should) => { |
| 8 <head> | 23 // Create offline audio context |
| 9 <script src="../../resources/testharness.js"></script> | 24 let sampleRate = 44100.0; |
| 10 <script src="../../resources/testharnessreport.js"></script> | 25 should(() => { |
| 11 <script src="../resources/audit-util.js"></script> | 26 context = new OfflineAudioContext( |
| 12 <script src="../resources/audit.js"></script> | 27 6, sampleRate * toneLengthSeconds, sampleRate); |
| 13 <script src="../resources/mix-testing.js"></script> | 28 }, 'Creating context for testing').notThrow(); |
| 14 </head> | 29 should( |
| 15 <body> | 30 Audit |
| 31 .loadFileFromUrl( |
| 32 'audiobuffersource-multi-channels-expected.wav') |
| 33 .then(arrayBuffer => { |
| 34 context.decodeAudioData(arrayBuffer).then(audioBuffer => { |
| 35 expectedAudio = audioBuffer; |
| 36 }); |
| 37 }), |
| 38 'Fetching expected audio') |
| 39 .beResolved() |
| 40 .then(() => task.done()); |
| 16 | 41 |
| 17 <script> | 42 }); |
| 18 let audit = Audit.createTaskRunner(); | |
| 19 let context; | |
| 20 let expectedAudio; | |
| 21 | |
| 22 audit.define('initialize', (task, should) => { | |
| 23 // Create offline audio context | |
| 24 let sampleRate = 44100.0; | |
| 25 should(() => { | |
| 26 context = | |
| 27 new OfflineAudioContext(6, sampleRate * toneLengthSeconds, sampleRate); | |
| 28 }, 'Creating context for testing').notThrow(); | |
| 29 should( | |
| 30 Audit.loadFileFromUrl('audiobuffersource-multi-channels-expected.wav') | |
| 31 .then(arrayBuffer => { | |
| 32 context.decodeAudioData(arrayBuffer).then(audioBuffer => { | |
| 33 expectedAudio = audioBuffer; | |
| 34 }); | |
| 35 }), | |
| 36 'Fetching expected audio') | |
| 37 .beResolved() | |
| 38 .then(() => task.done()); | |
| 39 | 43 |
| 40 }); | 44 audit.define( |
| 45 {label: 'test', description: 'AudioBufferSource with 5.1 buffer'}, |
| 46 (task, should) => { |
| 47 let toneBuffer = |
| 48 createToneBuffer(context, 440, toneLengthSeconds, 6); |
| 41 | 49 |
| 42 audit.define( | 50 let source = context.createBufferSource(); |
| 43 {label: 'test', description: 'AudioBufferSource with 5.1 buffer'}, | 51 source.buffer = toneBuffer; |
| 44 (task, should) => { | |
| 45 let toneBuffer = createToneBuffer(context, 440, toneLengthSeconds, 6); | |
| 46 | 52 |
| 47 let source = context.createBufferSource(); | 53 source.connect(context.destination); |
| 48 source.buffer = toneBuffer; | 54 source.start(0); |
| 49 | 55 |
| 50 source.connect(context.destination); | 56 context.startRendering() |
| 51 source.start(0); | 57 .then(renderedAudio => { |
| 58 // Compute a threshold based on the maximum error, |maxUlp|, |
| 59 // in ULP. This is experimentally determined. Assuming that |
| 60 // the reference file is a 16-bit wav file, the max values in |
| 61 // the wave file are +/- 32768. |
| 62 let maxUlp = 1; |
| 63 let threshold = maxUlp / 32768; |
| 52 | 64 |
| 53 context.startRendering() | 65 for (let k = 0; k < renderedAudio.numberOfChannels; ++k) { |
| 54 .then(renderedAudio => { | 66 should( |
| 55 // Compute a threshold based on the maximum error, |maxUlp|, in ULP. | 67 renderedAudio.getChannelData(k), |
| 56 // This is experimentally determined. Assuming that the reference | 68 'Rendered audio for channel ' + k) |
| 57 // file is a 16-bit wav file, the max values in the wave file | 69 .beCloseToArray( |
| 58 // are +/- 32768. | 70 expectedAudio.getChannelData(k), |
| 59 let maxUlp = 1; | 71 {absoluteThreshold: threshold}); |
| 60 let threshold = maxUlp / 32768; | 72 } |
| 73 }) |
| 74 .then(() => task.done()); |
| 75 }); |
| 61 | 76 |
| 62 for (let k = 0; k < renderedAudio.numberOfChannels; ++k) { | 77 audit.run(); |
| 63 should( | 78 </script> |
| 64 renderedAudio.getChannelData(k), | 79 </body> |
| 65 'Rendered audio for channel ' + k) | |
| 66 .beCloseToArray( | |
| 67 expectedAudio.getChannelData(k), | |
| 68 {absoluteThreshold: threshold}); | |
| 69 } | |
| 70 }) | |
| 71 .then(() => task.done()); | |
| 72 }); | |
| 73 | |
| 74 audit.run(); | |
| 75 </script> | |
| 76 | |
| 77 </body> | |
| 78 </html> | 80 </html> |
| OLD | NEW |