Responsive Images: the src
of the image has to be first in the srcset
, because of a bug in iOS8. Update the unit tests to reflect the changes.
Props jaspermdegroot, joemcgill, azaozz. Fixes #35030. git-svn-id: https://develop.svn.wordpress.org/trunk@37034 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
d85a319cd1
commit
33947e4ba6
@ -1067,6 +1067,7 @@ function wp_calculate_image_srcset( $size_array, $image_src, $image_meta, $attac
|
|||||||
* versions of the same edit.
|
* versions of the same edit.
|
||||||
*/
|
*/
|
||||||
foreach ( $image_sizes as $image ) {
|
foreach ( $image_sizes as $image ) {
|
||||||
|
$is_src = false;
|
||||||
|
|
||||||
// Check if image meta isn't corrupted.
|
// Check if image meta isn't corrupted.
|
||||||
if ( ! is_array( $image ) ) {
|
if ( ! is_array( $image ) ) {
|
||||||
@ -1075,7 +1076,7 @@ function wp_calculate_image_srcset( $size_array, $image_src, $image_meta, $attac
|
|||||||
|
|
||||||
// If the file name is part of the `src`, we've confirmed a match.
|
// If the file name is part of the `src`, we've confirmed a match.
|
||||||
if ( ! $src_matched && false !== strpos( $image_src, $dirname . $image['file'] ) ) {
|
if ( ! $src_matched && false !== strpos( $image_src, $dirname . $image['file'] ) ) {
|
||||||
$src_matched = true;
|
$src_matched = $is_src = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Filter out images that are from previous edits.
|
// Filter out images that are from previous edits.
|
||||||
@ -1087,9 +1088,7 @@ function wp_calculate_image_srcset( $size_array, $image_src, $image_meta, $attac
|
|||||||
* Filter out images that are wider than '$max_srcset_image_width' unless
|
* Filter out images that are wider than '$max_srcset_image_width' unless
|
||||||
* that file is in the 'src' attribute.
|
* that file is in the 'src' attribute.
|
||||||
*/
|
*/
|
||||||
if ( $max_srcset_image_width && $image['width'] > $max_srcset_image_width &&
|
if ( $max_srcset_image_width && $image['width'] > $max_srcset_image_width && ! $is_src ) {
|
||||||
false === strpos( $image_src, $image['file'] ) ) {
|
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1109,11 +1108,18 @@ function wp_calculate_image_srcset( $size_array, $image_src, $image_meta, $attac
|
|||||||
// If the image dimensions are within 1px of the expected size, use it.
|
// If the image dimensions are within 1px of the expected size, use it.
|
||||||
if ( abs( $constrained_size[0] - $expected_size[0] ) <= 1 && abs( $constrained_size[1] - $expected_size[1] ) <= 1 ) {
|
if ( abs( $constrained_size[0] - $expected_size[0] ) <= 1 && abs( $constrained_size[1] - $expected_size[1] ) <= 1 ) {
|
||||||
// Add the URL, descriptor, and value to the sources array to be returned.
|
// Add the URL, descriptor, and value to the sources array to be returned.
|
||||||
$sources[ $image['width'] ] = array(
|
$source = array(
|
||||||
'url' => $image_baseurl . $image['file'],
|
'url' => $image_baseurl . $image['file'],
|
||||||
'descriptor' => 'w',
|
'descriptor' => 'w',
|
||||||
'value' => $image['width'],
|
'value' => $image['width'],
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// The 'src' image has to be the first in the 'srcset', because of a bug in iOS8. See #35030.
|
||||||
|
if ( $is_src ) {
|
||||||
|
$sources = array( $image['width'] => $source ) + $sources;
|
||||||
|
} else {
|
||||||
|
$sources[ $image['width'] ] = $source;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -833,23 +833,35 @@ EOF;
|
|||||||
/**
|
/**
|
||||||
* Helper function to get image size array from size "name"
|
* Helper function to get image size array from size "name"
|
||||||
*/
|
*/
|
||||||
function _get_image_size_array_from_name( $size_name ) {
|
function _get_image_size_array_from_meta( $image_meta, $size_name ) {
|
||||||
switch ( $size_name ) {
|
$array = false;
|
||||||
case 'thumbnail':
|
|
||||||
return array( 150, 150 );
|
if ( is_array( $image_meta ) ) {
|
||||||
case 'medium':
|
if ( 'full' === $size_name && isset( $image_meta['width'] ) && isset( $image_meta['height'] ) ) {
|
||||||
return array( 300, 225 );
|
$array = array( $image_meta['width'], $image_meta['height'] );
|
||||||
case 'medium_large':
|
} elseif ( isset( $image_meta['sizes'][ $size_name ]['width'] ) && isset( $image_meta['sizes'][ $size_name ]['height'] ) ) {
|
||||||
return array( 768, 576 );
|
$array = array( $image_meta['sizes'][ $size_name ]['width'], $image_meta['sizes'][ $size_name ]['height'] );
|
||||||
case 'large':
|
|
||||||
return array( 1024, 768 );
|
|
||||||
case 'full':
|
|
||||||
return array( 1600, 1200 ); // actual size of ../data/images/test-image-large.png
|
|
||||||
default:
|
|
||||||
return array( 800, 600 ); // soft-resized image
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $array;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper function to move the src image to the first position in the expected srcset string.
|
||||||
|
*/
|
||||||
|
function _src_first( $srcset, $src_url, $src_width ) {
|
||||||
|
$src_string = $src_url . ' ' . $src_width . 'w';
|
||||||
|
$src_not_first = ', ' . $src_string;
|
||||||
|
|
||||||
|
if ( strpos( $srcset, $src_not_first ) ) {
|
||||||
|
$srcset = str_replace( $src_not_first, '', $srcset );
|
||||||
|
$srcset = $src_string . ', ' . $srcset;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $srcset;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ticket 33641
|
* @ticket 33641
|
||||||
*/
|
*/
|
||||||
@ -870,9 +882,9 @@ EOF;
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$expected = "";
|
$expected = '';
|
||||||
|
|
||||||
foreach( $image_meta['sizes'] as $name => $size ) {
|
foreach ( $image_meta['sizes'] as $name => $size ) {
|
||||||
// Whitelist the sizes that should be included so we pick up 'medium_large' in 4.4.
|
// Whitelist the sizes that should be included so we pick up 'medium_large' in 4.4.
|
||||||
if ( in_array( $name, $intermediates ) ) {
|
if ( in_array( $name, $intermediates ) ) {
|
||||||
$expected .= $uploads_dir_url . $year_month . '/' . $size['file'] . ' ' . $size['width'] . 'w, ';
|
$expected .= $uploads_dir_url . $year_month . '/' . $size['file'] . ' ' . $size['width'] . 'w, ';
|
||||||
@ -884,8 +896,9 @@ EOF;
|
|||||||
|
|
||||||
foreach ( $intermediates as $int ) {
|
foreach ( $intermediates as $int ) {
|
||||||
$image_url = wp_get_attachment_image_url( self::$large_id, $int );
|
$image_url = wp_get_attachment_image_url( self::$large_id, $int );
|
||||||
$size_array = $this->_get_image_size_array_from_name( $int );
|
$size_array = $this->_get_image_size_array_from_meta( $image_meta, $int );
|
||||||
$this->assertSame( $expected, wp_calculate_image_srcset( $size_array, $image_url, $image_meta ) );
|
$expected_srcset = $this->_src_first( $expected, $image_url, $size_array[0] );
|
||||||
|
$this->assertSame( $expected_srcset, wp_calculate_image_srcset( $size_array, $image_url, $image_meta ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -914,9 +927,9 @@ EOF;
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$expected = "";
|
$expected = '';
|
||||||
|
|
||||||
foreach( $image_meta['sizes'] as $name => $size ) {
|
foreach ( $image_meta['sizes'] as $name => $size ) {
|
||||||
// Whitelist the sizes that should be included so we pick up 'medium_large' in 4.4.
|
// Whitelist the sizes that should be included so we pick up 'medium_large' in 4.4.
|
||||||
if ( in_array( $name, $intermediates ) ) {
|
if ( in_array( $name, $intermediates ) ) {
|
||||||
$expected .= $uploads_dir_url . $size['file'] . ' ' . $size['width'] . 'w, ';
|
$expected .= $uploads_dir_url . $size['file'] . ' ' . $size['width'] . 'w, ';
|
||||||
@ -927,9 +940,10 @@ EOF;
|
|||||||
$expected .= $uploads_dir_url . $image_meta['file'] . ' ' . $image_meta['width'] .'w';
|
$expected .= $uploads_dir_url . $image_meta['file'] . ' ' . $image_meta['width'] .'w';
|
||||||
|
|
||||||
foreach ( $intermediates as $int ) {
|
foreach ( $intermediates as $int ) {
|
||||||
$size_array = $this->_get_image_size_array_from_name( $int );
|
$size_array = $this->_get_image_size_array_from_meta( $image_meta, $int );
|
||||||
$image_url = wp_get_attachment_image_url( $id, $int );
|
$image_url = wp_get_attachment_image_url( $id, $int );
|
||||||
$this->assertSame( $expected, wp_calculate_image_srcset( $size_array, $image_url, $image_meta ) );
|
$expected_srcset = $this->_src_first( $expected, $image_url, $size_array[0] );
|
||||||
|
$this->assertSame( $expected_srcset, wp_calculate_image_srcset( $size_array, $image_url, $image_meta ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove the attachment
|
// Remove the attachment
|
||||||
@ -945,7 +959,7 @@ EOF;
|
|||||||
// Start by getting the attachment metadata.
|
// Start by getting the attachment metadata.
|
||||||
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
||||||
$image_url = wp_get_attachment_image_url( self::$large_id, 'medium' );
|
$image_url = wp_get_attachment_image_url( self::$large_id, 'medium' );
|
||||||
$size_array = $this->_get_image_size_array_from_name( 'medium' );
|
$size_array = $this->_get_image_size_array_from_meta( $image_meta, 'medium' );
|
||||||
|
|
||||||
// Copy hash generation method used in wp_save_image().
|
// Copy hash generation method used in wp_save_image().
|
||||||
$hash = 'e' . time() . rand(100, 999);
|
$hash = 'e' . time() . rand(100, 999);
|
||||||
@ -1007,8 +1021,9 @@ EOF;
|
|||||||
|
|
||||||
foreach ( $intermediates as $int ) {
|
foreach ( $intermediates as $int ) {
|
||||||
$image_url = wp_get_attachment_image_url( self::$large_id, $int );
|
$image_url = wp_get_attachment_image_url( self::$large_id, $int );
|
||||||
$size_array = $this->_get_image_size_array_from_name( $int );
|
$size_array = $this->_get_image_size_array_from_meta( $image_meta, $int );
|
||||||
$this->assertSame( $expected, wp_calculate_image_srcset( $size_array, $image_url, $image_meta ) );
|
$expected_srcset = $this->_src_first( $expected, $image_url, $size_array[0] );
|
||||||
|
$this->assertSame( $expected_srcset, wp_calculate_image_srcset( $size_array, $image_url, $image_meta ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1123,7 +1138,7 @@ EOF;
|
|||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
$expected_srcset = 'http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test-300x150.png 300w, http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test-768x384.png 768w, http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test-1024x512.png 1024w, http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test.png 2000w';
|
$expected_srcset = 'http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test.png 2000w, http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test-300x150.png 300w, http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test-768x384.png 768w, http://' . WP_TESTS_DOMAIN . '/wp-content/uploads/2015/12/test-1024x512.png 1024w';
|
||||||
|
|
||||||
$this->assertSame( $expected_srcset, wp_calculate_image_srcset( $size_array, $image_src, $image_meta ) );
|
$this->assertSame( $expected_srcset, wp_calculate_image_srcset( $size_array, $image_src, $image_meta ) );
|
||||||
}
|
}
|
||||||
@ -1226,7 +1241,7 @@ EOF;
|
|||||||
|
|
||||||
$expected = "";
|
$expected = "";
|
||||||
|
|
||||||
foreach( $image_meta['sizes'] as $name => $size ) {
|
foreach ( $image_meta['sizes'] as $name => $size ) {
|
||||||
// Whitelist the sizes that should be included so we pick up 'medium_large' in 4.4.
|
// Whitelist the sizes that should be included so we pick up 'medium_large' in 4.4.
|
||||||
if ( in_array( $name, $intermediates ) ) {
|
if ( in_array( $name, $intermediates ) ) {
|
||||||
$expected .= $uploads_dir . $year_month . '/' . $size['file'] . ' ' . $size['width'] . 'w, ';
|
$expected .= $uploads_dir . $year_month . '/' . $size['file'] . ' ' . $size['width'] . 'w, ';
|
||||||
@ -1235,7 +1250,9 @@ EOF;
|
|||||||
|
|
||||||
$expected .= $uploads_dir . $image_meta['file'] . ' ' . $image_meta['width'] .'w';
|
$expected .= $uploads_dir . $image_meta['file'] . ' ' . $image_meta['width'] .'w';
|
||||||
|
|
||||||
$this->assertSame( $expected, $srcset );
|
$expected_srcset = $this->_src_first( $expected, $uploads_dir . $image_meta['file'], $size_array[0] );
|
||||||
|
|
||||||
|
$this->assertSame( $expected_srcset, $srcset );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1294,15 +1311,15 @@ EOF;
|
|||||||
*/
|
*/
|
||||||
function test_wp_calculate_image_sizes() {
|
function test_wp_calculate_image_sizes() {
|
||||||
// Test sizes against the default WP sizes.
|
// Test sizes against the default WP sizes.
|
||||||
$intermediates = array('thumbnail', 'medium', 'medium_large', 'large');
|
$intermediates = array( 'thumbnail', 'medium', 'medium_large', 'large' );
|
||||||
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
||||||
|
|
||||||
// Make sure themes aren't filtering the sizes array.
|
// Make sure themes aren't filtering the sizes array.
|
||||||
remove_all_filters( 'wp_calculate_image_sizes' );
|
remove_all_filters( 'wp_calculate_image_sizes' );
|
||||||
|
|
||||||
foreach( $intermediates as $int_size ) {
|
foreach ( $intermediates as $int_size ) {
|
||||||
$size_array = $this->_get_image_size_array_from_name( $int_size );
|
$size_array = $this->_get_image_size_array_from_meta( $image_meta, $int_size );
|
||||||
$image_src = $image_meta['sizes'][$int_size]['file'];
|
$image_src = $image_meta['sizes'][ $int_size ]['file'];
|
||||||
list( $width, $height ) = $size_array;
|
list( $width, $height ) = $size_array;
|
||||||
|
|
||||||
$expected = '(max-width: ' . $width . 'px) 100vw, ' . $width . 'px';
|
$expected = '(max-width: ' . $width . 'px) 100vw, ' . $width . 'px';
|
||||||
@ -1317,7 +1334,7 @@ EOF;
|
|||||||
*/
|
*/
|
||||||
function test_wp_make_content_images_responsive() {
|
function test_wp_make_content_images_responsive() {
|
||||||
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
||||||
$size_array = $this->_get_image_size_array_from_name( 'medium' );
|
$size_array = $this->_get_image_size_array_from_meta( $image_meta, 'medium' );
|
||||||
|
|
||||||
$srcset = sprintf( 'srcset="%s"', wp_get_attachment_image_srcset( self::$large_id, $size_array, $image_meta ) );
|
$srcset = sprintf( 'srcset="%s"', wp_get_attachment_image_srcset( self::$large_id, $size_array, $image_meta ) );
|
||||||
$sizes = sprintf( 'sizes="%s"', wp_get_attachment_image_sizes( self::$large_id, $size_array, $image_meta ) );
|
$sizes = sprintf( 'sizes="%s"', wp_get_attachment_image_sizes( self::$large_id, $size_array, $image_meta ) );
|
||||||
@ -1450,7 +1467,7 @@ EOF;
|
|||||||
*/
|
*/
|
||||||
function test_wp_make_content_images_responsive_schemes() {
|
function test_wp_make_content_images_responsive_schemes() {
|
||||||
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
$image_meta = wp_get_attachment_metadata( self::$large_id );
|
||||||
$size_array = $this->_get_image_size_array_from_name( 'medium' );
|
$size_array = $this->_get_image_size_array_from_meta( $image_meta, 'medium' );
|
||||||
|
|
||||||
$srcset = sprintf( 'srcset="%s"', wp_get_attachment_image_srcset( self::$large_id, $size_array, $image_meta ) );
|
$srcset = sprintf( 'srcset="%s"', wp_get_attachment_image_srcset( self::$large_id, $size_array, $image_meta ) );
|
||||||
$sizes = sprintf( 'sizes="%s"', wp_get_attachment_image_sizes( self::$large_id, $size_array, $image_meta ) );
|
$sizes = sprintf( 'sizes="%s"', wp_get_attachment_image_sizes( self::$large_id, $size_array, $image_meta ) );
|
||||||
@ -1480,7 +1497,7 @@ EOF;
|
|||||||
$actual = wp_make_content_images_responsive( $unfiltered );
|
$actual = wp_make_content_images_responsive( $unfiltered );
|
||||||
|
|
||||||
$this->assertSame( $expected, $actual );
|
$this->assertSame( $expected, $actual );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ticket 34945
|
* @ticket 34945
|
||||||
@ -1517,7 +1534,7 @@ EOF;
|
|||||||
|
|
||||||
$_SERVER['HTTPS'] = 'on';
|
$_SERVER['HTTPS'] = 'on';
|
||||||
|
|
||||||
$expected = 'https://' . WP_TESTS_DOMAIN . '/wp-content/uploads/test-300x150.jpg 300w, https://' . WP_TESTS_DOMAIN . '/wp-content/uploads/test-1024x512.jpg 1024w, https://' . WP_TESTS_DOMAIN . '/wp-content/uploads/test.jpg 1200w';
|
$expected = 'https://' . WP_TESTS_DOMAIN . '/wp-content/uploads/test-1024x512.jpg 1024w, https://' . WP_TESTS_DOMAIN . '/wp-content/uploads/test-300x150.jpg 300w, https://' . WP_TESTS_DOMAIN . '/wp-content/uploads/test.jpg 1200w';
|
||||||
$actual = wp_calculate_image_srcset( $size_array, $image_url, $image_meta );
|
$actual = wp_calculate_image_srcset( $size_array, $image_url, $image_meta );
|
||||||
|
|
||||||
$this->assertSame( $expected, $actual );
|
$this->assertSame( $expected, $actual );
|
||||||
|
Loading…
Reference in New Issue
Block a user