Fixes #7397; 4 supporting unit tests
authorrwldrn <waldron.rick@gmail.com>
Tue, 9 Nov 2010 23:06:33 +0000 (18:06 -0500)
committerrwldrn <waldron.rick@gmail.com>
Tue, 9 Nov 2010 23:06:33 +0000 (18:06 -0500)
src/effects.js
test/unit/effects.js

index 51ce0c5..f9c682c 100644 (file)
@@ -60,11 +60,12 @@ jQuery.fn.extend({
 
                } else {
                        for ( var i = 0, j = this.length; i < j; i++ ) {
-                               var display = jQuery.css( this[i], "display" );
-
-                               if ( display !== "none" ) {
-                                       jQuery.data( this[i], "olddisplay", display );
-                               }
+                               var display = jQuery.css( this[i], "display" ), 
+                                   old = jQuery.data( this[i], "olddisplay" );
+        
+                               if ( !old && display !== "none" ) {
+                                         jQuery.data( this[i], "olddisplay", display );
+                         }                               
                        }
 
                        // Set the display of the elements in a second loop
index 74b336f..aca9263 100644 (file)
@@ -130,6 +130,41 @@ test("show(Number) - other displays", function() {
        });
 });
 
+
+
+//  Supports #7397
+test("Persist correct display value", function() {
+  expect(4);
+       QUnit.reset();
+       stop();
+
+       // #show-tests * is set display: none in CSS
+       jQuery("#main").append('<div id="show-tests"><span style="position:absolute;"></span></div>');
+  
+       var $span = jQuery("#show-tests span"),  
+         orig = $span.css("display"),
+               num = 0;
+               
+  equal(orig, "none", "Expecting to start at display: none");
+
+  $span.text('Saving...').fadeIn(100, function() {
+
+    equal($span.css("display"), "block", "Expecting display: block");
+
+    $span.text('Saved!').fadeOut(100, function () {
+  
+      equal($span.css("display"), "none", "Expecting display: none");
+      
+      $span.text('Saving...').fadeIn(100, function() {
+      
+        equal($span.css("display"), "block", "Expecting display: block");
+      
+        start();
+      });
+    });
+  });
+});
+
 test("animate(Hash, Object, Function)", function() {
        expect(1);
        stop();