fune/testing/web-platform/tests/permissions-policy
Marcos Cáceres f1abdf0d5a Bug 1900290 [wpt PR 46580] - Geolocation: simplify feature check, a=testonly
Automatic update from web-platform-tests
Geolocation: simplify feature check (#46580)

--

wpt-commits: 93263b60a46dda6382fb6f093cc529fcb4433677
wpt-pr: 46580
2024-06-07 07:38:56 +00:00
..
experimental-features
reporting
resources Bug 1900290 [wpt PR 46580] - Geolocation: simplify feature check, a=testonly 2024-06-07 07:38:56 +00:00
bluetooth-allowed-by-permissions-policy-attribute-redirect-on-load.https.sub.html
bluetooth-allowed-by-permissions-policy-attribute.https.sub.html
bluetooth-allowed-by-permissions-policy.https.sub.html
bluetooth-allowed-by-permissions-policy.https.sub.html.headers
bluetooth-default-permissions-policy.https.sub.html
bluetooth-disabled-by-permissions-policy.https.sub.html
bluetooth-disabled-by-permissions-policy.https.sub.html.headers
idlharness.window.js
META.yml
payment-allowed-by-permissions-policy-attribute-redirect-on-load.https.sub.html
payment-allowed-by-permissions-policy-attribute.https.sub.html
payment-allowed-by-permissions-policy.https.sub.html
payment-allowed-by-permissions-policy.https.sub.html.headers
payment-default-permissions-policy.https.sub.html
payment-disabled-by-permissions-policy.https.sub.html
payment-disabled-by-permissions-policy.https.sub.html.headers
payment-extension-allowed-by-permissions-policy-attribute.https.sub.html Bug 1888985 [wpt PR 45455] - fix permissions-policy-payment-extension.html to only check error name, a=testonly 2024-05-23 10:00:42 +00:00
payment-supported-by-permissions-policy.tentative.html
permissions-policy-frame-policy-allowed-for-all.https.sub.html
permissions-policy-frame-policy-allowed-for-all.https.sub.html.sub.headers
permissions-policy-frame-policy-allowed-for-self.https.sub.html
permissions-policy-frame-policy-allowed-for-self.https.sub.html.sub.headers
permissions-policy-frame-policy-allowed-for-some-override.https.sub.html
permissions-policy-frame-policy-allowed-for-some-override.https.sub.html.sub.headers
permissions-policy-frame-policy-allowed-for-some.https.sub.html
permissions-policy-frame-policy-allowed-for-some.https.sub.html.sub.headers
permissions-policy-frame-policy-disallowed-for-all.https.sub.html
permissions-policy-frame-policy-disallowed-for-all.https.sub.html.sub.headers
permissions-policy-frame-policy-timing-iframe-camera.https.sub.html Bug 1899382 [wpt PR 46516] - [WPT] fix *-policy-frame-policy-timing, a=testonly 2024-06-03 07:40:34 +00:00
permissions-policy-frame-policy-timing.https.sub.html Bug 1899382 [wpt PR 46516] - [WPT] fix *-policy-frame-policy-timing, a=testonly 2024-06-03 07:40:34 +00:00
permissions-policy-header-policy-allowed-for-all.https.sub.html
permissions-policy-header-policy-allowed-for-all.https.sub.html.sub.headers
permissions-policy-header-policy-allowed-for-malformed-wildcard.https.sub.html
permissions-policy-header-policy-allowed-for-malformed-wildcard.https.sub.html.sub.headers
permissions-policy-header-policy-allowed-for-self.https.sub.html
permissions-policy-header-policy-allowed-for-self.https.sub.html.sub.headers
permissions-policy-header-policy-allowed-for-some.https.sub.html
permissions-policy-header-policy-allowed-for-some.https.sub.html.sub.headers
permissions-policy-header-policy-allowed-for-wildcard.https.sub.html
permissions-policy-header-policy-allowed-for-wildcard.https.sub.html.sub.headers
permissions-policy-header-policy-declined.https.sub.html
permissions-policy-header-policy-declined.https.sub.html.sub.headers
permissions-policy-header-policy-disallowed-for-all.https.sub.html
permissions-policy-header-policy-disallowed-for-all.https.sub.html.sub.headers
permissions-policy-javascript-url-frame-policy.https.html
permissions-policy-nested-header-policy-allowed-for-all.https.sub.html
permissions-policy-nested-header-policy-allowed-for-all.https.sub.html.sub.headers
permissions-policy-nested-header-policy-allowed-for-self.https.sub.html
permissions-policy-nested-header-policy-allowed-for-self.https.sub.html.sub.headers
permissions-policy-nested-header-policy-disallowed-for-all.https.sub.html
permissions-policy-nested-header-policy-disallowed-for-all.https.sub.html.sub.headers
permissions-policy-opaque-origin-history.https.html
permissions-policy-opaque-origin.https.html
picture-in-picture-allowed-by-permissions-policy-attribute-redirect-on-load.https.sub.html
picture-in-picture-allowed-by-permissions-policy-attribute.https.sub.html
picture-in-picture-allowed-by-permissions-policy.https.sub.html
picture-in-picture-allowed-by-permissions-policy.https.sub.html.headers
picture-in-picture-default-permissions-policy.https.sub.html
picture-in-picture-disabled-by-permissions-policy.https.sub.html
picture-in-picture-disabled-by-permissions-policy.https.sub.html.headers
picture-in-picture-supported-by-permissions-policy.html
policy-extends-to-sandbox.html
private-state-token-issue-allowed-by-permissions-policy-attribute.tentative.https.sub.html
private-state-token-issue-disabled-by-permissions-policy.tentative.https.sub.html
private-state-token-issue-disabled-by-permissions-policy.tentative.https.sub.html.headers
private-state-token-issue-enabled-by-permissions-policy.tentative.https.sub.html
private-state-token-issue-enabled-by-permissions-policy.tentative.https.sub.html.headers
private-state-token-issue-supported-by-permissions-policy.tentative.html
README.md

Permissions Policy Guide

How to Test a New Feature with permissions policy

This directory contains a framework to test features with permissions policy.

When adding a new feature to permissions policy, the following cases should be tested:

  • feature enabled by header policy [HTTP tests]
    • test when feature is enabled by permissions policy HTTP header;
  • feature disabled by header policy [HTTP tests]
    • test when feature is disabled by permissions policy HTTP header;
  • feature enabled on self origin by header policy [HTTP tests]
    • test when feature is enabled only on self origin by permissions policy HTTP header.
  • feature allowed by container policy (iframe "allow" attribute);
    • test when feature is enabled by iframe "allow" attribute on self and cross origins.
  • feature allowed by container policy, redirect on load.
    • test when feature is enabled by iframe "allow" attribute when the iframe is being redirected to a new origin upon loading

How to Use the Test Framework

Use test_feature_availability() defined in /permissions-policy/resources/permissions-policy.js. Please refer to the comments in /permissions-policy/resources/permissions-policy.js for how this function works.

How to Write Header Policy Tests

HTTP tests are used to test features with header policy.

  • Define the header policy in <feature-name>-<enabled | disabled | enabled-on-self-origin>-by-permissions-policy.https.sub.html.headers. Example:

    Permissions-Policy: feature-name=*

  • In <feature-name>-<enabled | disabled | enabled-on-self-origin>-by-permissions-policy.https.sub.html:

  • test if feature is enabled / disabled in the main frame;

  • test if feature is enabled / disabled in a same-origin iframe;

  • test if feature is enabled / disabled in a cross-origin iframe.

Examples: /permissions-policy/payment-disabled-by-permissions-policy.https.sub.html /permissions-policy/payment-disabled-by-permissions-policy.https.sub.html.headers

How to Write Container Policy Tests

Simply use test_feature_availability() with the optional argument feature_name specified to test if:

  • feature is enabled / disabled in a same-origin iframe;
  • feature is enabled / disabled in a cross-origin iframe.

Example: /permissions-policy/payment-allowed-by-permissions-policy-attribute.https.sub.html

How to Write Container Policy Tests with Redirect

Similar to the section above, append /permissions-policy/resources/redirect-on-load.html# to the argument src passed to test_feature_availability().

Example: /permissions-policy/payment-allowed-by-permissions-policy-attribute-redirect-on-load.https.sub.html