Reviewed by @emilio in [bug 1329088](https://bugzilla.mozilla.org/show_bug.cgi?id=1329088). r? @emilio --- - [x] `./mach build -d` does not report any errors - [x] `./mach test-tidy` does not report any errors Source-Repo: https://github.com/servo/servo Source-Revision: 5c56640508b4f24a67fe92c5d3179d89d030e959
146 lines
6.8 KiB
Rust
146 lines
6.8 KiB
Rust
/* 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 parsing::parse;
|
|
use style::properties::longhands::{mask_clip, mask_composite, mask_image, mask_mode};
|
|
use style::properties::longhands::{mask_origin, mask_position_x, mask_position_y, mask_repeat, mask_size};
|
|
use style::properties::shorthands::mask;
|
|
|
|
#[test]
|
|
fn mask_shorthand_should_parse_all_available_properties_when_specified() {
|
|
let input = "url(\"http://servo/test.png\") luminance 7px 4px / 70px 50px repeat-x padding-box border-box subtract";
|
|
let result = parse(mask::parse_value, input).unwrap();
|
|
|
|
assert_eq!(result.mask_image, parse_longhand!(mask_image, "url(\"http://servo/test.png\")"));
|
|
assert_eq!(result.mask_mode, parse_longhand!(mask_mode, "luminance"));
|
|
assert_eq!(result.mask_position_x, parse_longhand!(mask_position_x, "7px"));
|
|
assert_eq!(result.mask_position_y, parse_longhand!(mask_position_y, "4px"));
|
|
assert_eq!(result.mask_size, parse_longhand!(mask_size, "70px 50px"));
|
|
assert_eq!(result.mask_repeat, parse_longhand!(mask_repeat, "repeat-x"));
|
|
assert_eq!(result.mask_origin, parse_longhand!(mask_origin, "padding-box"));
|
|
assert_eq!(result.mask_clip, parse_longhand!(mask_clip, "border-box"));
|
|
assert_eq!(result.mask_composite, parse_longhand!(mask_composite, "subtract"));
|
|
}
|
|
|
|
#[test]
|
|
fn mask_shorthand_should_parse_when_some_fields_set() {
|
|
let result = parse(mask::parse_value, "14px 40px repeat-y").unwrap();
|
|
|
|
assert_eq!(result.mask_position_x, parse_longhand!(mask_position_x, "14px"));
|
|
assert_eq!(result.mask_position_y, parse_longhand!(mask_position_y, "40px"));
|
|
assert_eq!(result.mask_repeat, parse_longhand!(mask_repeat, "repeat-y"));
|
|
|
|
let result = parse(mask::parse_value, "url(\"http://servo/test.png\") repeat add").unwrap();
|
|
|
|
assert_eq!(result.mask_image, parse_longhand!(mask_image, "url(\"http://servo/test.png\")"));
|
|
assert_eq!(result.mask_repeat, parse_longhand!(mask_repeat, "repeat"));
|
|
assert_eq!(result.mask_composite, parse_longhand!(mask_composite, "add"));
|
|
|
|
let result = parse(mask::parse_value, "intersect").unwrap();
|
|
|
|
assert_eq!(result.mask_composite, parse_longhand!(mask_composite, "intersect"));
|
|
|
|
let result = parse(mask::parse_value, "url(\"http://servo/test.png\")").unwrap();
|
|
|
|
assert_eq!(result.mask_image, parse_longhand!(mask_image, "url(\"http://servo/test.png\")"));
|
|
}
|
|
|
|
#[test]
|
|
fn mask_shorthand_should_parse_position_and_size_correctly() {
|
|
let result = parse(mask::parse_value, "7px 4px").unwrap();
|
|
|
|
assert_eq!(result.mask_position_x, parse_longhand!(mask_position_x, "7px"));
|
|
assert_eq!(result.mask_position_y, parse_longhand!(mask_position_y, "4px"));
|
|
|
|
let result = parse(mask::parse_value, "7px 4px / 30px 20px").unwrap();
|
|
|
|
assert_eq!(result.mask_position_x, parse_longhand!(mask_position_x, "7px"));
|
|
assert_eq!(result.mask_position_y, parse_longhand!(mask_position_y, "4px"));
|
|
assert_eq!(result.mask_size, parse_longhand!(mask_size, "30px 20px"));
|
|
|
|
assert!(parse(mask::parse_value, "/ 30px 20px").is_err());
|
|
|
|
assert!(parse(mask::parse_value, "match-source repeat-x / 30px 20px").is_err());
|
|
}
|
|
|
|
#[test]
|
|
fn mask_shorthand_should_parse_origin_and_clip_correctly() {
|
|
let result = parse(mask::parse_value, "padding-box content-box").unwrap();
|
|
|
|
assert_eq!(result.mask_origin, parse_longhand!(mask_origin, "padding-box"));
|
|
assert_eq!(result.mask_clip, parse_longhand!(mask_clip, "content-box"));
|
|
|
|
let result = parse(mask::parse_value, "padding-box padding-box").unwrap();
|
|
|
|
assert_eq!(result.mask_origin, parse_longhand!(mask_origin, "padding-box"));
|
|
assert_eq!(result.mask_clip, parse_longhand!(mask_clip, "padding-box"));
|
|
|
|
let result = parse(mask::parse_value, "padding-box").unwrap();
|
|
|
|
assert_eq!(result.mask_origin, parse_longhand!(mask_origin, "padding-box"));
|
|
assert_eq!(result.mask_clip, parse_longhand!(mask_clip, "padding-box"));
|
|
}
|
|
|
|
#[test]
|
|
fn mask_shorthand_should_parse_mode_everywhere() {
|
|
assert!(parse(mask::parse_value, "luminance 7px 4px repeat-x padding-box").is_ok());
|
|
assert!(parse(mask::parse_value, "alpha").is_ok());
|
|
}
|
|
|
|
#[test]
|
|
fn mask_repeat_should_parse_shorthand_correctly() {
|
|
use style::properties::longhands::mask_repeat::single_value::{RepeatKeyword, SpecifiedValue};
|
|
|
|
let repeat_x = parse_longhand!(mask_repeat, "repeat-x");
|
|
assert_eq!(repeat_x, mask_repeat::SpecifiedValue(vec![SpecifiedValue::RepeatX]));
|
|
|
|
let repeat_y = parse_longhand!(mask_repeat, "repeat-y");
|
|
assert_eq!(repeat_y, mask_repeat::SpecifiedValue(vec![SpecifiedValue::RepeatY]));
|
|
|
|
let repeat = parse_longhand!(mask_repeat, "repeat");
|
|
assert_eq!(repeat,
|
|
mask_repeat::SpecifiedValue(vec![SpecifiedValue::Other(RepeatKeyword::Repeat, None)]));
|
|
|
|
let space = parse_longhand!(mask_repeat, "space");
|
|
assert_eq!(space,
|
|
mask_repeat::SpecifiedValue(vec![SpecifiedValue::Other(RepeatKeyword::Space, None)]));
|
|
|
|
let round = parse_longhand!(mask_repeat, "round");
|
|
assert_eq!(round,
|
|
mask_repeat::SpecifiedValue(vec![SpecifiedValue::Other(RepeatKeyword::Round, None)]));
|
|
|
|
let no_repeat = parse_longhand!(mask_repeat, "no-repeat");
|
|
assert_eq!(no_repeat,
|
|
mask_repeat::SpecifiedValue(vec![SpecifiedValue::Other(RepeatKeyword::NoRepeat, None)]));
|
|
}
|
|
|
|
#[test]
|
|
fn mask_repeat_should_parse_longhand_correctly() {
|
|
use style::properties::longhands::mask_repeat::single_value::{RepeatKeyword, SpecifiedValue};
|
|
|
|
// repeat-x is not available in longhand form.
|
|
assert!(parse(mask_repeat::parse, "repeat-x no-repeat").is_err());
|
|
assert!(parse(mask_repeat::parse, "no-repeat repeat-x").is_err());
|
|
|
|
// repeat-y is not available in longhand form.
|
|
assert!(parse(mask_repeat::parse, "repeat-y no-repeat").is_err());
|
|
assert!(parse(mask_repeat::parse, "no-repeat repeat-y").is_err());
|
|
|
|
// Longhand form supports two directions.
|
|
let no_repeat_and_round = parse_longhand!(mask_repeat, "no-repeat round");
|
|
assert_eq!(no_repeat_and_round,
|
|
mask_repeat::SpecifiedValue(vec![SpecifiedValue::Other(RepeatKeyword::NoRepeat,
|
|
Some(RepeatKeyword::Round))]));
|
|
|
|
// Not three directions.
|
|
assert!(parse(mask_repeat::parse, "repeat no-repeat round").is_err());
|
|
|
|
// Multiple values with mixed shortform and longform should parse.
|
|
let multiple = parse_longhand!(mask_repeat, "repeat, no-repeat round");
|
|
assert_eq!(multiple,
|
|
mask_repeat::SpecifiedValue(vec![SpecifiedValue::Other(RepeatKeyword::Repeat, None),
|
|
SpecifiedValue::Other(RepeatKeyword::NoRepeat,
|
|
Some(RepeatKeyword::Round))]));
|
|
}
|