diff options
author | Michał Gołębiowski-Owczarek <m.goleb@gmail.com> | 2018-04-23 21:00:14 +0200 |
---|---|---|
committer | Michał Gołębiowski-Owczarek <m.goleb@gmail.com> | 2019-04-08 19:26:08 +0200 |
commit | 00a9c2e5f4c855382435cec6b3908eb9bd5a53b7 (patch) | |
tree | 460e2907e1559eed4619bbdec9fc34f1cc6390b3 /test | |
parent | c4f2fa2fb33d6e52f7c8fad9f687ef970f442179 (diff) | |
download | jquery-00a9c2e5f4c855382435cec6b3908eb9bd5a53b7.tar.gz jquery-00a9c2e5f4c855382435cec6b3908eb9bd5a53b7.zip |
CSS: Don't automatically add "px" to properties with a few exceptions
Fixes gh-2795
Closes gh-4055
Ref gh-4009
Diffstat (limited to 'test')
-rw-r--r-- | test/unit/css.js | 82 |
1 files changed, 80 insertions, 2 deletions
diff --git a/test/unit/css.js b/test/unit/css.js index e7acd1915..20a5a77bc 100644 --- a/test/unit/css.js +++ b/test/unit/css.js @@ -1198,14 +1198,17 @@ if ( jQuery.fn.offset ) { } QUnit.test( "Do not append px (#9548, #12990, #2792)", function( assert ) { - assert.expect( 3 ); + assert.expect( 4 ); var $div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ); $div.css( "fill-opacity", 1 ); - assert.equal( $div.css( "fill-opacity" ), 1, "Do not append px to 'fill-opacity'" ); + $div.css( "font-size", "27px" ); + $div.css( "line-height", 2 ); + assert.equal( $div.css( "line-height" ), "54px", "Do not append px to 'line-height'" ); + $div.css( "column-count", 1 ); if ( $div.css( "column-count" ) !== undefined ) { assert.equal( $div.css( "column-count" ), 1, "Do not append px to 'column-count'" ); @@ -1273,6 +1276,81 @@ QUnit[ } } ); +QUnit.test( "Do not append px to most properties not accepting integer values", function( assert ) { + assert.expect( 3 ); + + var $div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ); + + $div.css( "font-size", "27px" ); + + $div.css( "font-size", 2 ); + assert.equal( $div.css( "font-size" ), "27px", "Do not append px to 'font-size'" ); + + $div.css( "fontSize", 2 ); + assert.equal( $div.css( "fontSize" ), "27px", "Do not append px to 'fontSize'" ); + + $div.css( "letter-spacing", "2px" ); + $div.css( "letter-spacing", 3 ); + assert.equal( $div.css( "letter-spacing" ), "2px", "Do not append px to 'letter-spacing'" ); +} ); + +QUnit.test( "Append px to whitelisted properties", function( assert ) { + var prop, + $div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ), + whitelist = { + margin: "marginTop", + marginTop: undefined, + marginRight: undefined, + marginBottom: undefined, + marginLeft: undefined, + padding: "paddingTop", + paddingTop: undefined, + paddingRight: undefined, + paddingBottom: undefined, + paddingLeft: undefined, + top: undefined, + right: undefined, + bottom: undefined, + left: undefined, + width: undefined, + height: undefined, + minWidth: undefined, + minHeight: undefined, + maxWidth: undefined, + maxHeight: undefined, + border: "borderTopWidth", + borderWidth: "borderTopWidth", + borderTop: "borderTopWidth", + borderTopWidth: undefined, + borderRight: "borderRightWidth", + borderRightWidth: undefined, + borderBottom: "borderBottomWidth", + borderBottomWidth: undefined, + borderLeft: "borderLeftWidth", + borderLeftWidth: undefined + }; + + assert.expect( ( Object.keys( whitelist ).length ) * 2 ); + + for ( prop in whitelist ) { + var propToCheck = whitelist[ prop ] || prop, + kebabProp = prop.replace( /[A-Z]/g, function( match ) { + return "-" + match.toLowerCase(); + } ), + kebabPropToCheck = propToCheck.replace( /[A-Z]/g, function( match ) { + return "-" + match.toLowerCase(); + } ); + $div.css( prop, 3 ) + .css( "position", "absolute" ) + .css( "border-style", "solid" ); + assert.equal( $div.css( propToCheck ), "3px", "Append px to '" + prop + "'" ); + $div.css( kebabProp, 3 ) + .css( "position", "absolute" ) + .css( "border-style", "solid" ); + assert.equal( $div.css( kebabPropToCheck ), "3px", "Append px to '" + kebabProp + "'" ); + } +} ); + QUnit.test( "css('width') and css('height') should respect box-sizing, see #11004", function( assert ) { assert.expect( 4 ); |