aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTetsuharu OHZEKI <saneyuki.snyk@gmail.com>2014-03-15 17:31:11 +0900
committerTetsuharu OHZEKI <saneyuki.snyk@gmail.com>2014-03-15 23:21:33 +0900
commit6ecb9ba4b6f801020e3f33556e81deaa90bfa555 (patch)
tree2041c9d26d48a78735748502cf5e1446777435ae /src
parentbfb849bb046f8ca8117b38b0a98704b2c6a6c40d (diff)
downloadservo-6ecb9ba4b6f801020e3f33556e81deaa90bfa555.tar.gz
servo-6ecb9ba4b6f801020e3f33556e81deaa90bfa555.zip
Don't call bind_to_tree when appending a node to another node that isn't in the tree (fixes #1874).
Diffstat (limited to 'src')
-rw-r--r--src/components/script/dom/node.rs10
-rw-r--r--src/test/content/test_document_getElementById.html19
2 files changed, 21 insertions, 8 deletions
diff --git a/src/components/script/dom/node.rs b/src/components/script/dom/node.rs
index 000a19be847..21732c479bb 100644
--- a/src/components/script/dom/node.rs
+++ b/src/components/script/dom/node.rs
@@ -405,10 +405,12 @@ impl NodeHelpers for JS<Node> {
assert!(self.parent_node().is_some());
let document = document_from_node(self);
- for node in self.traverse_preorder() {
- if node.is_element() {
- let element: JS<Element> = ElementCast::to(&node);
- element.bind_to_tree_impl();
+ if self.is_in_doc() {
+ for node in self.traverse_preorder() {
+ if node.is_element() {
+ let element: JS<Element> = ElementCast::to(&node);
+ element.bind_to_tree_impl();
+ }
}
}
diff --git a/src/test/content/test_document_getElementById.html b/src/test/content/test_document_getElementById.html
index 92040c8f257..9d066137ef3 100644
--- a/src/test/content/test_document_getElementById.html
+++ b/src/test/content/test_document_getElementById.html
@@ -66,21 +66,32 @@
is(e2, null, "test3-2, the method should return null when the passed id is none in document.");
}
+ // test 4
{
// Ensure that the id attribute only affects elements present in a document
let e = document.createElement('div');
e.id = "should-not-exist";
- is(document.getElementById("should-not-exist"), null);
+ is(document.getElementById("should-not-exist"), null, "test 4-0");
document.body.appendChild(e);
- is(document.getElementById("should-not-exist"), e);
+ is(document.getElementById("should-not-exist"), e, "test 4-1");
}
// TODO:
- // test4: "in tree order, within the context object's tree"
+ // test5: "in tree order, within the context object's tree"
// http://dom.spec.whatwg.org/#dom-document-getelementbyid.
// TODO:
- // test5: innerHTML
+ // test6: innerHTML
+
+ // test 7
+ {
+ // Test that we only cache elements by ID if they're in a document (see #1874).
+ let s = document.createElement("div");
+ s.setAttribute("id", "x");
+ document.createElement("div").appendChild(s);
+ is(document.getElementById("x"), null, "test 7-0");
+ }
+
finish();
</script>
</body>