aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorMichał Gołębiowski <m.goleb@gmail.com>2014-03-10 00:59:14 +0100
committerMichał Gołębiowski <m.goleb@gmail.com>2014-03-10 19:14:44 +0100
commit2c180ef938201f1213b5c43c8212856d0282e1f0 (patch)
treee496942a345b13787031650ad6a68240cdb07f9e /test
parentb19d4d3450c385b7074035b17f3ba8d0b86cf0b0 (diff)
downloadjquery-2c180ef938201f1213b5c43c8212856d0282e1f0.tar.gz
jquery-2c180ef938201f1213b5c43c8212856d0282e1f0.zip
Css: Revert 24e587929f62428e1959b10aace6dc4fd65ab397
The workaround to be able to change !important styles broke the browser keeping the old CSS value if the new one was rejected. Patching it would involve a significant perf hit (~33%) so the initial patch needs to be reverted instead. Tests by m_gol & gibson042. Fixes #14836 Closes gh-1532
Diffstat (limited to 'test')
-rw-r--r--test/unit/css.js27
1 files changed, 20 insertions, 7 deletions
diff --git a/test/unit/css.js b/test/unit/css.js
index 09839f185..a65bf1dbe 100644
--- a/test/unit/css.js
+++ b/test/unit/css.js
@@ -204,7 +204,7 @@ test( "css() explicit and relative values", 29, function() {
});
test("css(String, Object)", function() {
- expect( 19 );
+ expect( 20 );
var j, div, display, ret, success;
jQuery("#nothiddendiv").css("top", "-1em");
@@ -239,15 +239,18 @@ test("css(String, Object)", function() {
equal( ret, div, "Make sure setting undefined returns the original set." );
equal( div.css("display"), display, "Make sure that the display wasn't changed." );
- // Test for Bug #5509
success = true;
try {
- jQuery("#foo").css("backgroundColor", "rgba(0, 0, 0, 0.1)");
+ jQuery( "#foo" ).css( "backgroundColor", "rgba(0, 0, 0, 0.1)" );
}
catch (e) {
success = false;
}
- ok( success, "Setting RGBA values does not throw Error" );
+ ok( success, "Setting RGBA values does not throw Error (#5509)" );
+
+ jQuery( "#foo" ).css( "font", "7px/21px sans-serif" );
+ strictEqual( jQuery( "#foo" ).css( "line-height" ), "21px",
+ "Set font shorthand property (#14759)" );
});
test( "css(Array)", function() {
@@ -923,10 +926,20 @@ test( ":visible/:hidden selectors", function() {
t( "Is Hidden", "#form input:hidden", ["hidden1","hidden2"] );
});
-test( "Override !important when changing styles (#14394)", function() {
+test( "Keep the last style if the new one isn't recognized by the browser (#14836)", function() {
+ expect( 2 );
+
+ var el;
+ el = jQuery( "<div></div>" ).css( "color", "black" ).css( "color", "fake value" );
+ equal( el.css( "color" ), "black", "The old style is kept when setting an unrecognized value" );
+ el = jQuery( "<div></div>" ).css( "color", "black" ).css( "color", " " );
+ equal( el.css( "color" ), "black", "The old style is kept when setting to a space" );
+});
+
+test( "Reset the style if set to an empty string", function() {
expect( 1 );
- var el = jQuery( "<div style='display: block !important;'></div>" ).css( "display", "none" );
- equal( el.css( "display" ), "none", "New style replaced !important" );
+ var el = jQuery( "<div></div>" ).css( "color", "black" ).css( "color", "" );
+ equal( el.css( "color" ), "", "The style can be reset by setting to an empty string" );
});
asyncTest( "Clearing a Cloned Element's Style Shouldn't Clear the Original Element's Style (#8908)", 24, function() {