diff options
author | Jason Bedard <jason+github@jbedard.ca> | 2017-06-15 00:04:45 -0700 |
---|---|---|
committer | Jason Bedard <jason+github@jbedard.ca> | 2017-07-10 09:03:08 -0700 |
commit | 30b5ba5b929d51f811e90e44f13b0d9e5cb728f2 (patch) | |
tree | 0286bdd8ec56b2b21f7c18653268ee76e5c806d5 | |
parent | c18d608537d8945de6c5855a9475657177fa74ac (diff) | |
download | jquery-30b5ba5b929d51f811e90e44f13b0d9e5cb728f2.tar.gz jquery-30b5ba5b929d51f811e90e44f13b0d9e5cb728f2.zip |
Test: ensure position/offset return mutable objects
Fixes gh-3612
Closes gh-3695
-rw-r--r-- | test/unit/offset.js | 36 |
1 files changed, 31 insertions, 5 deletions
diff --git a/test/unit/offset.js b/test/unit/offset.js index d1fad57fa..8e0cd7275 100644 --- a/test/unit/offset.js +++ b/test/unit/offset.js @@ -65,7 +65,7 @@ QUnit.test( "empty set", function( assert ) { } ); QUnit.test( "disconnected element", function( assert ) { - assert.expect( 3 ); + assert.expect( 4 ); var result = jQuery( document.createElement( "div" ) ).offset(); @@ -75,10 +75,11 @@ QUnit.test( "disconnected element", function( assert ) { assert.equal( result.top, 0, "Retrieving offset on disconnected elements returns zeros (gh-2310)" ); assert.equal( result.left, 0, "Retrieving offset on disconnected elements returns zeros (gh-2310)" ); assert.equal( Object.keys( result ).length, 2, "Retrieving offset on disconnected elements returns offset object (gh-3167)" ); + assert.equal( jQuery.isPlainObject( result ), true, "Retrieving offset on disconnected elements returns plain object (gh-3612)" ); } ); QUnit.test( "hidden (display: none) element", function( assert ) { - assert.expect( 3 ); + assert.expect( 4 ); var node = jQuery( "<div style='display: none' />" ).appendTo( "#qunit-fixture" ), result = node.offset(); @@ -91,10 +92,11 @@ QUnit.test( "hidden (display: none) element", function( assert ) { assert.equal( result.top, 0, "Retrieving offset on hidden elements returns zeros (gh-2310)" ); assert.equal( result.left, 0, "Retrieving offset on hidden elements returns zeros (gh-2310)" ); assert.equal( Object.keys( result ).length, 2, "Retrieving offset on hidden elements returns offset object (gh-3167)" ); + assert.equal( jQuery.isPlainObject( result ), true, "Retrieving offset on hidden elements returns plain object (gh-3612)" ); } ); QUnit.test( "0 sized element", function( assert ) { - assert.expect( 3 ); + assert.expect( 4 ); var node = jQuery( "<div style='margin: 5px; width: 0; height: 0' />" ).appendTo( "#qunit-fixture" ), result = node.offset(); @@ -104,10 +106,11 @@ QUnit.test( "0 sized element", function( assert ) { assert.notEqual( result.top, 0, "Retrieving offset on 0 sized elements (gh-3167)" ); assert.notEqual( result.left, 0, "Retrieving offset on 0 sized elements (gh-3167)" ); assert.equal( Object.keys( result ).length, 2, "Retrieving offset on 0 sized elements returns offset object (gh-3167)" ); + assert.equal( jQuery.isPlainObject( result ), true, "Retrieving offset on 0 sized elements returns plain object (gh-3612)" ); } ); QUnit.test( "hidden (visibility: hidden) element", function( assert ) { - assert.expect( 3 ); + assert.expect( 4 ); var node = jQuery( "<div style='margin: 5px; visibility: hidden' />" ).appendTo( "#qunit-fixture" ), result = node.offset(); @@ -117,6 +120,23 @@ QUnit.test( "hidden (visibility: hidden) element", function( assert ) { assert.notEqual( result.top, 0, "Retrieving offset on visibility:hidden elements (gh-3167)" ); assert.notEqual( result.left, 0, "Retrieving offset on visibility:hidden elements (gh-3167)" ); assert.equal( Object.keys( result ).length, 2, "Retrieving offset on visibility:hidden elements returns offset object (gh-3167)" ); + assert.equal( jQuery.isPlainObject( result ), true, "Retrieving offset on visibility:hidden elements returns plain object (gh-3612)" ); +} ); + +QUnit.test( "normal element", function( assert ) { + assert.expect( 4 ); + + var node = jQuery( "<div>" ).appendTo( "#qunit-fixture" ), + offset = node.offset(), + position = node.position(); + + node.remove(); + + assert.equal( Object.keys( offset ).length, 2, "Retrieving offset on normal elements returns offset object (gh-3612)" ); + assert.equal( jQuery.isPlainObject( offset ), true, "Retrieving offset on normal elements returns plain object (gh-3612)" ); + + assert.equal( Object.keys( position ).length, 2, "Retrieving position on normal elements returns offset object (gh-3612)" ); + assert.equal( jQuery.isPlainObject( position ), true, "Retrieving position on normal elements returns plain object (gh-3612)" ); } ); testIframe( "absolute", "offset/absolute.html", function( assert, $, iframe ) { @@ -350,7 +370,7 @@ testIframe( "static", "offset/static.html", function( assert, $ ) { } ); testIframe( "fixed", "offset/fixed.html", function( assert, $, window ) { - assert.expect( 34 ); + assert.expect( 38 ); var tests, $noTopLeft; @@ -377,8 +397,12 @@ testIframe( "fixed", "offset/fixed.html", function( assert, $, window ) { assert.ok( true, "Browser doesn't support scroll position." ); assert.ok( true, "Browser doesn't support scroll position." ); assert.ok( true, "Browser doesn't support scroll position." ); + assert.ok( true, "Browser doesn't support scroll position." ); + assert.ok( true, "Browser doesn't support scroll position." ); } else if ( window.supportsFixedPosition ) { + assert.equal( jQuery.isPlainObject( $( this.id ).offset() ), true, "jQuery('" + this.id + "').offset() is plain object" ); + assert.equal( jQuery.isPlainObject( $( this.id ).position() ), true, "jQuery('" + this.id + "').position() is plain object" ); assert.equal( $( this.id ).offset().top, this.offsetTop, "jQuery('" + this.id + "').offset().top" ); assert.equal( $( this.id ).position().top, this.positionTop, "jQuery('" + this.id + "').position().top" ); assert.equal( $( this.id ).offset().left, this.offsetLeft, "jQuery('" + this.id + "').offset().left" ); @@ -390,6 +414,8 @@ testIframe( "fixed", "offset/fixed.html", function( assert, $, window ) { assert.ok( true, "Fixed position is not supported" ); assert.ok( true, "Fixed position is not supported" ); assert.ok( true, "Fixed position is not supported" ); + assert.ok( true, "Fixed position is not supported" ); + assert.ok( true, "Fixed position is not supported" ); } } ); |