Adding relevant mutations and new test results

This commit is contained in:
paavininanda 2018-07-22 15:48:43 +05:30
parent a6dbfdd29f
commit 3f24d67928
8 changed files with 83 additions and 127 deletions

View file

@ -872,7 +872,7 @@ impl HTMLImageElement {
} }
/// <https://html.spec.whatwg.org/multipage/#update-the-image-data> /// <https://html.spec.whatwg.org/multipage/#update-the-image-data>
fn update_the_image_data(&self) { pub fn update_the_image_data(&self) {
let document = document_from_node(self); let document = document_from_node(self);
let window = document.window(); let window = document.window();
let elem = self.upcast::<Element>(); let elem = self.upcast::<Element>();
@ -1574,15 +1574,11 @@ impl VirtualMethods for HTMLImageElement {
fn attribute_mutated(&self, attr: &Attr, mutation: AttributeMutation) { fn attribute_mutated(&self, attr: &Attr, mutation: AttributeMutation) {
self.super_type().unwrap().attribute_mutated(attr, mutation); self.super_type().unwrap().attribute_mutated(attr, mutation);
match attr.local_name() { match attr.local_name() {
&local_name!("src") => self.update_the_image_data(), &local_name!("src") | &local_name!("srcset") |
&local_name!("srcset") => self.update_the_image_data(), &local_name!("width") | &local_name!("crossorigin") |
&local_name!("sizes") => self.update_the_image_data(),
_ => {}, _ => {},
} }
if let Some(parent) = self.upcast::<Node>().GetParentElement() {
if parent.is::<HTMLPictureElement>() {
self.update_the_image_data();
}
}
} }
fn parse_plain_attribute(&self, name: &LocalName, value: DOMString) -> AttrValue { fn parse_plain_attribute(&self, name: &LocalName, value: DOMString) -> AttrValue {
@ -1645,6 +1641,9 @@ impl VirtualMethods for HTMLImageElement {
if tree_in_doc { if tree_in_doc {
document.register_responsive_image(self); document.register_responsive_image(self);
} }
// The element is inserted into a picture parent element
// https://html.spec.whatwg.org/multipage/#relevant-mutations
if let Some(parent) = self.upcast::<Node>().GetParentElement() { if let Some(parent) = self.upcast::<Node>().GetParentElement() {
if parent.is::<HTMLPictureElement>() { if parent.is::<HTMLPictureElement>() {
self.update_the_image_data(); self.update_the_image_data();
@ -1656,6 +1655,12 @@ impl VirtualMethods for HTMLImageElement {
self.super_type().unwrap().unbind_from_tree(context); self.super_type().unwrap().unbind_from_tree(context);
let document = document_from_node(self); let document = document_from_node(self);
document.unregister_responsive_image(self); document.unregister_responsive_image(self);
// The element is removed from a picture parent element
// https://html.spec.whatwg.org/multipage/#relevant-mutations
if context.parent.is::<HTMLPictureElement>() {
self.update_the_image_data();
}
} }
} }

View file

@ -2,16 +2,20 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
use dom::attr::Attr;
use dom::bindings::codegen::Bindings::HTMLSourceElementBinding; use dom::bindings::codegen::Bindings::HTMLSourceElementBinding;
use dom::bindings::codegen::Bindings::HTMLSourceElementBinding::HTMLSourceElementMethods; use dom::bindings::codegen::Bindings::HTMLSourceElementBinding::HTMLSourceElementMethods;
use dom::bindings::codegen::Bindings::NodeBinding::NodeBinding::NodeMethods; use dom::bindings::codegen::Bindings::NodeBinding::NodeBinding::NodeMethods;
use dom::bindings::inheritance::Castable; use dom::bindings::inheritance::Castable;
use dom::bindings::root::{Dom, Root};
use dom::bindings::root::DomRoot; use dom::bindings::root::DomRoot;
use dom::bindings::str::DOMString; use dom::bindings::str::DOMString;
use dom::document::Document; use dom::document::Document;
use dom::element::AttributeMutation;
use dom::htmlelement::HTMLElement; use dom::htmlelement::HTMLElement;
use dom::htmlimageelement::HTMLImageElement;
use dom::htmlmediaelement::HTMLMediaElement; use dom::htmlmediaelement::HTMLMediaElement;
use dom::node::Node; use dom::node::{Node, UnbindContext};
use dom::virtualmethods::VirtualMethods; use dom::virtualmethods::VirtualMethods;
use dom_struct::dom_struct; use dom_struct::dom_struct;
use html5ever::{LocalName, Prefix}; use html5ever::{LocalName, Prefix};
@ -46,6 +50,14 @@ impl HTMLSourceElement {
HTMLSourceElementBinding::Wrap, HTMLSourceElementBinding::Wrap,
) )
} }
fn iterate_next_html_image_element_siblings(next_siblings_iterator: impl Iterator<Item=Root<Dom<Node>>>) {
for next_sibling in next_siblings_iterator {
if let Some(html_image_element_sibling) = next_sibling.downcast::<HTMLImageElement>() {
html_image_element_sibling.update_the_image_data();
}
}
}
} }
impl VirtualMethods for HTMLSourceElement { impl VirtualMethods for HTMLSourceElement {
@ -53,6 +65,18 @@ impl VirtualMethods for HTMLSourceElement {
Some(self.upcast::<HTMLElement>() as &VirtualMethods) Some(self.upcast::<HTMLElement>() as &VirtualMethods)
} }
fn attribute_mutated(&self, attr: &Attr, mutation: AttributeMutation) {
self.super_type().unwrap().attribute_mutated(attr, mutation);
match attr.local_name() {
&local_name!("srcset") | &local_name!("sizes") |
&local_name!("media") | &local_name!("type") => {
let next_sibling_iterator = self.upcast::<Node>().following_siblings();
HTMLSourceElement::iterate_next_html_image_element_siblings(next_sibling_iterator);
},
_ => {},
}
}
/// <https://html.spec.whatwg.org/multipage/#the-source-element:nodes-are-inserted> /// <https://html.spec.whatwg.org/multipage/#the-source-element:nodes-are-inserted>
fn bind_to_tree(&self, tree_in_doc: bool) { fn bind_to_tree(&self, tree_in_doc: bool) {
self.super_type().unwrap().bind_to_tree(tree_in_doc); self.super_type().unwrap().bind_to_tree(tree_in_doc);
@ -60,6 +84,16 @@ impl VirtualMethods for HTMLSourceElement {
if let Some(media) = parent.downcast::<HTMLMediaElement>() { if let Some(media) = parent.downcast::<HTMLMediaElement>() {
media.handle_source_child_insertion(); media.handle_source_child_insertion();
} }
let next_sibling_iterator = self.upcast::<Node>().following_siblings();
HTMLSourceElement::iterate_next_html_image_element_siblings(next_sibling_iterator);
}
fn unbind_from_tree(&self, context: &UnbindContext) {
self.super_type().unwrap().unbind_from_tree(context);
if let Some(next_sibling) = context.next_sibling {
let next_sibling_iterator = next_sibling.inclusively_following_siblings();
HTMLSourceElement::iterate_next_html_image_element_siblings(next_sibling_iterator);
}
} }
} }

View file

@ -293,7 +293,7 @@ impl Node {
}, },
} }
let context = UnbindContext::new(self, prev_sibling.r(), cached_index); let context = UnbindContext::new(self, prev_sibling.r(), next_sibling.r(), cached_index);
child.prev_sibling.set(None); child.prev_sibling.set(None);
child.next_sibling.set(None); child.next_sibling.set(None);
@ -2812,17 +2812,23 @@ pub struct UnbindContext<'a> {
pub parent: &'a Node, pub parent: &'a Node,
/// The previous sibling of the inclusive ancestor that was removed. /// The previous sibling of the inclusive ancestor that was removed.
prev_sibling: Option<&'a Node>, prev_sibling: Option<&'a Node>,
/// The next sibling of the inclusive ancestor that was removed.
pub next_sibling: Option<&'a Node>,
/// Whether the tree is in a document. /// Whether the tree is in a document.
pub tree_in_doc: bool, pub tree_in_doc: bool,
} }
impl<'a> UnbindContext<'a> { impl<'a> UnbindContext<'a> {
/// Create a new `UnbindContext` value. /// Create a new `UnbindContext` value.
fn new(parent: &'a Node, prev_sibling: Option<&'a Node>, cached_index: Option<u32>) -> Self { fn new(parent: &'a Node,
prev_sibling: Option<&'a Node>,
next_sibling: Option<&'a Node>,
cached_index: Option<u32>) -> Self {
UnbindContext { UnbindContext {
index: Cell::new(cached_index), index: Cell::new(cached_index),
parent: parent, parent: parent,
prev_sibling: prev_sibling, prev_sibling: prev_sibling,
next_sibling: next_sibling,
tree_in_doc: parent.is_in_doc(), tree_in_doc: parent.is_in_doc(),
} }
} }

View file

@ -1,14 +1,14 @@
[viewport-change.html] [viewport-change.html]
type: testharness type: testharness
[picture: source (max-width:500px) broken image, img valid image, resize to wide] [picture: source (max-width:500px) broken image, img valid image, resize to wide]
expected: FAIL expected: TIMEOUT
[picture: source (max-width:500px) valid image, img valid image, resize to wide] [picture: source (max-width:500px) valid image, img valid image, resize to wide]
expected: FAIL expected: TIMEOUT
[picture: source (max-width:500px) valid image, img broken image, resize to narrow] [picture: source (max-width:500px) valid image, img broken image, resize to narrow]
expected: FAIL expected: TIMEOUT
[picture: source (max-width:500px) valid image, img valid image, resize to narrow] [picture: source (max-width:500px) valid image, img valid image, resize to narrow]
expected: FAIL expected: TIMEOUT

View file

@ -1,11 +0,0 @@
[non-active-document.html]
type: testharness
[DOMParser]
expected: FAIL
[createHTMLDocument]
expected: FAIL
[<template>]
expected: FAIL

View file

@ -1,103 +1,32 @@
[relevant-mutations.html] [relevant-mutations.html]
type: testharness type: testharness
expected: TIMEOUT [srcset is set to same value]
disabled: unstable failures and timeouts in release builds expected: FAIL
[src removed]
expected: TIMEOUT
[inserted into picture] [ancestor picture; previous sibling source inserted]
expected: TIMEOUT expected: FAIL
[removed from picture] [picture is inserted; img has previous sibling source]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source inserted] [crossorigin state not changed: anonymous to foobar]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source removed] [crossorigin state not changed: empty to anonymous]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source has srcset set] [ancestor picture; previous sibling source removed]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source has srcset changed] [crossorigin state not changed: use-credentials to USE-CREDENTIALS]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source has srcset removed] [picture is inserted; img has following sibling source]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source has sizes set] [picture is inserted; img has srcset]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source has sizes changed] [picture is inserted; img has src]
expected: TIMEOUT expected: FAIL
[parent is picture, previous source has sizes removed]
expected: TIMEOUT
[parent is picture, previous source has media set]
expected: TIMEOUT
[parent is picture, previous source has media changed]
expected: TIMEOUT
[parent is picture, previous source has media removed]
expected: TIMEOUT
[parent is picture, previous source has type set]
expected: TIMEOUT
[parent is picture, previous source has type changed]
expected: TIMEOUT
[parent is picture, previous source has type removed]
expected: TIMEOUT
[srcset set]
expected: TIMEOUT
[srcset changed]
expected: TIMEOUT
[srcset removed]
expected: TIMEOUT
[sizes set]
expected: TIMEOUT
[sizes changed]
expected: TIMEOUT
[sizes removed]
expected: TIMEOUT
[crossorigin absent to empty]
expected: TIMEOUT
[crossorigin absent to anonymous]
expected: TIMEOUT
[crossorigin absent to use-credentials]
expected: TIMEOUT
[crossorigin empty to absent]
expected: TIMEOUT
[crossorigin empty to use-credentials]
expected: TIMEOUT
[crossorigin anonymous to absent]
expected: TIMEOUT
[crossorigin anonymous to use-credentials]
expected: TIMEOUT
[crossorigin use-credentials to absent]
expected: TIMEOUT
[crossorigin use-credentials to empty]
expected: TIMEOUT
[crossorigin use-credentials to anonymous]
expected: TIMEOUT

View file

@ -1,6 +0,0 @@
[update-media.html]
type: testharness
expected: TIMEOUT
[set media after src updates selected image]
expected: TIMEOUT

View file

@ -1,8 +1,7 @@
[texture-upload-size.html] [texture-upload-size.html]
expected: TIMEOUT
[Overall test]
expected: NOTRUN
[WebGL test #20: could not create image (SVG)] [WebGL test #20: could not create image (SVG)]
expected: FAIL expected: FAIL
[WebGL test #36: could not create image (SVG)]
expected: FAIL