aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEmilio Cobos Álvarez <emilio@crisal.io>2018-07-01 00:40:32 +0200
committerEmilio Cobos Álvarez <emilio@crisal.io>2018-07-01 00:54:30 +0200
commite149059608f35b1b371e20decff84b98d698ea1d (patch)
tree75fed1ec2ad62df28a7c41d504ab33cd38e6c664
parentfc5dbc1baebd15ab9f28916440d541dda7cb4222 (diff)
downloadservo-e149059608f35b1b371e20decff84b98d698ea1d.tar.gz
servo-e149059608f35b1b371e20decff84b98d698ea1d.zip
style: Fix build / unit tests.
-rw-r--r--components/style/servo/media_queries.rs2
-rw-r--r--tests/unit/style/Cargo.toml2
-rw-r--r--tests/unit/style/lib.rs14
-rw-r--r--tests/unit/style/media_queries.rs398
4 files changed, 2 insertions, 414 deletions
diff --git a/components/style/servo/media_queries.rs b/components/style/servo/media_queries.rs
index 3a8235aa65c..ba31cfcaf4b 100644
--- a/components/style/servo/media_queries.rs
+++ b/components/style/servo/media_queries.rs
@@ -216,7 +216,7 @@ impl MediaFeatureExpression {
"width" => {
ExpressionKind::Width(Range::Eq(specified::Length::parse_non_negative(context, input)?))
},
- _ => return Err(input.new_custom_error(SelectorParseErrorKind::UnexpectedIdent(name)))
+ _ => return Err(input.new_custom_error(SelectorParseErrorKind::UnexpectedIdent(name.clone())))
}))
}
diff --git a/tests/unit/style/Cargo.toml b/tests/unit/style/Cargo.toml
index 23778c73f93..77b0ac34fd1 100644
--- a/tests/unit/style/Cargo.toml
+++ b/tests/unit/style/Cargo.toml
@@ -12,7 +12,7 @@ doctest = false
[dependencies]
byteorder = "1.0"
app_units = "0.6"
-cssparser = "0.23.0"
+cssparser = "0.24.0"
euclid = "0.17"
html5ever = "0.22"
parking_lot = "0.5"
diff --git a/tests/unit/style/lib.rs b/tests/unit/style/lib.rs
index 2c46bb65063..faa15845195 100644
--- a/tests/unit/style/lib.rs
+++ b/tests/unit/style/lib.rs
@@ -27,7 +27,6 @@ mod attr;
mod custom_properties;
mod keyframes;
mod logical_geometry;
-mod media_queries;
mod parsing;
mod properties;
mod rule_tree;
@@ -37,16 +36,3 @@ mod str;
mod stylesheets;
mod stylist;
mod viewport;
-
-mod writing_modes {
- use style::logical_geometry::WritingMode;
- use style::properties::INITIAL_SERVO_VALUES;
-
- #[test]
- fn initial_writing_mode_is_empty() {
- assert_eq!(
- WritingMode::new(INITIAL_SERVO_VALUES.get_inherited_box()),
- WritingMode::empty(),
- )
- }
-}
diff --git a/tests/unit/style/media_queries.rs b/tests/unit/style/media_queries.rs
deleted file mode 100644
index 044dee3db72..00000000000
--- a/tests/unit/style/media_queries.rs
+++ /dev/null
@@ -1,398 +0,0 @@
-/* This Source Code Form is subject to the terms of the Mozilla Public
- * 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/. */
-
-use euclid::TypedScale;
-use euclid::TypedSize2D;
-use servo_arc::Arc;
-use servo_url::ServoUrl;
-use std::borrow::ToOwned;
-use style::Atom;
-use style::context::QuirksMode;
-use style::media_queries::*;
-use style::servo::media_queries::*;
-use style::shared_lock::SharedRwLock;
-use style::stylesheets::{AllRules, Stylesheet, StylesheetInDocument, Origin, CssRule};
-use style::values::{CustomIdent, specified};
-use style_traits::ToCss;
-
-fn test_media_rule<F>(css: &str, callback: F)
-where
- F: Fn(&MediaList, &str),
-{
- let url = ServoUrl::parse("http://localhost").unwrap();
- let css_str = css.to_owned();
- let lock = SharedRwLock::new();
- let media_list = Arc::new(lock.wrap(MediaList::empty()));
- let stylesheet = Stylesheet::from_str(
- css, url, Origin::Author, media_list, lock,
- None, None, QuirksMode::NoQuirks, 0);
- let dummy = Device::new(MediaType::screen(), TypedSize2D::new(200.0, 100.0), TypedScale::new(1.0));
- let mut rule_count = 0;
- let guard = stylesheet.shared_lock.read();
- for rule in stylesheet.iter_rules::<AllRules>(&dummy, &guard) {
- if let CssRule::Media(ref lock) = *rule {
- rule_count += 1;
- callback(&lock.read_with(&guard).media_queries.read_with(&guard), css);
- }
- }
- assert!(rule_count > 0, css_str);
-}
-
-fn media_query_test(device: &Device, css: &str, expected_rule_count: usize) {
- let url = ServoUrl::parse("http://localhost").unwrap();
- let lock = SharedRwLock::new();
- let media_list = Arc::new(lock.wrap(MediaList::empty()));
- let ss = Stylesheet::from_str(
- css, url, Origin::Author, media_list, lock,
- None, None, QuirksMode::NoQuirks, 0);
- let mut rule_count = 0;
- ss.effective_style_rules(device, &ss.shared_lock.read(), |_| rule_count += 1);
- assert!(rule_count == expected_rule_count, css.to_owned());
-}
-
-#[test]
-fn test_mq_empty() {
- test_media_rule("@media { }", |list, css| {
- assert!(list.media_queries.len() == 0, css.to_owned());
- });
-}
-
-#[test]
-fn test_mq_screen() {
- test_media_rule("@media screen { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::screen()), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media only screen { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Only), css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::screen()), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media not screen { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Not), css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::screen()), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-}
-
-#[test]
-fn test_mq_print() {
- test_media_rule("@media print { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::print()), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media only print { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Only), css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::print()), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media not print { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Not), css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::print()), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-}
-
-#[test]
-fn test_mq_unknown() {
- test_media_rule("@media fridge { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(
- MediaType(CustomIdent(Atom::from("fridge")))), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media only glass { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Only), css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(
- MediaType(CustomIdent(Atom::from("glass")))), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media not wood { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Not), css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(
- MediaType(CustomIdent(Atom::from("wood")))), css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-}
-
-#[test]
-fn test_mq_all() {
- test_media_rule("@media all { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::All, css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media only all { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Only), css.to_owned());
- assert!(q.media_type == MediaQueryType::All, css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-
- test_media_rule("@media not all { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Not), css.to_owned());
- assert!(q.media_type == MediaQueryType::All, css.to_owned());
- assert!(q.expressions.len() == 0, css.to_owned());
- });
-}
-
-#[test]
-fn test_mq_or() {
- test_media_rule("@media screen, print { }", |list, css| {
- assert!(list.media_queries.len() == 2, css.to_owned());
- let q0 = &list.media_queries[0];
- assert!(q0.qualifier == None, css.to_owned());
- assert!(q0.media_type == MediaQueryType::Concrete(MediaType::screen()), css.to_owned());
- assert!(q0.expressions.len() == 0, css.to_owned());
-
- let q1 = &list.media_queries[1];
- assert!(q1.qualifier == None, css.to_owned());
- assert!(q1.media_type == MediaQueryType::Concrete(MediaType::print()), css.to_owned());
- assert!(q1.expressions.len() == 0, css.to_owned());
- });
-}
-
-#[test]
-fn test_mq_default_expressions() {
- test_media_rule("@media (min-width: 100px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::All, css.to_owned());
- assert!(q.expressions.len() == 1, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Min(ref w)) => assert!(*w == specified::Length::from_px(100.)),
- _ => panic!("wrong expression type"),
- }
- });
-
- test_media_rule("@media (max-width: 43px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::All, css.to_owned());
- assert!(q.expressions.len() == 1, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Max(ref w)) => assert!(*w == specified::Length::from_px(43.)),
- _ => panic!("wrong expression type"),
- }
- });
-}
-
-#[test]
-fn test_mq_expressions() {
- test_media_rule("@media screen and (min-width: 100px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::screen()), css.to_owned());
- assert!(q.expressions.len() == 1, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Min(ref w)) => assert!(*w == specified::Length::from_px(100.)),
- _ => panic!("wrong expression type"),
- }
- });
-
- test_media_rule("@media print and (max-width: 43px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::print()), css.to_owned());
- assert!(q.expressions.len() == 1, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Max(ref w)) => assert!(*w == specified::Length::from_px(43.)),
- _ => panic!("wrong expression type"),
- }
- });
-
- test_media_rule("@media print and (width: 43px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::print()), css.to_owned());
- assert!(q.expressions.len() == 1, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Eq(ref w)) => assert!(*w == specified::Length::from_px(43.)),
- _ => panic!("wrong expression type"),
- }
- });
-
- test_media_rule("@media fridge and (max-width: 52px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(
- MediaType(CustomIdent(Atom::from("fridge")))), css.to_owned());
- assert!(q.expressions.len() == 1, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Max(ref w)) => assert!(*w == specified::Length::from_px(52.)),
- _ => panic!("wrong expression type"),
- }
- });
-}
-
-#[test]
-fn test_to_css() {
- test_media_rule("@media print and (width: 43px) { }", |list, _| {
- let q = &list.media_queries[0];
- let dest = q.to_css_string();
- assert_eq!(dest, "print and (width: 43px)");
- });
-}
-
-#[test]
-fn test_mq_multiple_expressions() {
- test_media_rule("@media (min-width: 100px) and (max-width: 200px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == None, css.to_owned());
- assert!(q.media_type == MediaQueryType::All, css.to_owned());
- assert!(q.expressions.len() == 2, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Min(ref w)) => assert!(*w == specified::Length::from_px(100.)),
- _ => panic!("wrong expression type"),
- }
- match *q.expressions[1].kind_for_testing() {
- ExpressionKind::Width(Range::Max(ref w)) => assert!(*w == specified::Length::from_px(200.)),
- _ => panic!("wrong expression type"),
- }
- });
-
- test_media_rule("@media not screen and (min-width: 100px) and (max-width: 200px) { }", |list, css| {
- assert!(list.media_queries.len() == 1, css.to_owned());
- let q = &list.media_queries[0];
- assert!(q.qualifier == Some(Qualifier::Not), css.to_owned());
- assert!(q.media_type == MediaQueryType::Concrete(MediaType::screen()), css.to_owned());
- assert!(q.expressions.len() == 2, css.to_owned());
- match *q.expressions[0].kind_for_testing() {
- ExpressionKind::Width(Range::Min(ref w)) => assert!(*w == specified::Length::from_px(100.)),
- _ => panic!("wrong expression type"),
- }
- match *q.expressions[1].kind_for_testing() {
- ExpressionKind::Width(Range::Max(ref w)) => assert!(*w == specified::Length::from_px(200.)),
- _ => panic!("wrong expression type"),
- }
- });
-}
-
-#[test]
-fn test_mq_malformed_expressions() {
- fn check_malformed_expr(list: &MediaList, css: &str) {
- assert!(!list.media_queries.is_empty(), css.to_owned());
- for mq in &list.media_queries {
- assert!(mq.qualifier == Some(Qualifier::Not), css.to_owned());
- assert!(mq.media_type == MediaQueryType::All, css.to_owned());
- assert!(mq.expressions.is_empty(), css.to_owned());
- }
- }
-
- for rule in &[
- "@media (min-width: 100blah) and (max-width: 200px) { }",
- "@media screen and (height: 200px) { }",
- "@media (min-width: 30em foo bar) {}",
- "@media not {}",
- "@media not (min-width: 300px) {}",
- "@media , {}",
- ] {
- test_media_rule(rule, check_malformed_expr);
- }
-}
-
-#[test]
-fn test_matching_simple() {
- let device = Device::new(MediaType::screen(), TypedSize2D::new(200.0, 100.0), TypedScale::new(1.0));
-
- media_query_test(&device, "@media not all { a { color: red; } }", 0);
- media_query_test(&device, "@media not screen { a { color: red; } }", 0);
- media_query_test(&device, "@media not print { a { color: red; } }", 1);
-
- media_query_test(&device, "@media unknown { a { color: red; } }", 0);
- media_query_test(&device, "@media not unknown { a { color: red; } }", 1);
-
- media_query_test(&device, "@media { a { color: red; } }", 1);
- media_query_test(&device, "@media screen { a { color: red; } }", 1);
- media_query_test(&device, "@media print { a { color: red; } }", 0);
-}
-
-#[test]
-fn test_matching_width() {
- let device = Device::new(MediaType::screen(), TypedSize2D::new(200.0, 100.0), TypedScale::new(1.0));
-
- media_query_test(&device, "@media { a { color: red; } }", 1);
-
- media_query_test(&device, "@media (min-width: 50px) { a { color: red; } }", 1);
- media_query_test(&device, "@media (min-width: 150px) { a { color: red; } }", 1);
- media_query_test(&device, "@media (min-width: 300px) { a { color: red; } }", 0);
-
- media_query_test(&device, "@media screen and (min-width: 50px) { a { color: red; } }", 1);
- media_query_test(&device, "@media screen and (min-width: 150px) { a { color: red; } }", 1);
- media_query_test(&device, "@media screen and (min-width: 300px) { a { color: red; } }", 0);
-
- media_query_test(&device, "@media not screen and (min-width: 50px) { a { color: red; } }", 0);
- media_query_test(&device, "@media not screen and (min-width: 150px) { a { color: red; } }", 0);
- media_query_test(&device, "@media not screen and (min-width: 300px) { a { color: red; } }", 1);
-
- media_query_test(&device, "@media (max-width: 50px) { a { color: red; } }", 0);
- media_query_test(&device, "@media (max-width: 150px) { a { color: red; } }", 0);
- media_query_test(&device, "@media (max-width: 300px) { a { color: red; } }", 1);
-
- media_query_test(&device, "@media screen and (min-width: 50px) and (max-width: 100px) { a { color: red; } }", 0);
- media_query_test(&device, "@media screen and (min-width: 250px) and (max-width: 300px) { a { color: red; } }", 0);
- media_query_test(&device, "@media screen and (min-width: 50px) and (max-width: 250px) { a { color: red; } }", 1);
-
- media_query_test(
- &device, "@media not screen and (min-width: 50px) and (max-width: 100px) { a { color: red; } }", 1);
- media_query_test(
- &device, "@media not screen and (min-width: 250px) and (max-width: 300px) { a { color: red; } }", 1);
- media_query_test(
- &device, "@media not screen and (min-width: 50px) and (max-width: 250px) { a { color: red; } }", 0);
-
- media_query_test(
- &device, "@media not screen and (min-width: 3.1em) and (max-width: 6em) { a { color: red; } }", 1);
- media_query_test(
- &device, "@media not screen and (min-width: 16em) and (max-width: 19.75em) { a { color: red; } }", 1);
- media_query_test(
- &device, "@media not screen and (min-width: 3em) and (max-width: 250px) { a { color: red; } }", 0);
-}
-
-#[test]
-fn test_matching_invalid() {
- let device = Device::new(MediaType::screen(), TypedSize2D::new(200.0, 100.0), TypedScale::new(1.0));
-
- media_query_test(&device, "@media fridge { a { color: red; } }", 0);
- media_query_test(&device, "@media screen and (height: 100px) { a { color: red; } }", 0);
- media_query_test(&device, "@media not print and (width: 100) { a { color: red; } }", 0);
-}