mirror of
https://github.com/servo/servo.git
synced 2025-08-19 12:25:33 +01:00
Update web-platform-tests to revision b9d4748d6a7f9b21bd420486955b44349aa005ea
This commit is contained in:
parent
0a9a222356
commit
28ed236c3a
76 changed files with 2158 additions and 581 deletions
|
@ -116,7 +116,7 @@ function forEachWebxrObject(callback) {
|
|||
|
||||
// Code for loading test api in chromium.
|
||||
let loadChromiumResources = Promise.resolve().then(() => {
|
||||
if (!MojoInterfaceInterceptor) {
|
||||
if (!('MojoInterfaceInterceptor' in self)) {
|
||||
// Do nothing on non-Chromium-based browsers or when the Mojo bindings are
|
||||
// not present in the global namespace.
|
||||
return;
|
||||
|
|
|
@ -0,0 +1,61 @@
|
|||
<!DOCTYPE html>
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="resources/test-constants.js"></script>
|
||||
<script src="resources/webxr_util.js"></script>
|
||||
<script src="resources/xr-test-asserts.js"></script>
|
||||
<canvas></canvas>
|
||||
|
||||
<script>
|
||||
|
||||
let immersiveTestName = "XRWebGLLayer reports a valid viewports for immersive sessions";
|
||||
let inlineTestName = "XRWebGLLayer reports a valid viewports for inline sessions";
|
||||
|
||||
let fakeDeviceInitParams = { supportsImmersive:true };
|
||||
|
||||
let testFunction = function(session, fakeDeviceController, t) {
|
||||
// Need to have a valid pose.
|
||||
fakeDeviceController.setXRPresentationFrameData(VALID_POSE_MATRIX, [{
|
||||
eye:"left",
|
||||
projectionMatrix: VALID_PROJECTION_MATRIX,
|
||||
viewMatrix: VALID_VIEW_MATRIX
|
||||
}, {
|
||||
eye:"right",
|
||||
projectionMatrix: VALID_PROJECTION_MATRIX,
|
||||
viewMatrix: VALID_VIEW_MATRIX
|
||||
}]);
|
||||
|
||||
return session.requestReferenceSpace('viewer')
|
||||
.then((space) => new Promise((resolve) => {
|
||||
function onFrame(time, xrFrame) {
|
||||
let viewer_pose = xrFrame.getViewerPose(space);
|
||||
|
||||
let layer = xrFrame.session.renderState.baseLayer;
|
||||
for (view of viewer_pose.views) {
|
||||
let viewport = layer.getViewport(view);
|
||||
|
||||
// Ensure the returned object is an XRViewport object
|
||||
assert_not_equals(viewport, null);
|
||||
assert_true(viewport instanceof XRViewport);
|
||||
|
||||
// Ensure the viewport dimensions are valid
|
||||
assert_greater_than_equal(viewport.x, 0);
|
||||
assert_greater_than_equal(viewport.y, 0);
|
||||
assert_greater_than_equal(viewport.width, 1);
|
||||
assert_greater_than_equal(viewport.height, 1);
|
||||
}
|
||||
|
||||
// Finished test.
|
||||
resolve();
|
||||
}
|
||||
|
||||
session.requestAnimationFrame(onFrame);
|
||||
}));
|
||||
};
|
||||
|
||||
xr_session_promise_test(immersiveTestName, testFunction,
|
||||
fakeDeviceInitParams, 'immersive-vr');
|
||||
xr_session_promise_test(inlineTestName, testFunction,
|
||||
fakeDeviceInitParams, 'inline');
|
||||
|
||||
</script>
|
Loading…
Add table
Add a link
Reference in a new issue