mirror of
https://github.com/servo/servo.git
synced 2025-08-04 13:10:20 +01:00
Auto merge of #14930 - zaynetro:remove-stylesheets, r=emilio
Implement support for removing stylesheets from their document <!-- Please describe your changes on the following line: --> This pull request implements removing styles from the document when * `<link>` element with associated styles is removed * `<style>` element is removed Additionally, it tests that when `<style>` element is changed. Styles are being reapplied correctly. --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: --> - [x] `./mach build -d` does not report any errors - [x] `./mach test-tidy` does not report any errors - [x] These changes fix #14886 (github issue number if applicable). <!-- Either: --> - [x] There are tests for these changes <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> <!-- Reviewable:start --> --- This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/servo/servo/14930) <!-- Reviewable:end -->
This commit is contained in:
commit
f3c102d2fe
11 changed files with 180 additions and 24 deletions
|
@ -18,7 +18,7 @@ use dom::element::{AttributeMutation, Element, ElementCreator};
|
||||||
use dom::element::{cors_setting_for_element, reflect_cross_origin_attribute, set_cross_origin_attribute};
|
use dom::element::{cors_setting_for_element, reflect_cross_origin_attribute, set_cross_origin_attribute};
|
||||||
use dom::globalscope::GlobalScope;
|
use dom::globalscope::GlobalScope;
|
||||||
use dom::htmlelement::HTMLElement;
|
use dom::htmlelement::HTMLElement;
|
||||||
use dom::node::{Node, document_from_node, window_from_node};
|
use dom::node::{Node, UnbindContext, document_from_node, window_from_node};
|
||||||
use dom::stylesheet::StyleSheet as DOMStyleSheet;
|
use dom::stylesheet::StyleSheet as DOMStyleSheet;
|
||||||
use dom::virtualmethods::VirtualMethods;
|
use dom::virtualmethods::VirtualMethods;
|
||||||
use html5ever_atoms::LocalName;
|
use html5ever_atoms::LocalName;
|
||||||
|
@ -228,6 +228,15 @@ impl VirtualMethods for HTMLLinkElement {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn unbind_from_tree(&self, context: &UnbindContext) {
|
||||||
|
if let Some(ref s) = self.super_type() {
|
||||||
|
s.unbind_from_tree(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
let document = document_from_node(self);
|
||||||
|
document.invalidate_stylesheets();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ use dom::document::Document;
|
||||||
use dom::element::{Element, ElementCreator};
|
use dom::element::{Element, ElementCreator};
|
||||||
use dom::eventtarget::EventTarget;
|
use dom::eventtarget::EventTarget;
|
||||||
use dom::htmlelement::HTMLElement;
|
use dom::htmlelement::HTMLElement;
|
||||||
use dom::node::{ChildrenMutation, Node, document_from_node, window_from_node};
|
use dom::node::{ChildrenMutation, Node, UnbindContext, document_from_node, window_from_node};
|
||||||
use dom::stylesheet::StyleSheet as DOMStyleSheet;
|
use dom::stylesheet::StyleSheet as DOMStyleSheet;
|
||||||
use dom::virtualmethods::VirtualMethods;
|
use dom::virtualmethods::VirtualMethods;
|
||||||
use html5ever_atoms::LocalName;
|
use html5ever_atoms::LocalName;
|
||||||
|
@ -161,6 +161,15 @@ impl VirtualMethods for HTMLStyleElement {
|
||||||
self.parse_own_css();
|
self.parse_own_css();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn unbind_from_tree(&self, context: &UnbindContext) {
|
||||||
|
if let Some(ref s) = self.super_type() {
|
||||||
|
s.unbind_from_tree(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
let doc = document_from_node(self);
|
||||||
|
doc.invalidate_stylesheets();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl StylesheetOwner for HTMLStyleElement {
|
impl StylesheetOwner for HTMLStyleElement {
|
||||||
|
|
|
@ -3,25 +3,3 @@
|
||||||
expected: OK
|
expected: OK
|
||||||
[Style: Same-origin with correct sha256 and sha512 hash, rel='alternate stylesheet' enabled]
|
[Style: Same-origin with correct sha256 and sha512 hash, rel='alternate stylesheet' enabled]
|
||||||
expected: FAIL
|
expected: FAIL
|
||||||
|
|
||||||
[Style: Same-origin with incorrect hash.]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[Style: Same-origin with sha256 match, sha512 mismatch]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[Style: <crossorigin='anonymous'> with CORS-ineligible resource]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[Style: Cross-origin, not CORS request, with correct hash]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[Style: Cross-origin, not CORS request, with hash mismatch]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[Style: <crossorigin='use-credentials'> with incorrect hash CORS-eligible]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[Style: <crossorigin='anonymous'> with incorrect hash, ACAO: *]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
|
|
|
@ -6474,6 +6474,42 @@
|
||||||
"url": "/_mozilla/mozilla/iframe/resize_after_load.html"
|
"url": "/_mozilla/mozilla/iframe/resize_after_load.html"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"mozilla/remove_link_styles.html": [
|
||||||
|
{
|
||||||
|
"path": "mozilla/remove_link_styles.html",
|
||||||
|
"references": [
|
||||||
|
[
|
||||||
|
"/_mozilla/mozilla/remove_link_styles_ref.html",
|
||||||
|
"=="
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"url": "/_mozilla/mozilla/remove_link_styles.html"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"mozilla/remove_style_styles.html": [
|
||||||
|
{
|
||||||
|
"path": "mozilla/remove_style_styles.html",
|
||||||
|
"references": [
|
||||||
|
[
|
||||||
|
"/_mozilla/mozilla/remove_style_styles_ref.html",
|
||||||
|
"=="
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"url": "/_mozilla/mozilla/remove_style_styles.html"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"mozilla/reparse_style_elements.html": [
|
||||||
|
{
|
||||||
|
"path": "mozilla/reparse_style_elements.html",
|
||||||
|
"references": [
|
||||||
|
[
|
||||||
|
"/_mozilla/mozilla/reparse_style_elements_ref.html",
|
||||||
|
"=="
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"url": "/_mozilla/mozilla/reparse_style_elements.html"
|
||||||
|
}
|
||||||
|
],
|
||||||
"mozilla/restyle-out-of-document.html": [
|
"mozilla/restyle-out-of-document.html": [
|
||||||
{
|
{
|
||||||
"path": "mozilla/restyle-out-of-document.html",
|
"path": "mozilla/restyle-out-of-document.html",
|
||||||
|
@ -21876,6 +21912,42 @@
|
||||||
"url": "/_mozilla/mozilla/iframe/resize_after_load.html"
|
"url": "/_mozilla/mozilla/iframe/resize_after_load.html"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"mozilla/remove_link_styles.html": [
|
||||||
|
{
|
||||||
|
"path": "mozilla/remove_link_styles.html",
|
||||||
|
"references": [
|
||||||
|
[
|
||||||
|
"/_mozilla/mozilla/remove_link_styles_ref.html",
|
||||||
|
"=="
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"url": "/_mozilla/mozilla/remove_link_styles.html"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"mozilla/remove_style_styles.html": [
|
||||||
|
{
|
||||||
|
"path": "mozilla/remove_style_styles.html",
|
||||||
|
"references": [
|
||||||
|
[
|
||||||
|
"/_mozilla/mozilla/remove_style_styles_ref.html",
|
||||||
|
"=="
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"url": "/_mozilla/mozilla/remove_style_styles.html"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"mozilla/reparse_style_elements.html": [
|
||||||
|
{
|
||||||
|
"path": "mozilla/reparse_style_elements.html",
|
||||||
|
"references": [
|
||||||
|
[
|
||||||
|
"/_mozilla/mozilla/reparse_style_elements_ref.html",
|
||||||
|
"=="
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"url": "/_mozilla/mozilla/reparse_style_elements.html"
|
||||||
|
}
|
||||||
|
],
|
||||||
"mozilla/restyle-out-of-document.html": [
|
"mozilla/restyle-out-of-document.html": [
|
||||||
{
|
{
|
||||||
"path": "mozilla/restyle-out-of-document.html",
|
"path": "mozilla/restyle-out-of-document.html",
|
||||||
|
|
4
tests/wpt/mozilla/tests/mozilla/remove_link_styles.css
Normal file
4
tests/wpt/mozilla/tests/mozilla/remove_link_styles.css
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
body {
|
||||||
|
background-color: red;
|
||||||
|
color: white !important;
|
||||||
|
}
|
19
tests/wpt/mozilla/tests/mozilla/remove_link_styles.html
Normal file
19
tests/wpt/mozilla/tests/mozilla/remove_link_styles.html
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
<!doctype html>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<title>Removing link tag should remove associated styles</title>
|
||||||
|
<link rel="stylesheet" type="text/css" href="remove_link_styles.css">
|
||||||
|
<link rel="match" href="remove_link_styles_ref.html">
|
||||||
|
<body>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
color: green;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
This text should be green and the background should not be red.
|
||||||
|
|
||||||
|
<script>
|
||||||
|
var l = document.querySelector('link[rel="stylesheet"]');
|
||||||
|
l.parentNode.removeChild(l);
|
||||||
|
</script>
|
||||||
|
</body>
|
11
tests/wpt/mozilla/tests/mozilla/remove_link_styles_ref.html
Normal file
11
tests/wpt/mozilla/tests/mozilla/remove_link_styles_ref.html
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
<!doctype html>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<body>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
color: green;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
This text should be green and the background should not be red.
|
||||||
|
</body>
|
20
tests/wpt/mozilla/tests/mozilla/remove_style_styles.html
Normal file
20
tests/wpt/mozilla/tests/mozilla/remove_style_styles.html
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<!doctype html>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<title>Removing style element should remove all associated styles</title>
|
||||||
|
<link rel="match" href="remove_style_styles_ref.html">
|
||||||
|
<body>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: red;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
This text should be black and the background should not be red.
|
||||||
|
|
||||||
|
<script>
|
||||||
|
// Force restyling
|
||||||
|
window.getComputedStyle(document.body);
|
||||||
|
var s = document.querySelector('style');
|
||||||
|
s.parentNode.removeChild(s);
|
||||||
|
</script>
|
||||||
|
</body>
|
|
@ -0,0 +1,5 @@
|
||||||
|
<!doctype html>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<body>
|
||||||
|
This text should be black and the background should not be red.
|
||||||
|
</body>
|
18
tests/wpt/mozilla/tests/mozilla/reparse_style_elements.html
Normal file
18
tests/wpt/mozilla/tests/mozilla/reparse_style_elements.html
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
<!doctype html>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<title>Style elements should be reparsed on change</title>
|
||||||
|
<link rel="match" href="reparse_style_elements_ref.html">
|
||||||
|
<body>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: red;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
This text should be green and the background should not be red.
|
||||||
|
|
||||||
|
<script>
|
||||||
|
var s = document.querySelector('body > style');
|
||||||
|
s.textContent = 'body { color: green; }';
|
||||||
|
</script>
|
||||||
|
</body>
|
|
@ -0,0 +1,11 @@
|
||||||
|
<!doctype html>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<body>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
color: green;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
This text should be green and the background should not be red.
|
||||||
|
</body>
|
Loading…
Add table
Add a link
Reference in a new issue