test: update WPT files for WebIDL tests

PR-URL: https://github.com/nodejs/node/pull/50712
Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
This commit is contained in:
Filip Skokan 2023-11-13 15:32:53 +01:00 committed by Node.js GitHub Bot
parent 2aff5cf638
commit e0bbe8fd52
21 changed files with 763 additions and 131 deletions

View File

@ -23,10 +23,10 @@ Last update:
- html/webappapis/microtask-queuing: https://github.com/web-platform-tests/wpt/tree/2c5c3c4c27/html/webappapis/microtask-queuing - html/webappapis/microtask-queuing: https://github.com/web-platform-tests/wpt/tree/2c5c3c4c27/html/webappapis/microtask-queuing
- html/webappapis/structured-clone: https://github.com/web-platform-tests/wpt/tree/47d3fb280c/html/webappapis/structured-clone - html/webappapis/structured-clone: https://github.com/web-platform-tests/wpt/tree/47d3fb280c/html/webappapis/structured-clone
- html/webappapis/timers: https://github.com/web-platform-tests/wpt/tree/5873f2d8f1/html/webappapis/timers - html/webappapis/timers: https://github.com/web-platform-tests/wpt/tree/5873f2d8f1/html/webappapis/timers
- interfaces: https://github.com/web-platform-tests/wpt/tree/df731dab88/interfaces - interfaces: https://github.com/web-platform-tests/wpt/tree/727995f043/interfaces
- performance-timeline: https://github.com/web-platform-tests/wpt/tree/17ebc3aea0/performance-timeline - performance-timeline: https://github.com/web-platform-tests/wpt/tree/17ebc3aea0/performance-timeline
- resource-timing: https://github.com/web-platform-tests/wpt/tree/22d38586d0/resource-timing - resource-timing: https://github.com/web-platform-tests/wpt/tree/22d38586d0/resource-timing
- resources: https://github.com/web-platform-tests/wpt/tree/919874f84f/resources - resources: https://github.com/web-platform-tests/wpt/tree/1e140d63ec/resources
- streams: https://github.com/web-platform-tests/wpt/tree/517e945bbf/streams - streams: https://github.com/web-platform-tests/wpt/tree/517e945bbf/streams
- url: https://github.com/web-platform-tests/wpt/tree/c2d7e70b52/url - url: https://github.com/web-platform-tests/wpt/tree/c2d7e70b52/url
- user-timing: https://github.com/web-platform-tests/wpt/tree/5ae85bf826/user-timing - user-timing: https://github.com/web-platform-tests/wpt/tree/5ae85bf826/user-timing

View File

@ -0,0 +1,22 @@
// GENERATED CONTENT - DO NOT EDIT
// Content was automatically extracted by Reffy into webref
// (https://github.com/w3c/webref)
// Source: Compression Streams (https://wicg.github.io/compression/)
enum CompressionFormat {
"deflate",
"deflate-raw",
"gzip",
};
[Exposed=*]
interface CompressionStream {
constructor(CompressionFormat format);
};
CompressionStream includes GenericTransformStream;
[Exposed=*]
interface DecompressionStream {
constructor(CompressionFormat format);
};
DecompressionStream includes GenericTransformStream;

View File

@ -95,6 +95,7 @@ interface AbortController {
interface AbortSignal : EventTarget { interface AbortSignal : EventTarget {
[NewObject] static AbortSignal abort(optional any reason); [NewObject] static AbortSignal abort(optional any reason);
[Exposed=(Window,Worker), NewObject] static AbortSignal timeout([EnforceRange] unsigned long long milliseconds); [Exposed=(Window,Worker), NewObject] static AbortSignal timeout([EnforceRange] unsigned long long milliseconds);
[NewObject] static AbortSignal _any(sequence<AbortSignal> signals);
readonly attribute boolean aborted; readonly attribute boolean aborted;
readonly attribute any reason; readonly attribute any reason;
@ -618,7 +619,7 @@ callback interface XPathNSResolver {
interface mixin XPathEvaluatorBase { interface mixin XPathEvaluatorBase {
[NewObject] XPathExpression createExpression(DOMString expression, optional XPathNSResolver? resolver = null); [NewObject] XPathExpression createExpression(DOMString expression, optional XPathNSResolver? resolver = null);
XPathNSResolver createNSResolver(Node nodeResolver); Node createNSResolver(Node nodeResolver); // legacy
// XPathResult.ANY_TYPE = 0 // XPathResult.ANY_TYPE = 0
XPathResult evaluate(DOMString expression, Node contextNode, optional XPathNSResolver? resolver = null, optional unsigned short type = 0, optional XPathResult? result = null); XPathResult evaluate(DOMString expression, Node contextNode, optional XPathNSResolver? resolver = null, optional unsigned short type = 0, optional XPathResult? result = null);
}; };

View File

@ -22,7 +22,7 @@ dictionary TextDecodeOptions {
interface TextDecoder { interface TextDecoder {
constructor(optional DOMString label = "utf-8", optional TextDecoderOptions options = {}); constructor(optional DOMString label = "utf-8", optional TextDecoderOptions options = {});
USVString decode(optional [AllowShared] BufferSource input, optional TextDecodeOptions options = {}); USVString decode(optional AllowSharedBufferSource input, optional TextDecodeOptions options = {});
}; };
TextDecoder includes TextDecoderCommon; TextDecoder includes TextDecoderCommon;

View File

@ -7,7 +7,7 @@ typedef double DOMHighResTimeStamp;
typedef unsigned long long EpochTimeStamp; typedef unsigned long long EpochTimeStamp;
[Exposed=*] [Exposed=(Window,Worker)]
interface Performance : EventTarget { interface Performance : EventTarget {
DOMHighResTimeStamp now(); DOMHighResTimeStamp now();
readonly attribute DOMHighResTimeStamp timeOrigin; readonly attribute DOMHighResTimeStamp timeOrigin;

View File

@ -98,7 +98,6 @@ partial interface Document {
// also has obsolete members // also has obsolete members
}; };
Document includes GlobalEventHandlers; Document includes GlobalEventHandlers;
Document includes DocumentAndElementEventHandlers;
partial interface mixin DocumentOrShadowRoot { partial interface mixin DocumentOrShadowRoot {
readonly attribute Element? activeElement; readonly attribute Element? activeElement;
@ -128,10 +127,15 @@ interface HTMLElement : Element {
[CEReactions] attribute [LegacyNullToEmptyString] DOMString outerText; [CEReactions] attribute [LegacyNullToEmptyString] DOMString outerText;
ElementInternals attachInternals(); ElementInternals attachInternals();
// The popover API
undefined showPopover();
undefined hidePopover();
boolean togglePopover(optional boolean force);
[CEReactions] attribute DOMString? popover;
}; };
HTMLElement includes GlobalEventHandlers; HTMLElement includes GlobalEventHandlers;
HTMLElement includes DocumentAndElementEventHandlers;
HTMLElement includes ElementContentEditable; HTMLElement includes ElementContentEditable;
HTMLElement includes HTMLOrSVGElement; HTMLElement includes HTMLOrSVGElement;
@ -204,6 +208,7 @@ interface HTMLLinkElement : HTMLElement {
[CEReactions] attribute DOMString referrerPolicy; [CEReactions] attribute DOMString referrerPolicy;
[SameObject, PutForwards=value] readonly attribute DOMTokenList blocking; [SameObject, PutForwards=value] readonly attribute DOMTokenList blocking;
[CEReactions] attribute boolean disabled; [CEReactions] attribute boolean disabled;
[CEReactions] attribute DOMString fetchPriority;
// also has obsolete members // also has obsolete members
}; };
@ -432,6 +437,7 @@ interface HTMLImageElement : HTMLElement {
[CEReactions] attribute DOMString referrerPolicy; [CEReactions] attribute DOMString referrerPolicy;
[CEReactions] attribute DOMString decoding; [CEReactions] attribute DOMString decoding;
[CEReactions] attribute DOMString loading; [CEReactions] attribute DOMString loading;
[CEReactions] attribute DOMString fetchPriority;
Promise<undefined> decode(); Promise<undefined> decode();
@ -886,7 +892,7 @@ interface HTMLInputElement : HTMLElement {
[CEReactions] attribute DOMString formTarget; [CEReactions] attribute DOMString formTarget;
[CEReactions] attribute unsigned long height; [CEReactions] attribute unsigned long height;
attribute boolean indeterminate; attribute boolean indeterminate;
readonly attribute HTMLElement? list; readonly attribute HTMLDataListElement? list;
[CEReactions] attribute DOMString max; [CEReactions] attribute DOMString max;
[CEReactions] attribute long maxLength; [CEReactions] attribute long maxLength;
[CEReactions] attribute DOMString min; [CEReactions] attribute DOMString min;
@ -931,6 +937,7 @@ interface HTMLInputElement : HTMLElement {
// also has obsolete members // also has obsolete members
}; };
HTMLInputElement includes PopoverInvokerElement;
[Exposed=Window] [Exposed=Window]
interface HTMLButtonElement : HTMLElement { interface HTMLButtonElement : HTMLElement {
@ -956,6 +963,7 @@ interface HTMLButtonElement : HTMLElement {
readonly attribute NodeList labels; readonly attribute NodeList labels;
}; };
HTMLButtonElement includes PopoverInvokerElement;
[Exposed=Window] [Exposed=Window]
interface HTMLSelectElement : HTMLElement { interface HTMLSelectElement : HTMLElement {
@ -1216,6 +1224,7 @@ interface HTMLScriptElement : HTMLElement {
[CEReactions] attribute DOMString integrity; [CEReactions] attribute DOMString integrity;
[CEReactions] attribute DOMString referrerPolicy; [CEReactions] attribute DOMString referrerPolicy;
[SameObject, PutForwards=value] readonly attribute DOMTokenList blocking; [SameObject, PutForwards=value] readonly attribute DOMTokenList blocking;
[CEReactions] attribute DOMString fetchPriority;
static boolean supports(DOMString type); static boolean supports(DOMString type);
@ -1364,14 +1373,7 @@ interface mixin CanvasShadowStyles {
interface mixin CanvasFilters { interface mixin CanvasFilters {
// filters // filters
attribute (DOMString or CanvasFilter) filter; // (default "none") attribute DOMString filter; // (default "none")
};
typedef record<DOMString, any> CanvasFilterInput;
[Exposed=(Window,Worker,PaintWorklet)]
interface CanvasFilter {
constructor(optional (CanvasFilterInput or sequence<CanvasFilterInput>) filters);
}; };
interface mixin CanvasRect { interface mixin CanvasRect {
@ -1592,6 +1594,7 @@ OffscreenCanvasRenderingContext2D includes CanvasPath;
interface CustomElementRegistry { interface CustomElementRegistry {
[CEReactions] undefined define(DOMString name, CustomElementConstructor constructor, optional ElementDefinitionOptions options = {}); [CEReactions] undefined define(DOMString name, CustomElementConstructor constructor, optional ElementDefinitionOptions options = {});
(CustomElementConstructor or undefined) get(DOMString name); (CustomElementConstructor or undefined) get(DOMString name);
DOMString? getName(CustomElementConstructor constructor);
Promise<CustomElementConstructor> whenDefined(DOMString name); Promise<CustomElementConstructor> whenDefined(DOMString name);
[CEReactions] undefined upgrade(Node root); [CEReactions] undefined upgrade(Node root);
}; };
@ -1641,8 +1644,39 @@ dictionary ValidityStateFlags {
boolean customError = false; boolean customError = false;
}; };
[Exposed=(Window)]
interface VisibilityStateEntry : PerformanceEntry {
readonly attribute DOMString name; // shadows inherited name
readonly attribute DOMString entryType; // shadows inherited entryType
readonly attribute DOMHighResTimeStamp startTime; // shadows inherited startTime
readonly attribute unsigned long duration; // shadows inherited duration
};
[Exposed=Window]
interface UserActivation {
readonly attribute boolean hasBeenActive;
readonly attribute boolean isActive;
};
partial interface Navigator {
[SameObject] readonly attribute UserActivation userActivation;
};
[Exposed=Window]
interface ToggleEvent : Event {
constructor(DOMString type, optional ToggleEventInit eventInitDict = {});
readonly attribute DOMString oldState;
readonly attribute DOMString newState;
};
dictionary ToggleEventInit : EventInit {
DOMString oldState = "";
DOMString newState = "";
};
dictionary FocusOptions { dictionary FocusOptions {
boolean preventScroll = false; boolean preventScroll = false;
boolean focusVisible;
}; };
interface mixin ElementContentEditable { interface mixin ElementContentEditable {
@ -1702,6 +1736,11 @@ dictionary DragEventInit : MouseEventInit {
DataTransfer? dataTransfer = null; DataTransfer? dataTransfer = null;
}; };
interface mixin PopoverInvokerElement {
[CEReactions] attribute Element? popoverTargetElement;
[CEReactions] attribute DOMString popoverTargetAction;
};
[Global=Window, [Global=Window,
Exposed=Window, Exposed=Window,
LegacyUnenumerableNamedProperties] LegacyUnenumerableNamedProperties]
@ -1713,6 +1752,7 @@ interface Window : EventTarget {
attribute DOMString name; attribute DOMString name;
[PutForwards=href, LegacyUnforgeable] readonly attribute Location location; [PutForwards=href, LegacyUnforgeable] readonly attribute Location location;
readonly attribute History history; readonly attribute History history;
readonly attribute Navigation navigation;
readonly attribute CustomElementRegistry customElements; readonly attribute CustomElementRegistry customElements;
[Replaceable] readonly attribute BarProp locationbar; [Replaceable] readonly attribute BarProp locationbar;
[Replaceable] readonly attribute BarProp menubar; [Replaceable] readonly attribute BarProp menubar;
@ -1735,14 +1775,15 @@ interface Window : EventTarget {
[Replaceable] readonly attribute WindowProxy? parent; [Replaceable] readonly attribute WindowProxy? parent;
readonly attribute Element? frameElement; readonly attribute Element? frameElement;
WindowProxy? open(optional USVString url = "", optional DOMString target = "_blank", optional [LegacyNullToEmptyString] DOMString features = ""); WindowProxy? open(optional USVString url = "", optional DOMString target = "_blank", optional [LegacyNullToEmptyString] DOMString features = "");
getter object (DOMString name);
// Since this is the global object, the IDL named getter adds a NamedPropertiesObject exotic // Since this is the global object, the IDL named getter adds a NamedPropertiesObject exotic
// object on the prototype chain. Indeed, this does not make the global object an exotic object. // object on the prototype chain. Indeed, this does not make the global object an exotic object.
// Indexed access is taken care of by the WindowProxy exotic object. // Indexed access is taken care of by the WindowProxy exotic object.
getter object (DOMString name);
// the user agent // the user agent
readonly attribute Navigator navigator; readonly attribute Navigator navigator;
readonly attribute Navigator clientInformation; // legacy alias of .navigator [Replaceable] readonly attribute Navigator clientInformation; // legacy alias of .navigator
readonly attribute boolean originAgentCluster; readonly attribute boolean originAgentCluster;
// user prompts // user prompts
@ -1769,20 +1810,6 @@ interface BarProp {
readonly attribute boolean visible; readonly attribute boolean visible;
}; };
enum ScrollRestoration { "auto", "manual" };
[Exposed=Window]
interface History {
readonly attribute unsigned long length;
attribute ScrollRestoration scrollRestoration;
readonly attribute any state;
undefined go(optional long delta = 0);
undefined back();
undefined forward();
undefined pushState(any data, DOMString unused, optional USVString? url = null);
undefined replaceState(any data, DOMString unused, optional USVString? url = null);
};
[Exposed=Window] [Exposed=Window]
interface Location { // but see also additional creation steps and overridden internal methods interface Location { // but see also additional creation steps and overridden internal methods
[LegacyUnforgeable] stringifier attribute USVString href; [LegacyUnforgeable] stringifier attribute USVString href;
@ -1802,15 +1829,183 @@ interface Location { // but see also additional creation steps and overridden in
[LegacyUnforgeable, SameObject] readonly attribute DOMStringList ancestorOrigins; [LegacyUnforgeable, SameObject] readonly attribute DOMStringList ancestorOrigins;
}; };
enum ScrollRestoration { "auto", "manual" };
[Exposed=Window]
interface History {
readonly attribute unsigned long length;
attribute ScrollRestoration scrollRestoration;
readonly attribute any state;
undefined go(optional long delta = 0);
undefined back();
undefined forward();
undefined pushState(any data, DOMString unused, optional USVString? url = null);
undefined replaceState(any data, DOMString unused, optional USVString? url = null);
};
[Exposed=Window]
interface Navigation : EventTarget {
sequence<NavigationHistoryEntry> entries();
readonly attribute NavigationHistoryEntry? currentEntry;
undefined updateCurrentEntry(NavigationUpdateCurrentEntryOptions options);
readonly attribute NavigationTransition? transition;
readonly attribute boolean canGoBack;
readonly attribute boolean canGoForward;
NavigationResult navigate(USVString url, optional NavigationNavigateOptions options = {});
NavigationResult reload(optional NavigationReloadOptions options = {});
NavigationResult traverseTo(DOMString key, optional NavigationOptions options = {});
NavigationResult back(optional NavigationOptions options = {});
NavigationResult forward(optional NavigationOptions options = {});
attribute EventHandler onnavigate;
attribute EventHandler onnavigatesuccess;
attribute EventHandler onnavigateerror;
attribute EventHandler oncurrententrychange;
};
dictionary NavigationUpdateCurrentEntryOptions {
required any state;
};
dictionary NavigationOptions {
any info;
};
dictionary NavigationNavigateOptions : NavigationOptions {
any state;
NavigationHistoryBehavior history = "auto";
};
dictionary NavigationReloadOptions : NavigationOptions {
any state;
};
dictionary NavigationResult {
Promise<NavigationHistoryEntry> committed;
Promise<NavigationHistoryEntry> finished;
};
enum NavigationHistoryBehavior {
"auto",
"push",
"replace"
};
enum NavigationType {
"push",
"replace",
"reload",
"traverse"
};
[Exposed=Window]
interface NavigationHistoryEntry : EventTarget {
readonly attribute USVString? url;
readonly attribute DOMString key;
readonly attribute DOMString id;
readonly attribute long long index;
readonly attribute boolean sameDocument;
any getState();
attribute EventHandler ondispose;
};
[Exposed=Window]
interface NavigationTransition {
readonly attribute NavigationType navigationType;
readonly attribute NavigationHistoryEntry from;
readonly attribute Promise<undefined> finished;
};
[Exposed=Window]
interface NavigateEvent : Event {
constructor(DOMString type, NavigateEventInit eventInitDict);
readonly attribute NavigationType navigationType;
readonly attribute NavigationDestination destination;
readonly attribute boolean canIntercept;
readonly attribute boolean userInitiated;
readonly attribute boolean hashChange;
readonly attribute AbortSignal signal;
readonly attribute FormData? formData;
readonly attribute DOMString? downloadRequest;
readonly attribute any info;
readonly attribute boolean hasUAVisualTransition;
undefined intercept(optional NavigationInterceptOptions options = {});
undefined scroll();
};
dictionary NavigateEventInit : EventInit {
NavigationType navigationType = "push";
required NavigationDestination destination;
boolean canIntercept = false;
boolean userInitiated = false;
boolean hashChange = false;
required AbortSignal signal;
FormData? formData = null;
DOMString? downloadRequest = null;
any info;
boolean hasUAVisualTransition = false;
};
dictionary NavigationInterceptOptions {
NavigationInterceptHandler handler;
NavigationFocusReset focusReset;
NavigationScrollBehavior scroll;
};
enum NavigationFocusReset {
"after-transition",
"manual"
};
enum NavigationScrollBehavior {
"after-transition",
"manual"
};
callback NavigationInterceptHandler = Promise<undefined> ();
[Exposed=Window]
interface NavigationDestination {
readonly attribute USVString url;
readonly attribute DOMString key;
readonly attribute DOMString id;
readonly attribute long long index;
readonly attribute boolean sameDocument;
any getState();
};
[Exposed=Window]
interface NavigationCurrentEntryChangeEvent : Event {
constructor(DOMString type, NavigationCurrentEntryChangeEventInit eventInitDict);
readonly attribute NavigationType? navigationType;
readonly attribute NavigationHistoryEntry from;
};
dictionary NavigationCurrentEntryChangeEventInit : EventInit {
NavigationType? navigationType = null;
required NavigationHistoryEntry from;
};
[Exposed=Window] [Exposed=Window]
interface PopStateEvent : Event { interface PopStateEvent : Event {
constructor(DOMString type, optional PopStateEventInit eventInitDict = {}); constructor(DOMString type, optional PopStateEventInit eventInitDict = {});
readonly attribute any state; readonly attribute any state;
readonly attribute boolean hasUAVisualTransition;
}; };
dictionary PopStateEventInit : EventInit { dictionary PopStateEventInit : EventInit {
any state = null; any state = null;
boolean hasUAVisualTransition = false;
}; };
[Exposed=Window] [Exposed=Window]
@ -1891,6 +2086,7 @@ interface mixin GlobalEventHandlers {
attribute EventHandler onauxclick; attribute EventHandler onauxclick;
attribute EventHandler onbeforeinput; attribute EventHandler onbeforeinput;
attribute EventHandler onbeforematch; attribute EventHandler onbeforematch;
attribute EventHandler onbeforetoggle;
attribute EventHandler onblur; attribute EventHandler onblur;
attribute EventHandler oncancel; attribute EventHandler oncancel;
attribute EventHandler oncanplay; attribute EventHandler oncanplay;
@ -1901,7 +2097,9 @@ interface mixin GlobalEventHandlers {
attribute EventHandler oncontextlost; attribute EventHandler oncontextlost;
attribute EventHandler oncontextmenu; attribute EventHandler oncontextmenu;
attribute EventHandler oncontextrestored; attribute EventHandler oncontextrestored;
attribute EventHandler oncopy;
attribute EventHandler oncuechange; attribute EventHandler oncuechange;
attribute EventHandler oncut;
attribute EventHandler ondblclick; attribute EventHandler ondblclick;
attribute EventHandler ondrag; attribute EventHandler ondrag;
attribute EventHandler ondragend; attribute EventHandler ondragend;
@ -1932,6 +2130,7 @@ interface mixin GlobalEventHandlers {
attribute EventHandler onmouseout; attribute EventHandler onmouseout;
attribute EventHandler onmouseover; attribute EventHandler onmouseover;
attribute EventHandler onmouseup; attribute EventHandler onmouseup;
attribute EventHandler onpaste;
attribute EventHandler onpause; attribute EventHandler onpause;
attribute EventHandler onplay; attribute EventHandler onplay;
attribute EventHandler onplaying; attribute EventHandler onplaying;
@ -1940,6 +2139,7 @@ interface mixin GlobalEventHandlers {
attribute EventHandler onreset; attribute EventHandler onreset;
attribute EventHandler onresize; attribute EventHandler onresize;
attribute EventHandler onscroll; attribute EventHandler onscroll;
attribute EventHandler onscrollend;
attribute EventHandler onsecuritypolicyviolation; attribute EventHandler onsecuritypolicyviolation;
attribute EventHandler onseeked; attribute EventHandler onseeked;
attribute EventHandler onseeking; attribute EventHandler onseeking;
@ -1978,12 +2178,6 @@ interface mixin WindowEventHandlers {
attribute EventHandler onunload; attribute EventHandler onunload;
}; };
interface mixin DocumentAndElementEventHandlers {
attribute EventHandler oncopy;
attribute EventHandler oncut;
attribute EventHandler onpaste;
};
typedef (DOMString or Function) TimerHandler; typedef (DOMString or Function) TimerHandler;
interface mixin WindowOrWorkerGlobalScope { interface mixin WindowOrWorkerGlobalScope {
@ -2132,13 +2326,13 @@ typedef (CanvasImageSource or
Blob or Blob or
ImageData) ImageBitmapSource; ImageData) ImageBitmapSource;
enum ImageOrientation { "none", "flipY" }; enum ImageOrientation { "from-image", "flipY" };
enum PremultiplyAlpha { "none", "premultiply", "default" }; enum PremultiplyAlpha { "none", "premultiply", "default" };
enum ColorSpaceConversion { "none", "default" }; enum ColorSpaceConversion { "none", "default" };
enum ResizeQuality { "pixelated", "low", "medium", "high" }; enum ResizeQuality { "pixelated", "low", "medium", "high" };
dictionary ImageBitmapOptions { dictionary ImageBitmapOptions {
ImageOrientation imageOrientation = "none"; ImageOrientation imageOrientation = "from-image";
PremultiplyAlpha premultiplyAlpha = "default"; PremultiplyAlpha premultiplyAlpha = "default";
ColorSpaceConversion colorSpaceConversion = "default"; ColorSpaceConversion colorSpaceConversion = "default";
[EnforceRange] unsigned long resizeWidth; [EnforceRange] unsigned long resizeWidth;

View File

@ -1,7 +1,7 @@
// GENERATED CONTENT - DO NOT EDIT // GENERATED CONTENT - DO NOT EDIT
// Content was automatically extracted by Reffy into webref // Content was automatically extracted by Reffy into webref
// (https://github.com/w3c/webref) // (https://github.com/w3c/webref)
// Source: Performance Timeline Level 2 (https://w3c.github.io/performance-timeline/) // Source: Performance Timeline (https://w3c.github.io/performance-timeline/)
partial interface Performance { partial interface Performance {
PerformanceEntryList getEntries (); PerformanceEntryList getEntries ();
@ -10,7 +10,7 @@ partial interface Performance {
}; };
typedef sequence<PerformanceEntry> PerformanceEntryList; typedef sequence<PerformanceEntry> PerformanceEntryList;
[Exposed=*] [Exposed=(Window,Worker)]
interface PerformanceEntry { interface PerformanceEntry {
readonly attribute DOMString name; readonly attribute DOMString name;
readonly attribute DOMString entryType; readonly attribute DOMString entryType;
@ -22,7 +22,7 @@ interface PerformanceEntry {
callback PerformanceObserverCallback = undefined (PerformanceObserverEntryList entries, callback PerformanceObserverCallback = undefined (PerformanceObserverEntryList entries,
PerformanceObserver observer, PerformanceObserver observer,
optional PerformanceObserverCallbackOptions options = {}); optional PerformanceObserverCallbackOptions options = {});
[Exposed=*] [Exposed=(Window,Worker)]
interface PerformanceObserver { interface PerformanceObserver {
constructor(PerformanceObserverCallback callback); constructor(PerformanceObserverCallback callback);
undefined observe (optional PerformanceObserverInit options = {}); undefined observe (optional PerformanceObserverInit options = {});
@ -41,7 +41,7 @@ dictionary PerformanceObserverInit {
boolean buffered; boolean buffered;
}; };
[Exposed=*] [Exposed=(Window,Worker)]
interface PerformanceObserverEntryList { interface PerformanceObserverEntryList {
PerformanceEntryList getEntries(); PerformanceEntryList getEntries();
PerformanceEntryList getEntriesByType (DOMString type); PerformanceEntryList getEntriesByType (DOMString type);

View File

@ -1,11 +1,12 @@
// GENERATED CONTENT - DO NOT EDIT // GENERATED CONTENT - DO NOT EDIT
// Content was automatically extracted by Reffy into webref // Content was automatically extracted by Reffy into webref
// (https://github.com/w3c/webref) // (https://github.com/w3c/webref)
// Source: Resource Timing Level 2 (https://w3c.github.io/resource-timing/) // Source: Resource Timing (https://w3c.github.io/resource-timing/)
[Exposed=(Window,Worker)] [Exposed=(Window,Worker)]
interface PerformanceResourceTiming : PerformanceEntry { interface PerformanceResourceTiming : PerformanceEntry {
readonly attribute DOMString initiatorType; readonly attribute DOMString initiatorType;
readonly attribute DOMString deliveryType;
readonly attribute ByteString nextHopProtocol; readonly attribute ByteString nextHopProtocol;
readonly attribute DOMHighResTimeStamp workerStart; readonly attribute DOMHighResTimeStamp workerStart;
readonly attribute DOMHighResTimeStamp redirectStart; readonly attribute DOMHighResTimeStamp redirectStart;
@ -17,14 +18,23 @@ interface PerformanceResourceTiming : PerformanceEntry {
readonly attribute DOMHighResTimeStamp connectEnd; readonly attribute DOMHighResTimeStamp connectEnd;
readonly attribute DOMHighResTimeStamp secureConnectionStart; readonly attribute DOMHighResTimeStamp secureConnectionStart;
readonly attribute DOMHighResTimeStamp requestStart; readonly attribute DOMHighResTimeStamp requestStart;
readonly attribute DOMHighResTimeStamp firstInterimResponseStart;
readonly attribute DOMHighResTimeStamp responseStart; readonly attribute DOMHighResTimeStamp responseStart;
readonly attribute DOMHighResTimeStamp responseEnd; readonly attribute DOMHighResTimeStamp responseEnd;
readonly attribute unsigned long long transferSize; readonly attribute unsigned long long transferSize;
readonly attribute unsigned long long encodedBodySize; readonly attribute unsigned long long encodedBodySize;
readonly attribute unsigned long long decodedBodySize; readonly attribute unsigned long long decodedBodySize;
readonly attribute unsigned short responseStatus;
readonly attribute RenderBlockingStatusType renderBlockingStatus;
readonly attribute DOMString contentType;
[Default] object toJSON(); [Default] object toJSON();
}; };
enum RenderBlockingStatusType {
"blocking",
"non-blocking"
};
partial interface Performance { partial interface Performance {
undefined clearResourceTimings (); undefined clearResourceTimings ();
undefined setResourceTimingBufferSize (unsigned long maxSize); undefined setResourceTimingBufferSize (unsigned long maxSize);

View File

@ -7,6 +7,8 @@
interface ReadableStream { interface ReadableStream {
constructor(optional object underlyingSource, optional QueuingStrategy strategy = {}); constructor(optional object underlyingSource, optional QueuingStrategy strategy = {});
static ReadableStream from(any asyncIterable);
readonly attribute boolean locked; readonly attribute boolean locked;
Promise<undefined> cancel(optional any reason); Promise<undefined> cancel(optional any reason);

View File

@ -8,6 +8,8 @@
interface URL { interface URL {
constructor(USVString url, optional USVString base); constructor(USVString url, optional USVString base);
static boolean canParse(USVString url, optional USVString base);
stringifier attribute USVString href; stringifier attribute USVString href;
readonly attribute USVString origin; readonly attribute USVString origin;
attribute USVString protocol; attribute USVString protocol;
@ -28,11 +30,13 @@ interface URL {
interface URLSearchParams { interface URLSearchParams {
constructor(optional (sequence<sequence<USVString>> or record<USVString, USVString> or USVString) init = ""); constructor(optional (sequence<sequence<USVString>> or record<USVString, USVString> or USVString) init = "");
readonly attribute unsigned long size;
undefined append(USVString name, USVString value); undefined append(USVString name, USVString value);
undefined delete(USVString name); undefined delete(USVString name, optional USVString value);
USVString? get(USVString name); USVString? get(USVString name);
sequence<USVString> getAll(USVString name); sequence<USVString> getAll(USVString name);
boolean has(USVString name); boolean has(USVString name, optional USVString value);
undefined set(USVString name, USVString value); undefined set(USVString name, USVString value);
undefined sort(); undefined sort();

View File

@ -22,13 +22,13 @@ partial interface Performance {
undefined clearMeasures(optional DOMString measureName); undefined clearMeasures(optional DOMString measureName);
}; };
[Exposed=*] [Exposed=(Window,Worker)]
interface PerformanceMark : PerformanceEntry { interface PerformanceMark : PerformanceEntry {
constructor(DOMString markName, optional PerformanceMarkOptions markOptions = {}); constructor(DOMString markName, optional PerformanceMarkOptions markOptions = {});
readonly attribute any detail; readonly attribute any detail;
}; };
[Exposed=*] [Exposed=(Window,Worker)]
interface PerformanceMeasure : PerformanceEntry { interface PerformanceMeasure : PerformanceEntry {
readonly attribute any detail; readonly attribute any detail;
}; };

View File

@ -9,7 +9,8 @@ typedef (Int8Array or Int16Array or Int32Array or
Float32Array or Float64Array or DataView) ArrayBufferView; Float32Array or Float64Array or DataView) ArrayBufferView;
typedef (ArrayBufferView or ArrayBuffer) BufferSource; typedef (ArrayBufferView or ArrayBuffer) BufferSource;
[Exposed=(Window,Worker), typedef (ArrayBuffer or SharedArrayBuffer or [AllowShared] ArrayBufferView) AllowSharedBufferSource;
[Exposed=*,
Serializable] Serializable]
interface DOMException { // but see below note about ECMAScript binding interface DOMException { // but see below note about ECMAScript binding
constructor(optional DOMString message = "", optional DOMString name = "Error"); constructor(optional DOMString message = "", optional DOMString name = "Error");
@ -46,5 +47,3 @@ interface DOMException { // but see below note about ECMAScript binding
callback Function = any (any... arguments); callback Function = any (any... arguments);
callback VoidFunction = undefined (); callback VoidFunction = undefined ();
typedef unsigned long long DOMTimeStamp;

View File

@ -16,7 +16,8 @@ function polyfill_declarative_shadow_dom(root) {
return; return;
root.querySelectorAll("template[shadowrootmode]").forEach(template => { root.querySelectorAll("template[shadowrootmode]").forEach(template => {
const mode = template.getAttribute("shadowrootmode"); const mode = template.getAttribute("shadowrootmode");
const shadowRoot = template.parentNode.attachShadow({ mode }); const delegatesFocus = template.hasAttribute("shadowrootdelegatesfocus");
const shadowRoot = template.parentNode.attachShadow({ mode, delegatesFocus });
shadowRoot.appendChild(template.content); shadowRoot.appendChild(template.content);
template.remove(); template.remove();
polyfill_declarative_shadow_dom(shadowRoot); polyfill_declarative_shadow_dom(shadowRoot);

View File

@ -2357,12 +2357,13 @@ IdlInterface.prototype.do_member_operation_asserts = function(memberHolderObject
assert_equals(typeof memberHolderObject[member.name], "function", assert_equals(typeof memberHolderObject[member.name], "function",
"property must be a function"); "property must be a function");
const ctors = this.members.filter(function(m) { const operationOverloads = this.members.filter(function(m) {
return m.type == "operation" && m.name == member.name; return m.type == "operation" && m.name == member.name &&
(m.special === "static") === (member.special === "static");
}); });
assert_equals( assert_equals(
memberHolderObject[member.name].length, memberHolderObject[member.name].length,
minOverloadLength(ctors), minOverloadLength(operationOverloads),
"property has wrong .length"); "property has wrong .length");
assert_equals( assert_equals(
memberHolderObject[member.name].name, memberHolderObject[member.name].name,

View File

@ -220,6 +220,40 @@
return cookie; return cookie;
}, },
/**
* Get Computed Label for an element.
*
* This matches the behaviour of the
* `Get Computed Label
* <https://w3c.github.io/webdriver/#dfn-get-computed-label>`_
* WebDriver command.
*
* @param {Element} element
* @returns {Promise} fulfilled after the computed label is returned, or
* rejected in the cases the WebDriver command errors
*/
get_computed_label: async function(element) {
let label = await window.test_driver_internal.get_computed_label(element);
return label;
},
/**
* Get Computed Role for an element.
*
* This matches the behaviour of the
* `Get Computed Label
* <https://w3c.github.io/webdriver/#dfn-get-computed-role>`_
* WebDriver command.
*
* @param {Element} element
* @returns {Promise} fulfilled after the computed role is returned, or
* rejected in the cases the WebDriver command errors
*/
get_computed_role: async function(element) {
let role = await window.test_driver_internal.get_computed_role(element);
return role;
},
/** /**
* Send keys to an element. * Send keys to an element.
* *
@ -228,7 +262,9 @@
* occurs. * occurs.
* *
* If ``element`` is from a different browsing context, the * If ``element`` is from a different browsing context, the
* command will be run in that context. * command will be run in that context. The test must not depend
* on the ``window.name`` property being unset on the target
* window.
* *
* To send special keys, send the respective key's codepoint, * To send special keys, send the respective key's codepoint,
* as defined by `WebDriver * as defined by `WebDriver
@ -262,12 +298,6 @@
inline: "nearest"}); inline: "nearest"});
} }
var pointerInteractablePaintTree = getPointerInteractablePaintTree(element);
if (pointerInteractablePaintTree.length === 0 ||
!element.contains(pointerInteractablePaintTree[0])) {
return Promise.reject(new Error("element send_keys intercepted error"));
}
return window.test_driver_internal.send_keys(element, keys); return window.test_driver_internal.send_keys(element, keys);
}, },
@ -300,9 +330,9 @@
* to run the call, or null for the current * to run the call, or null for the current
* browsing context. * browsing context.
* *
* @returns {Promise} fulfilled with the previous {@link * @returns {Promise} fulfilled with the previous `WindowRect
* https://www.w3.org/TR/webdriver/#dfn-windowrect-object|WindowRect} * <https://www.w3.org/TR/webdriver/#dfn-windowrect-object>`_
* value, after the window is minimized. * value, after the window is minimized.
*/ */
minimize_window: function(context=null) { minimize_window: function(context=null) {
return window.test_driver_internal.minimize_window(context); return window.test_driver_internal.minimize_window(context);
@ -315,8 +345,8 @@
* <https://www.w3.org/TR/webdriver/#set-window-rect>`_ * <https://www.w3.org/TR/webdriver/#set-window-rect>`_
* WebDriver command * WebDriver command
* *
* @param {Object} rect - A {@link * @param {Object} rect - A `WindowRect
* https://www.w3.org/TR/webdriver/#dfn-windowrect-object|WindowRect} * <https://www.w3.org/TR/webdriver/#dfn-windowrect-object>`_
* @param {WindowProxy} context - Browsing context in which * @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current * to run the call, or null for the current
* browsing context. * browsing context.
@ -389,8 +419,9 @@
/** /**
* Sets the state of a permission * Sets the state of a permission
* *
* This function simulates a user setting a permission into a * This function causes permission requests and queries for the status
* particular state. * of a certain permission type (e.g. "push", or "background-fetch") to
* always return ``state``.
* *
* Matches the `Set Permission * Matches the `Set Permission
* <https://w3c.github.io/permissions/#set-permission-command>`_ * <https://w3c.github.io/permissions/#set-permission-command>`_
@ -402,8 +433,10 @@
* *
* @param {PermissionDescriptor} descriptor - a `PermissionDescriptor * @param {PermissionDescriptor} descriptor - a `PermissionDescriptor
* <https://w3c.github.io/permissions/#dom-permissiondescriptor>`_ * <https://w3c.github.io/permissions/#dom-permissiondescriptor>`_
* dictionary. * or derived object.
* @param {String} state - the state of the permission * @param {PermissionState} state - a `PermissionState
* <https://w3c.github.io/permissions/#dom-permissionstate>`_
* value.
* @param {WindowProxy} context - Browsing context in which * @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current * to run the call, or null for the current
* browsing context. * browsing context.
@ -646,6 +679,296 @@
set_spc_transaction_mode: function(mode, context=null) { set_spc_transaction_mode: function(mode, context=null) {
return window.test_driver_internal.set_spc_transaction_mode(mode, context); return window.test_driver_internal.set_spc_transaction_mode(mode, context);
}, },
/**
* Cancels the Federated Credential Management dialog
*
* Matches the `Cancel dialog
* <https://fedidcg.github.io/FedCM/#webdriver-canceldialog>`_
* WebDriver command.
*
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} Fulfilled after the dialog is canceled, or rejected
* in case the WebDriver command errors
*/
cancel_fedcm_dialog: function(context=null) {
return window.test_driver_internal.cancel_fedcm_dialog(context);
},
/**
* Clicks a button on the Federated Credential Management dialog
*
* Matches the `Click dialog button
* <https://fedidcg.github.io/FedCM/#webdriver-clickdialogbutton>`_
* WebDriver command.
*
* @param {String} dialog_button - String enum representing the dialog button to click.
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} Fulfilled after the button is clicked,
* or rejected in case the WebDriver command errors
*/
click_fedcm_dialog_button: function(dialog_button, context=null) {
return window.test_driver_internal.click_fedcm_dialog_button(dialog_button, context);
},
/**
* Selects an account from the Federated Credential Management dialog
*
* Matches the `Select account
* <https://fedidcg.github.io/FedCM/#webdriver-selectaccount>`_
* WebDriver command.
*
* @param {number} account_index - Index of the account to select.
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} Fulfilled after the account is selected,
* or rejected in case the WebDriver command errors
*/
select_fedcm_account: function(account_index, context=null) {
return window.test_driver_internal.select_fedcm_account(account_index, context);
},
/**
* Gets the account list from the Federated Credential Management dialog
*
* Matches the `Account list
* <https://fedidcg.github.io/FedCM/#webdriver-accountlist>`_
* WebDriver command.
*
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} fulfilled after the account list is returned, or
* rejected in case the WebDriver command errors
*/
get_fedcm_account_list: function(context=null) {
return window.test_driver_internal.get_fedcm_account_list(context);
},
/**
* Gets the title of the Federated Credential Management dialog
*
* Matches the `Get title
* <https://fedidcg.github.io/FedCM/#webdriver-gettitle>`_
* WebDriver command.
*
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} Fulfilled after the title is returned, or rejected
* in case the WebDriver command errors
*/
get_fedcm_dialog_title: function(context=null) {
return window.test_driver_internal.get_fedcm_dialog_title(context);
},
/**
* Gets the type of the Federated Credential Management dialog
*
* Matches the `Get dialog type
* <https://fedidcg.github.io/FedCM/#webdriver-getdialogtype>`_
* WebDriver command.
*
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} Fulfilled after the dialog type is returned, or
* rejected in case the WebDriver command errors
*/
get_fedcm_dialog_type: function(context=null) {
return window.test_driver_internal.get_fedcm_dialog_type(context);
},
/**
* Sets whether promise rejection delay is enabled for the Federated Credential Management dialog
*
* Matches the `Set delay enabled
* <https://fedidcg.github.io/FedCM/#webdriver-setdelayenabled>`_
* WebDriver command.
*
* @param {boolean} enabled - Whether to delay FedCM promise rejection.
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} Fulfilled after the delay has been enabled or disabled,
* or rejected in case the WebDriver command errors
*/
set_fedcm_delay_enabled: function(enabled, context=null) {
return window.test_driver_internal.set_fedcm_delay_enabled(enabled, context);
},
/**
* Resets the Federated Credential Management dialog's cooldown
*
* Matches the `Reset cooldown
* <https://fedidcg.github.io/FedCM/#webdriver-resetcooldown>`_
* WebDriver command.
*
* @param {WindowProxy} context - Browsing context in which
* to run the call, or null for the current
* browsing context.
*
* @returns {Promise} Fulfilled after the cooldown has been reset,
* or rejected in case the WebDriver command errors
*/
reset_fedcm_cooldown: function(context=null) {
return window.test_driver_internal.reset_fedcm_cooldown(context);
},
/**
* Creates a virtual sensor for use with the Generic Sensors APIs.
*
* Matches the `Create Virtual Sensor
* <https://w3c.github.io/sensors/#create-virtual-sensor-command>`_
* WebDriver command.
*
* Once created, a virtual sensor is available to all navigables under
* the same top-level traversable (i.e. all frames in the same page,
* regardless of origin).
*
* @param {String} sensor_type - A `virtual sensor type
* <https://w3c.github.io/sensors/#virtual-sensor-metadata-virtual-sensor-type>`_
* such as "accelerometer".
* @param {Object} [sensor_params={}] - Optional parameters described
* in `Create Virtual Sensor
* <https://w3c.github.io/sensors/#create-virtual-sensor-command>`_.
* @param {WindowProxy} [context=null] - Browsing context in which to
* run the call, or null for the
* current browsing context.
*
* @returns {Promise} Fulfilled when virtual sensor is created.
* Rejected in case the WebDriver command errors out
* (including if a virtual sensor of the same type
* already exists).
*/
create_virtual_sensor: function(sensor_type, sensor_params={}, context=null) {
return window.test_driver_internal.create_virtual_sensor(sensor_type, sensor_params, context);
},
/**
* Causes a virtual sensor to report a new reading to any connected
* platform sensor.
*
* Matches the `Update Virtual Sensor Reading
* <https://w3c.github.io/sensors/#update-virtual-sensor-reading-command>`_
* WebDriver command.
*
* Note: The ``Promise`` it returns may fulfill before or after a
* "reading" event is fired. When using
* :js:func:`EventWatcher.wait_for`, it is necessary to take this into
* account:
*
* Note: New values may also be discarded due to the checks in `update
* latest reading
* <https://w3c.github.io/sensors/#update-latest-reading>`_.
*
* @example
* // Avoid races between EventWatcher and update_virtual_sensor().
* // This assumes you are sure this reading will be processed (see
* // the example below otherwise).
* const reading = { x: 1, y: 2, z: 3 };
* await Promise.all([
* test_driver.update_virtual_sensor('gyroscope', reading),
* watcher.wait_for('reading')
* ]);
*
* @example
* // Do not wait forever if you are not sure the reading will be
* // processed.
* const readingPromise = watcher.wait_for('reading');
* const timeoutPromise = new Promise(resolve => {
* t.step_timeout(() => resolve('TIMEOUT', 3000))
* });
*
* const reading = { x: 1, y: 2, z: 3 };
* await test_driver.update_virtual_sensor('gyroscope', 'reading');
*
* const value =
* await Promise.race([timeoutPromise, readingPromise]);
* if (value !== 'TIMEOUT') {
* // Do something. The "reading" event was fired.
* }
*
* @param {String} sensor_type - A `virtual sensor type
* <https://w3c.github.io/sensors/#virtual-sensor-metadata-virtual-sensor-type>`_
* such as "accelerometer".
* @param {Object} reading - An Object describing a reading in a format
* dependent on ``sensor_type`` (e.g. ``{x:
* 1, y: 2, z: 3}`` or ``{ illuminance: 42
* }``).
* @param {WindowProxy} [context=null] - Browsing context in which to
* run the call, or null for the
* current browsing context.
*
* @returns {Promise} Fulfilled after the reading update reaches the
* virtual sensor. Rejected in case the WebDriver
* command errors out (including if a virtual sensor
* of the given type does not exist).
*/
update_virtual_sensor: function(sensor_type, reading, context=null) {
return window.test_driver_internal.update_virtual_sensor(sensor_type, reading, context);
},
/**
* Triggers the removal of a virtual sensor if it exists.
*
* Matches the `Delete Virtual Sensor
* <https://w3c.github.io/sensors/#delete-virtual-sensor-command>`_
* WebDriver command.
*
* @param {String} sensor_type - A `virtual sensor type
* <https://w3c.github.io/sensors/#virtual-sensor-metadata-virtual-sensor-type>`_
* such as "accelerometer".
* @param {WindowProxy} [context=null] - Browsing context in which to
* run the call, or null for the
* current browsing context.
*
* @returns {Promise} Fulfilled after the virtual sensor has been
* removed or if a sensor of the given type does not
* exist. Rejected in case the WebDriver command
* errors out.
*/
remove_virtual_sensor: function(sensor_type, context=null) {
return window.test_driver_internal.remove_virtual_sensor(sensor_type, context);
},
/**
* Returns information about a virtual sensor.
*
* Matches the `Get Virtual Sensor Information
* <https://w3c.github.io/sensors/#get-virtual-sensor-information-command>`_
* WebDriver command.
*
* @param {String} sensor_type - A `virtual sensor type
* <https://w3c.github.io/sensors/#virtual-sensor-metadata-virtual-sensor-type>`_
* such as "accelerometer".
* @param {WindowProxy} [context=null] - Browsing context in which to
* run the call, or null for the
* current browsing context.
*
* @returns {Promise} Fulfilled with an Object with the properties
* described in `Get Virtual Sensor Information
* <https://w3c.github.io/sensors/#get-virtual-sensor-information-command>`_.
* Rejected in case the WebDriver command errors out
* (including if a virtual sensor of the given type
* does not exist).
*/
get_virtual_sensor_information: function(sensor_type, context=null) {
return window.test_driver_internal.get_virtual_sensor_information(sensor_type, context);
}
}; };
window.test_driver_internal = { window.test_driver_internal = {
@ -657,9 +980,9 @@
*/ */
in_automation: false, in_automation: false,
click: function(element, coords) { async click(element, coords) {
if (this.in_automation) { if (this.in_automation) {
return Promise.reject(new Error('Not implemented')); throw new Error("click() is not implemented by testdriver-vendor.js");
} }
return new Promise(function(resolve, reject) { return new Promise(function(resolve, reject) {
@ -667,21 +990,21 @@
}); });
}, },
delete_all_cookies: function(context=null) { async delete_all_cookies(context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("delete_all_cookies() is not implemented by testdriver-vendor.js");
}, },
get_all_cookies: function(context=null) { async get_all_cookies(context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("get_all_cookies() is not implemented by testdriver-vendor.js");
}, },
get_named_cookie: function(name, context=null) { async get_named_cookie(name, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("get_named_cookie() is not implemented by testdriver-vendor.js");
}, },
send_keys: function(element, keys) { async send_keys(element, keys) {
if (this.in_automation) { if (this.in_automation) {
return Promise.reject(new Error('Not implemented')); throw new Error("send_keys() is not implemented by testdriver-vendor.js");
} }
return new Promise(function(resolve, reject) { return new Promise(function(resolve, reject) {
@ -711,66 +1034,112 @@
}); });
}, },
freeze: function(context=null) { async freeze(context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("freeze() is not implemented by testdriver-vendor.js");
}, },
minimize_window: function(context=null) { async minimize_window(context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("minimize_window() is not implemented by testdriver-vendor.js");
}, },
set_window_rect: function(rect, context=null) { async set_window_rect(rect, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("set_window_rect() is not implemented by testdriver-vendor.js");
}, },
action_sequence: function(actions, context=null) { async action_sequence(actions, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("action_sequence() is not implemented by testdriver-vendor.js");
}, },
generate_test_report: function(message, context=null) { async generate_test_report(message, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("generate_test_report() is not implemented by testdriver-vendor.js");
}, },
async set_permission(permission_params, context=null) {
set_permission: function(permission_params, context=null) { throw new Error("set_permission() is not implemented by testdriver-vendor.js");
return Promise.reject(new Error("unimplemented"));
}, },
add_virtual_authenticator: function(config, context=null) { async add_virtual_authenticator(config, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("add_virtual_authenticator() is not implemented by testdriver-vendor.js");
}, },
remove_virtual_authenticator: function(authenticator_id, context=null) { async remove_virtual_authenticator(authenticator_id, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("remove_virtual_authenticator() is not implemented by testdriver-vendor.js");
}, },
add_credential: function(authenticator_id, credential, context=null) { async add_credential(authenticator_id, credential, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("add_credential() is not implemented by testdriver-vendor.js");
}, },
get_credentials: function(authenticator_id, context=null) { async get_credentials(authenticator_id, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("get_credentials() is not implemented by testdriver-vendor.js");
}, },
remove_credential: function(authenticator_id, credential_id, context=null) { async remove_credential(authenticator_id, credential_id, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("remove_credential() is not implemented by testdriver-vendor.js");
}, },
remove_all_credentials: function(authenticator_id, context=null) { async remove_all_credentials(authenticator_id, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("remove_all_credentials() is not implemented by testdriver-vendor.js");
}, },
set_user_verified: function(authenticator_id, uv, context=null) { async set_user_verified(authenticator_id, uv, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("set_user_verified() is not implemented by testdriver-vendor.js");
}, },
set_storage_access: function(origin, embedding_origin, blocked, context=null) { async set_storage_access(origin, embedding_origin, blocked, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("set_storage_access() is not implemented by testdriver-vendor.js");
}, },
set_spc_transaction_mode: function(mode, context=null) { async set_spc_transaction_mode(mode, context=null) {
return Promise.reject(new Error("unimplemented")); throw new Error("set_spc_transaction_mode() is not implemented by testdriver-vendor.js");
}, },
async cancel_fedcm_dialog(context=null) {
throw new Error("cancel_fedcm_dialog() is not implemented by testdriver-vendor.js");
},
async click_fedcm_dialog_button(dialog_button, context=null) {
throw new Error("click_fedcm_dialog_button() is not implemented by testdriver-vendor.js");
},
async select_fedcm_account(account_index, context=null) {
throw new Error("select_fedcm_account() is not implemented by testdriver-vendor.js");
},
async get_fedcm_account_list(context=null) {
throw new Error("get_fedcm_account_list() is not implemented by testdriver-vendor.js");
},
async get_fedcm_dialog_title(context=null) {
throw new Error("get_fedcm_dialog_title() is not implemented by testdriver-vendor.js");
},
async get_fedcm_dialog_type(context=null) {
throw new Error("get_fedcm_dialog_type() is not implemented by testdriver-vendor.js");
},
async set_fedcm_delay_enabled(enabled, context=null) {
throw new Error("set_fedcm_delay_enabled() is not implemented by testdriver-vendor.js");
},
async reset_fedcm_cooldown(context=null) {
throw new Error("reset_fedcm_cooldown() is not implemented by testdriver-vendor.js");
},
async create_virtual_sensor(sensor_type, sensor_params, context=null) {
throw new Error("create_virtual_sensor() is not implemented by testdriver-vendor.js");
},
async update_virtual_sensor(sensor_type, reading, context=null) {
throw new Error("update_virtual_sensor() is not implemented by testdriver-vendor.js");
},
async remove_virtual_sensor(sensor_type, context=null) {
throw new Error("remove_virtual_sensor() is not implemented by testdriver-vendor.js");
},
async get_virtual_sensor_information(sensor_type, context=null) {
throw new Error("get_virtual_sensor_information() is not implemented by testdriver-vendor.js");
}
}; };
})(); })();

View File

@ -1426,12 +1426,16 @@
function assert_wrapper(...args) { function assert_wrapper(...args) {
let status = Test.statuses.TIMEOUT; let status = Test.statuses.TIMEOUT;
let stack = null; let stack = null;
let new_assert_index = null;
try { try {
if (settings.debug) { if (settings.debug) {
console.debug("ASSERT", name, tests.current_test && tests.current_test.name, args); console.debug("ASSERT", name, tests.current_test && tests.current_test.name, args);
} }
if (tests.output) { if (tests.output) {
tests.set_assert(name, args); tests.set_assert(name, args);
// Remember the newly pushed assert's index, because `apply`
// below might push new asserts.
new_assert_index = tests.asserts_run.length - 1;
} }
const rv = f.apply(undefined, args); const rv = f.apply(undefined, args);
status = Test.statuses.PASS; status = Test.statuses.PASS;
@ -1445,7 +1449,7 @@
stack = get_stack(); stack = get_stack();
} }
if (tests.output) { if (tests.output) {
tests.set_assert_status(status, stack); tests.set_assert_status(new_assert_index, status, stack);
} }
} }
} }
@ -1493,7 +1497,7 @@
/** /**
* Assert that ``actual`` is the same value as ``expected``. * Assert that ``actual`` is the same value as ``expected``.
* *
* For objects this compares by cobject identity; for primitives * For objects this compares by object identity; for primitives
* this distinguishes between 0 and -0, and has correct handling * this distinguishes between 0 and -0, and has correct handling
* of NaN. * of NaN.
* *
@ -2725,8 +2729,9 @@
* speed when the condition is quickly met. * speed when the condition is quickly met.
* *
* @param {Function} cond A function taking no arguments and * @param {Function} cond A function taking no arguments and
* returning a boolean. The callback is called * returning a boolean or a Promise. The callback is
* when this function returns true. * called when this function returns true, or the
* returned Promise is resolved with true.
* @param {Function} func A function taking no arguments to call once * @param {Function} func A function taking no arguments to call once
* the condition is met. * the condition is met.
* @param {string} [description] Error message to add to assert in case of * @param {string} [description] Error message to add to assert in case of
@ -2742,11 +2747,11 @@
var remaining = Math.ceil(timeout_full / interval); var remaining = Math.ceil(timeout_full / interval);
var test_this = this; var test_this = this;
var wait_for_inner = test_this.step_func(() => { const step = test_this.step_func((result) => {
if (cond()) { if (result) {
func(); func();
} else { } else {
if(remaining === 0) { if (remaining === 0) {
assert(false, "step_wait_func", description, assert(false, "step_wait_func", description,
"Timed out waiting on condition"); "Timed out waiting on condition");
} }
@ -2755,6 +2760,12 @@
} }
}); });
var wait_for_inner = test_this.step_func(() => {
Promise.resolve(cond()).then(
step,
test_this.unreached_func("step_wait_func"));
});
wait_for_inner(); wait_for_inner();
}; };
@ -2780,8 +2791,9 @@
* }, "Navigating a popup to about:blank"); * }, "Navigating a popup to about:blank");
* *
* @param {Function} cond A function taking no arguments and * @param {Function} cond A function taking no arguments and
* returning a boolean. The callback is called * returning a boolean or a Promise. The callback is
* when this function returns true. * called when this function returns true, or the
* returned Promise is resolved with true.
* @param {Function} func A function taking no arguments to call once * @param {Function} func A function taking no arguments to call once
* the condition is met. * the condition is met.
* @param {string} [description] Error message to add to assert in case of * @param {string} [description] Error message to add to assert in case of
@ -2817,7 +2829,7 @@
* }, ""); * }, "");
* *
* @param {Function} cond A function taking no arguments and * @param {Function} cond A function taking no arguments and
* returning a boolean. * returning a boolean or a Promise.
* @param {string} [description] Error message to add to assert in case of * @param {string} [description] Error message to add to assert in case of
* failure. * failure.
* @param {number} timeout Timeout in ms. This is multiplied by the global * @param {number} timeout Timeout in ms. This is multiplied by the global
@ -3673,8 +3685,8 @@
this.asserts_run.push(new AssertRecord(this.current_test, assert_name, args)) this.asserts_run.push(new AssertRecord(this.current_test, assert_name, args))
} }
Tests.prototype.set_assert_status = function(status, stack) { Tests.prototype.set_assert_status = function(index, status, stack) {
let assert_record = this.asserts_run[this.asserts_run.length - 1]; let assert_record = this.asserts_run[index];
assert_record.status = status; assert_record.status = status;
assert_record.stack = stack; assert_record.stack = stack;
} }

View File

@ -52,7 +52,7 @@
"path": "html/webappapis/timers" "path": "html/webappapis/timers"
}, },
"interfaces": { "interfaces": {
"commit": "df731dab88a1a25c04eb7e6238c11dc28fda0801", "commit": "727995f0432f7ab2ea35c8679412edc28d87ec08",
"path": "interfaces" "path": "interfaces"
}, },
"performance-timeline": { "performance-timeline": {
@ -64,7 +64,7 @@
"path": "resource-timing" "path": "resource-timing"
}, },
"resources": { "resources": {
"commit": "919874f84ff3703365063e749161a34af38c3d2a", "commit": "1e140d63ec885703ce24b3798abd81912696bb85",
"path": "resources" "path": "resources"
}, },
"streams": { "streams": {

View File

@ -22,9 +22,6 @@
"idlharness-shadowrealm.window.js": { "idlharness-shadowrealm.window.js": {
"skip": "ShadowRealm support is not enabled" "skip": "ShadowRealm support is not enabled"
}, },
"idlharness.https.any.js": {
"skip": "wpt/resources is not as simple to bring up to date"
},
"third_party/pako/pako_inflate.min.js": { "third_party/pako/pako_inflate.min.js": {
"skip": "This is not a test file." "skip": "This is not a test file."
} }

View File

@ -19,5 +19,22 @@
}, },
"buffered-flag.any.js": { "buffered-flag.any.js": {
"skip": "Browser-specific test" "skip": "Browser-specific test"
},
"idlharness.any.js": {
"fail": {
"expected": [
"PerformanceResourceTiming interface: attribute deliveryType",
"PerformanceResourceTiming interface: attribute firstInterimResponseStart",
"PerformanceResourceTiming interface: attribute responseStatus",
"PerformanceResourceTiming interface: attribute renderBlockingStatus",
"PerformanceResourceTiming interface: attribute contentType",
"PerformanceResourceTiming interface: resource must inherit property \"deliveryType\" with the proper type",
"PerformanceResourceTiming interface: resource must inherit property \"firstInterimResponseStart\" with the proper type",
"PerformanceResourceTiming interface: resource must inherit property \"responseStatus\" with the proper type",
"PerformanceResourceTiming interface: resource must inherit property \"renderBlockingStatus\" with the proper type",
"PerformanceResourceTiming interface: resource must inherit property \"contentType\" with the proper type",
"PerformanceResourceTiming interface: default toJSON operation on resource"
]
}
} }
} }

View File

@ -2,7 +2,8 @@
"idlharness.any.js": { "idlharness.any.js": {
"fail": { "fail": {
"expected": [ "expected": [
"ReadableStream interface: async iterable<any>" "ReadableStream interface: async iterable<any>",
"ReadableStream interface: operation from(any)"
] ]
} }
}, },

View File

@ -4,4 +4,6 @@ const { WPTRunner } = require('../common/wpt');
const runner = new WPTRunner('compression'); const runner = new WPTRunner('compression');
runner.pretendGlobalThisAs('Window');
runner.runJsTests(); runner.runJsTests();