gecko-dev/testing/web-platform/tests/webrtc/legacy/RTCPeerConnection-addStream.https.html
Mason Freed 9a6f859065 Bug 1511859 [wpt PR 14342] - Implement correct opacity and filter handling within backdrop-filter, a=testonly
Automatic update from web-platform-tests
Implement correct opacity and filter handling within backdrop-filter

Prior to this CL, opacity and filters applied to the backdrop-filtered
element did not get applied to the backdrop-filtered backdrop. Now, the
opacity and filters get applied directly to the backdrop-filtered
image directly, which is an approximation but should be very close.

Also fixed up a few of the backdrop-filter tests to account for this,
and removed a few lines from TestExpectations that now work.

Bug: 497522, 524689
Change-Id: If671bdf65ac0ae04cf175143eb8949ff4be0837b
Reviewed-on: https://chromium-review.googlesource.com/c/1357626
Reviewed-by: vmpstr <vmpstr@chromium.org>
Commit-Queue: Mason Freed <masonfreed@chromium.org>
Cr-Commit-Position: refs/heads/master@{#614383}

--

wpt-commits: 9a3c69f7e55bc1b0d8c0b38fd47c0dd38e7a0a71
wpt-pr: 14342
2018-12-14 13:54:33 +00:00

74 lines
2.5 KiB
HTML

<!doctype html>
<meta charset=utf-8>
<meta name="timeout" content="long">
<title>RTCPeerConnection legacy addStream</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="../RTCPeerConnection-helper.js"></script>
<script src="../RTCStats-helper.js"></script>
<script src="../dictionary-helper.js"></script>
<script>
'use strict';
// The following helper functions are called from RTCPeerConnection-helper.js:
// getUserMediaTracksAndStreams
// The following helper functions are called from RTCStats-helper.js
// (depends on dictionary-helper.js):
// validateRtcStats
// TODO(hbos): addStream() is legacy API not in the spec. Based on discussion
// whether to standardize in legacy section, consider removing this test or
// keeping it until addTrack() has wide support.
// https://github.com/w3c/webrtc-pc/issues/1705
// https://github.com/w3c/webrtc-pc/issues/1125
async_test(t => {
const pc = new RTCPeerConnection();
t.add_cleanup(() => pc.close());
let track;
let stream;
return getUserMediaTracksAndStreams(1)
.then(t.step_func(([tracks, streams]) => {
track = tracks[0];
stream = streams[0];
stream.addTrack(track);
pc.addStream(stream);
return pc.createOffer();
}))
.then(t.step_func(offer => {
return pc.setLocalDescription(offer);
}))
.then(t.step_func(() => {
return pc.getStats();
}))
.then(t.step_func(report => {
let trackStats = findStatsByTypeAndId(report, 'track', track.id);
let streamStats = findStatsByTypeAndId(report, 'stream', stream.id);
assert_true(trackStats != null && streamStats != null,
'Has stats for track and stream');
assert_array_equals(streamStats.trackIds, [ trackStats.id ],
'streamStats.trackIds == [ trackStats.id ]');
validateRtcStats(report, trackStats);
validateRtcStats(report, streamStats);
t.done();
}))
.catch(t.step_func(reason => {
assert_unreached(reason);
}));
}, 'Legacy addStream(): Media stream stats references track stats');
function findStatsByTypeAndId(report, type, identifier) {
return findStats(report, stats => {
return stats.type == type && stats[type + 'Identifier'] == identifier;
});
}
function findStats(report, findFunc) {
for (let it = report.values(), n = it.next(); !n.done; n = it.next()) {
if (findFunc(n.value))
return n.value;
}
return null;
}
</script>