From 80f1c8239e9d5f793f3e54e0cb8d7bd0747e4856 Mon Sep 17 00:00:00 2001 From: Richard Gibson Date: Mon, 19 Jun 2017 15:42:55 -0400 Subject: Dimensions: Include scroll gutter in "padding" box Fixes gh-3589 Closes gh-3656 --- test/unit/dimensions.js | 83 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) (limited to 'test') diff --git a/test/unit/dimensions.js b/test/unit/dimensions.js index 76850e9e2..2ec5f3683 100644 --- a/test/unit/dimensions.js +++ b/test/unit/dimensions.js @@ -544,4 +544,87 @@ QUnit.test( "width/height on an inline element with no explicitly-set dimensions } ); } ); +QUnit.test( "interaction with scrollbars (gh-3589)", function( assert ) { + assert.expect( 36 ); + + var i, + suffix = "", + updater = function( adjustment ) { + return function( i, old ) { + return old + adjustment; + }; + }, + parent = jQuery( "
" ) + .css( { position: "absolute", width: "1000px", height: "1000px" } ) + .appendTo( "#qunit-fixture" ), + fraction = jQuery( "
" ).appendTo( parent ).width() % 1, + borderWidth = 1, + padding = 2, + size = 100 + fraction, + scrollBox = { + position: "absolute", + overflow: "scroll", + width: size + "px", + height: size + "px" + }, + borderBox = { + border: borderWidth + "px solid blue", + padding: padding + "px" + }, + plainContentBox = jQuery( "
" ) + .css( scrollBox ) + .css( { "box-sizing": "content-box" } ) + .appendTo( parent ), + contentBox = jQuery( "
" ) + .css( scrollBox ) + .css( borderBox ) + .css( { "box-sizing": "content-box" } ) + .appendTo( parent ), + borderBox = jQuery( "
" ) + .css( scrollBox ) + .css( borderBox ) + .css( { "box-sizing": "border-box" } ) + .appendTo( parent ), + $boxes = jQuery( [ plainContentBox[ 0 ], contentBox[ 0 ], borderBox[ 0 ] ] ); + + for ( i = 0; i < 3; i++ ) { + if ( i === 1 ) { + suffix = " after increasing inner* by " + i; + size += i; + $boxes.innerWidth( updater( i ) ).innerHeight( updater( i ) ); + } else if ( i === 2 ) { + suffix = " after increasing outer* by " + i; + size += i; + $boxes.outerWidth( updater( i ) ).outerHeight( updater( i ) ); + } + + assert.equal( plainContentBox.innerWidth(), size, + "plain content-box innerWidth includes scroll gutter" + suffix ); + assert.equal( plainContentBox.innerHeight(), size, + "plain content-box innerHeight includes scroll gutter" + suffix ); + assert.equal( plainContentBox.outerWidth(), size, + "plain content-box outerWidth includes scroll gutter" + suffix ); + assert.equal( plainContentBox.outerHeight(), size, + "plain content-box outerHeight includes scroll gutter" + suffix ); + + assert.equal( contentBox.innerWidth(), size + 2 * padding, + "content-box innerWidth includes scroll gutter" + suffix ); + assert.equal( contentBox.innerHeight(), size + 2 * padding, + "content-box innerHeight includes scroll gutter" + suffix ); + assert.equal( contentBox.outerWidth(), size + 2 * padding + 2 * borderWidth, + "content-box outerWidth includes scroll gutter" + suffix ); + assert.equal( contentBox.outerHeight(), size + 2 * padding + 2 * borderWidth, + "content-box outerHeight includes scroll gutter" + suffix ); + + assert.equal( borderBox.innerWidth(), size - 2 * borderWidth, + "border-box innerWidth includes scroll gutter" + suffix ); + assert.equal( borderBox.innerHeight(), size - 2 * borderWidth, + "border-box innerHeight includes scroll gutter" + suffix ); + assert.equal( borderBox.outerWidth(), size, + "border-box outerWidth includes scroll gutter" + suffix ); + assert.equal( borderBox.outerHeight(), size, + "border-box outerHeight includes scroll gutter" + suffix ); + } +} ); + } )(); -- cgit v1.2.3