aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGregory Terzian <gterzian@users.noreply.github.com>2017-05-15 07:19:58 +0800
committerGregory Terzian <gterzian@users.noreply.github.com>2017-05-19 17:29:16 +0800
commita8390aea2451928153bd744e7eeb73fc70564124 (patch)
tree0848b50b49447aa9ce47a523f75e319f1915a442
parent5da0aa9f11b7b1c2dc8b5adf178eebafa92d1849 (diff)
downloadservo-a8390aea2451928153bd744e7eeb73fc70564124.tar.gz
servo-a8390aea2451928153bd744e7eeb73fc70564124.zip
use microtasks to await a stable state
-rw-r--r--components/script/dom/htmlmediaelement.rs83
-rw-r--r--components/script/microtask.rs9
-rw-r--r--components/script/script_thread.rs7
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-load.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause-networkState.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-play.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src-not-in-document.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src.html.ini5
-rw-r--r--tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-remove-src.html.ini5
12 files changed, 47 insertions, 97 deletions
diff --git a/components/script/dom/htmlmediaelement.rs b/components/script/dom/htmlmediaelement.rs
index 679294dae1a..eed7020887f 100644
--- a/components/script/dom/htmlmediaelement.rs
+++ b/components/script/dom/htmlmediaelement.rs
@@ -31,6 +31,7 @@ use dom_struct::dom_struct;
use html5ever::{LocalName, Prefix};
use ipc_channel::ipc;
use ipc_channel::router::ROUTER;
+use microtask::{Microtask, MicrotaskRunnable};
use net_traits::{FetchResponseListener, FetchMetadata, Metadata, NetworkError};
use net_traits::request::{CredentialsMode, Destination, RequestInit, Type as RequestType};
use network_listener::{NetworkListener, PreInvoke};
@@ -429,7 +430,11 @@ impl HTMLMediaElement {
// Step 4
let doc = document_from_node(self);
- ScriptThread::await_stable_state(ResourceSelectionTask::new(self, doc.base_url()));
+ let task = MediaElementMicrotask::ResourceSelectionTask {
+ elem: Root::from_ref(self),
+ base_url: doc.base_url()
+ };
+ ScriptThread::await_stable_state(Microtask::MediaElement(task));
}
// https://html.spec.whatwg.org/multipage/#concept-media-load-algorithm
@@ -781,7 +786,36 @@ impl VirtualMethods for HTMLMediaElement {
self.super_type().unwrap().unbind_from_tree(context);
if context.tree_in_doc {
- ScriptThread::await_stable_state(PauseIfNotInDocumentTask::new(self));
+ let task = MediaElementMicrotask::PauseIfNotInDocumentTask {
+ elem: Root::from_ref(self)
+ };
+ ScriptThread::await_stable_state(Microtask::MediaElement(task));
+ }
+ }
+}
+
+#[derive(JSTraceable, HeapSizeOf)]
+pub enum MediaElementMicrotask {
+ ResourceSelectionTask {
+ elem: Root<HTMLMediaElement>,
+ base_url: ServoUrl
+ },
+ PauseIfNotInDocumentTask {
+ elem: Root<HTMLMediaElement>,
+ }
+}
+
+impl MicrotaskRunnable for MediaElementMicrotask {
+ fn handler(&self) {
+ match self {
+ &MediaElementMicrotask::ResourceSelectionTask { ref elem, ref base_url } => {
+ elem.resource_selection_algorithm_sync(base_url.clone());
+ },
+ &MediaElementMicrotask::PauseIfNotInDocumentTask { ref elem } => {
+ if !elem.upcast::<Node>().is_in_doc() {
+ elem.internal_pause_steps();
+ }
+ },
}
}
}
@@ -809,28 +843,6 @@ impl Runnable for FireSimpleEventTask {
}
}
-struct ResourceSelectionTask {
- elem: Trusted<HTMLMediaElement>,
- base_url: ServoUrl,
-}
-
-impl ResourceSelectionTask {
- fn new(elem: &HTMLMediaElement, url: ServoUrl) -> ResourceSelectionTask {
- ResourceSelectionTask {
- elem: Trusted::new(elem),
- base_url: url,
- }
- }
-}
-
-impl Runnable for ResourceSelectionTask {
- fn name(&self) -> &'static str { "ResourceSelectionTask" }
-
- fn handler(self: Box<ResourceSelectionTask>) {
- self.elem.root().resource_selection_algorithm_sync(self.base_url);
- }
-}
-
struct DedicatedMediaSourceFailureTask {
elem: Trusted<HTMLMediaElement>,
}
@@ -851,29 +863,6 @@ impl Runnable for DedicatedMediaSourceFailureTask {
}
}
-struct PauseIfNotInDocumentTask {
- elem: Trusted<HTMLMediaElement>,
-}
-
-impl PauseIfNotInDocumentTask {
- fn new(elem: &HTMLMediaElement) -> PauseIfNotInDocumentTask {
- PauseIfNotInDocumentTask {
- elem: Trusted::new(elem),
- }
- }
-}
-
-impl Runnable for PauseIfNotInDocumentTask {
- fn name(&self) -> &'static str { "PauseIfNotInDocumentTask" }
-
- fn handler(self: Box<PauseIfNotInDocumentTask>) {
- let elem = self.elem.root();
- if !elem.upcast::<Node>().is_in_doc() {
- elem.internal_pause_steps();
- }
- }
-}
-
enum ResourceSelectionMode {
Object,
Attribute(String),
diff --git a/components/script/microtask.rs b/components/script/microtask.rs
index 7fadf111ddb..8f10dbcf489 100644
--- a/components/script/microtask.rs
+++ b/components/script/microtask.rs
@@ -11,6 +11,7 @@ use dom::bindings::cell::DOMRefCell;
use dom::bindings::codegen::Bindings::PromiseBinding::PromiseJobCallback;
use dom::bindings::js::Root;
use dom::globalscope::GlobalScope;
+use dom::htmlmediaelement::MediaElementMicrotask;
use dom::mutationobserver::MutationObserver;
use msg::constellation_msg::PipelineId;
use std::cell::Cell;
@@ -29,9 +30,14 @@ pub struct MicrotaskQueue {
#[derive(JSTraceable, HeapSizeOf)]
pub enum Microtask {
Promise(EnqueuedPromiseCallback),
+ MediaElement(MediaElementMicrotask),
NotifyMutationObservers,
}
+pub trait MicrotaskRunnable {
+ fn handler(&self) {}
+}
+
/// A promise callback scheduled to run during the next microtask checkpoint (#4283).
#[derive(JSTraceable, HeapSizeOf)]
pub struct EnqueuedPromiseCallback {
@@ -72,6 +78,9 @@ impl MicrotaskQueue {
if let Some(target) = target_provider(job.pipeline) {
let _ = job.callback.Call_(&*target, ExceptionHandling::Report);
}
+ },
+ Microtask::MediaElement(ref task) => {
+ task.handler();
}
Microtask::NotifyMutationObservers => {
MutationObserver::notify_mutation_observers();
diff --git a/components/script/script_thread.rs b/components/script/script_thread.rs
index a8b20b6cf98..3f6c82b80ef 100644
--- a/components/script/script_thread.rs
+++ b/components/script/script_thread.rs
@@ -665,14 +665,11 @@ impl ScriptThread {
}
// https://html.spec.whatwg.org/multipage/#await-a-stable-state
- pub fn await_stable_state<T: Runnable + Send + 'static>(task: T) {
- //TODO use microtasks when they exist
+ pub fn await_stable_state(task: Microtask) {
SCRIPT_THREAD_ROOT.with(|root| {
if let Some(script_thread) = root.get() {
let script_thread = unsafe { &*script_thread };
- let _ = script_thread.chan.send(CommonScriptMsg::RunnableMsg(
- ScriptThreadEventCategory::DomEvent,
- box task));
+ script_thread.microtask_queue.enqueue(task);
}
});
}
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html.ini
deleted file mode 100644
index e40c139642f..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-in-sync-event.html]
- type: testharness
- [await a stable state and sync event handlers]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-load.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-load.html.ini
deleted file mode 100644
index f27a8b88e16..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-load.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-load.html]
- type: testharness
- [invoking resource selection with load()]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause-networkState.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause-networkState.html.ini
deleted file mode 100644
index 3ca07b5635e..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause-networkState.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-pause-networkState.html]
- type: testharness
- [NOT invoking resource selection with pause() when networkState is not NETWORK_EMPTY]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause.html.ini
deleted file mode 100644
index 778a31e4fc0..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-pause.html]
- type: testharness
- [invoking resource selection with pause()]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-play.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-play.html.ini
deleted file mode 100644
index e0181017194..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-play.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-play.html]
- type: testharness
- [invoking resource selection with play()]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html.ini
deleted file mode 100644
index 0104538e3a5..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-remove-from-document-networkState.html]
- type: testharness
- [NOT invoking resource selection with implicit pause() when networkState is not NETWORK_EMPTY]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src-not-in-document.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src-not-in-document.html.ini
deleted file mode 100644
index b4b13f4b436..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src-not-in-document.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-set-src-not-in-document.html]
- type: testharness
- [invoking load by setting src on video not in a document]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src.html.ini
deleted file mode 100644
index 7ee9523c423..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-invoke-set-src.html]
- type: testharness
- [invoking load by setting src]
- expected: FAIL
-
diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-remove-src.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-remove-src.html.ini
deleted file mode 100644
index 1e560e440e6..00000000000
--- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-remove-src.html.ini
+++ /dev/null
@@ -1,5 +0,0 @@
-[resource-selection-remove-src.html]
- type: testharness
- [invoking resource selection by setting src; await stable state]
- expected: FAIL
-