fune/testing/web-platform/tests/webcodecs/audio-data-serialization.any.js
Thomas Guilbert fe58297bbb Bug 1777109 [wpt PR 34632] - Make AudioData transferable, a=testonly
Automatic update from web-platform-tests
Make AudioData transferable

The WebCodecs spec says AudioData should be transferable. This CL
mirrors the CL which made VideoFrames transferable [1], and adds
tranferability to AudioData.

[1]: https://chromium-review.googlesource.com/c/chromium/src/+/2719085

Bug: 1338935
Change-Id: I3b9799380331e9c823bb7f618729159318648064
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3733397
Reviewed-by: Dan Sanders <sandersd@chromium.org>
Commit-Queue: Thomas Guilbert <tguilbert@chromium.org>
Reviewed-by: Jeremy Roman <jbroman@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1021321}

--

wpt-commits: e6e73f3e041c74353ab6dafba08e512ef511e596
wpt-pr: 34632
2022-07-13 15:05:39 +00:00

93 lines
No EOL
2.6 KiB
JavaScript

// META: global=window
// META: script=/common/media.js
// META: script=/webcodecs/utils.js
var defaultInit = {
timestamp: 1234,
channels: 2,
sampleRate: 8000,
frames: 100,
}
function createDefaultAudioData() {
return make_audio_data(defaultInit.timestamp,
defaultInit.channels,
defaultInit.sampleRate,
defaultInit.frames);
}
async_test(t => {
let originalData = createDefaultAudioData();
let channel = new MessageChannel();
let localPort = channel.port1;
let externalPort = channel.port2;
externalPort.onmessage = t.step_func((e) => {
let newData = e.data;
// We should have a valid deserialized buffer.
assert_equals(newData.numberOfFrames, defaultInit.frames, 'numberOfFrames');
assert_equals(
newData.numberOfChannels, defaultInit.channels, 'numberOfChannels');
assert_equals(newData.sampleRate, defaultInit.sampleRate, 'sampleRate');
const originalData_copyDest = new Float32Array(defaultInit.frames);
const newData_copyDest = new Float32Array(defaultInit.frames);
for (var channel = 0; channel < defaultInit.channels; channel++) {
originalData.copyTo(originalData_copyDest, { planeIndex: channel});
newData.copyTo(newData_copyDest, { planeIndex: channel});
for (var i = 0; i < newData_copyDest.length; i+=10) {
assert_equals(newData_copyDest[i], originalData_copyDest[i],
"data (ch=" + channel + ", i=" + i + ")");
}
}
newData.close();
externalPort.postMessage("Done");
})
localPort.onmessage = t.step_func_done((e) => {
assert_equals(originalData.numberOfFrames, defaultInit.frames);
originalData.close();
})
localPort.postMessage(originalData);
}, 'Verify closing AudioData does not propagate accross contexts.');
async_test(t => {
let data = createDefaultAudioData();
let channel = new MessageChannel();
let localPort = channel.port1;
localPort.onmessage = t.unreached_func();
data.close();
assert_throws_dom("DataCloneError", () => {
localPort.postMessage(data);
});
t.done();
}, 'Verify posting closed AudioData throws.');
async_test(t => {
let localData = createDefaultAudioData();
let channel = new MessageChannel();
let localPort = channel.port1;
let externalPort = channel.port2;
externalPort.onmessage = t.step_func_done((e) => {
let externalData = e.data;
assert_equals(externalData.numberOfFrames, defaultInit.frames);
externalData.close();
})
localPort.postMessage(localData, [localData]);
assert_not_equals(localData.numberOfFrames, defaultInit.frames);
}, 'Verify transferring audio data closes them.');