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:
Andrew Ozz 2016-03-18 19:44:50 +00:00
parent d85a319cd1
commit 33947e4ba6
2 changed files with 72 additions and 49 deletions

View File

@ -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;
}
} }
} }

View File

@ -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 );