diff options
author | Glenn Watson <gw@intuitionlibrary.com> | 2015-02-26 13:01:12 +1000 |
---|---|---|
committer | Glenn Watson <gw@intuitionlibrary.com> | 2015-02-26 13:01:12 +1000 |
commit | 93088e84f07711481eb0e55d23fd4ab8f996f4a7 (patch) | |
tree | 8482334bcbd6c2c51eb5f520ebbdff79f9700f31 /components/script | |
parent | 259792e4818c6356a87d8375503feff9f837cf21 (diff) | |
download | servo-93088e84f07711481eb0e55d23fd4ab8f996f4a7.tar.gz servo-93088e84f07711481eb0e55d23fd4ab8f996f4a7.zip |
If root html element contains "reftest-wait" class, don't mark document as ready until it's removed.
This allows reftests to perform tests for incremental layout and other bugs that require rendering multiple frames.
Diffstat (limited to 'components/script')
-rw-r--r-- | components/script/script_task.rs | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/components/script/script_task.rs b/components/script/script_task.rs index 348328507c6..83b2fd8cadf 100644 --- a/components/script/script_task.rs +++ b/components/script/script_task.rs @@ -22,7 +22,7 @@ use dom::bindings::structuredclone::StructuredCloneData; use dom::bindings::trace::JSTraceable; use dom::bindings::utils::{wrap_for_same_compartment, pre_wrap}; use dom::document::{Document, IsHTMLDocument, DocumentHelpers, DocumentProgressHandler, DocumentProgressTask, DocumentSource}; -use dom::element::{Element, ActivationElementHelpers}; +use dom::element::{Element, ActivationElementHelpers, AttributeHandlers}; use dom::event::{Event, EventHelpers}; use dom::uievent::UIEvent; use dom::eventtarget::EventTarget; @@ -59,6 +59,7 @@ use net::image_cache_task::ImageCacheTask; use net::resource_task::{ResourceTask, ControlMsg}; use net::resource_task::LoadData as NetLoadData; use net::storage_task::StorageTask; +use string_cache::Atom; use util::geometry::to_frac_px; use util::smallvec::SmallVec; use util::str::DOMString; @@ -695,7 +696,13 @@ impl ScriptTask { *layout_join_port = None; } - self.compositor.borrow_mut().set_ready_state(pipeline_id, FinishedLoading); + let doc = page.frame().as_ref().unwrap().document.root(); + let html_element = doc.r().GetDocumentElement().root(); + let reftest_wait = html_element.r().map_or(false, |elem| elem.has_class(&Atom::from_slice("reftest-wait"))); + + if !reftest_wait { + self.compositor.borrow_mut().set_ready_state(pipeline_id, FinishedLoading); + } } /// Window was resized, but this script was not active, so don't reflow yet |