Ticket #56442: 56442.7.diff
File 56442.7.diff, 7.7 KB (added by , 3 years ago) |
---|
-
src/wp-includes/class-wp-image-editor.php
diff --git src/wp-includes/class-wp-image-editor.php src/wp-includes/class-wp-image-editor.php index e7070b1ca6..fed0fc16e8 100644
abstract class WP_Image_Editor { 414 414 // The image will be converted when saving. Set the quality for the new mime-type if not already set. 415 415 if ( $mime_type !== $this->output_mime_type ) { 416 416 $this->output_mime_type = $mime_type; 417 $this->set_quality();418 417 } 418 $this->set_quality(); 419 419 } elseif ( ! empty( $this->output_mime_type ) ) { 420 420 // Reset output_mime_type and quality. 421 421 $this->output_mime_type = null; -
tests/phpunit/tests/image/editor.php
diff --git tests/phpunit/tests/image/editor.php tests/phpunit/tests/image/editor.php index 487dad0664..be4591451d 100644
class Tests_Image_Editor extends WP_Image_UnitTestCase { 105 105 106 106 // Ensure wp_editor_set_quality filter applies if it exists before editor instantiation. 107 107 $this->assertSame( 100, $editor->get_quality() ); 108 109 // Clean up.110 remove_filter( 'wp_editor_set_quality', $func_100_percent );111 108 } 112 109 113 110 /** … … class Tests_Image_Editor extends WP_Image_UnitTestCase { 119 116 $editor = wp_get_image_editor( DIR_TESTDATA . '/images/test-image.png' ); 120 117 $editor->set_mime_type( 'image/png' ); // Ensure mime-specific filters act properly. 121 118 119 // Quality setting for the source image. For PNG the fallback default of 82 is used. 120 $this->assertSame( 82, $editor->get_quality(), 'Default quality setting is 82.' ); 121 122 122 // Set conversions for uploaded images. 123 123 add_filter( 'image_editor_output_format', array( $this, 'image_editor_output_formats' ) ); 124 124 125 125 // Quality setting for the source image. For PNG the fallback default of 82 is used. 126 126 $this->assertSame( 82, $editor->get_quality(), 'Default quality setting is 82.' ); 127 127 128 // Quality should change to the output format's value.129 // A PNG image will be converted to W EBP whose quialty should be 86.128 // When saving, quality should change to the output format's value. 129 // A PNG image will be converted to WebP whose quality should be 86. 130 130 $editor->save(); 131 $this->assertSame( 86, $editor->get_quality(), 'Output image format is W EBP. Quality setting for it should be 86.' );131 $this->assertSame( 86, $editor->get_quality(), 'Output image format is WebP. Quality setting for it should be 86.' ); 132 132 133 // Removing PNG to WEBP conversion on save. Quality setting should reset to the default. 133 // Saving again should not change the quality. 134 $editor->save(); 135 $this->assertSame( 86, $editor->get_quality(), 'Output image format is WebP. Quality setting for it should be 86.' ); 136 137 // Removing PNG to WebP conversion on save. Quality setting should reset to the default. 134 138 remove_filter( 'image_editor_output_format', array( $this, 'image_editor_output_formats' ) ); 135 139 $editor->save(); 136 140 $this->assertSame( 82, $editor->get_quality(), 'After removing image conversion quality setting should reset to the default of 82.' ); … … class Tests_Image_Editor extends WP_Image_UnitTestCase { 149 153 $this->assertSame( 56, $editor->get_quality(), 'Filtered default quality for JPEG is 56.' ); 150 154 151 155 // Quality should change to the output format's value as filtered above. 152 // A JPEG image will be converted to W EBP whose quialty should be 42.156 // A JPEG image will be converted to WebP whose quialty should be 42. 153 157 $editor->save(); 154 $this->assertSame( 42, $editor->get_quality(), 'Image conversion from JPEG to WEBP. Filtered WEBP quality sho ild be 42.' );158 $this->assertSame( 42, $editor->get_quality(), 'Image conversion from JPEG to WEBP. Filtered WEBP quality should be 42.' ); 155 159 156 160 // After removing the conversion the quality setting should reset to the filtered value for the original image type, JPEG. 157 161 remove_filter( 'image_editor_output_format', array( $this, 'image_editor_output_formats' ) ); … … class Tests_Image_Editor extends WP_Image_UnitTestCase { 161 165 $editor->get_quality(), 162 166 'After removing image conversion the quality setting should reset to the filtered value for JPEG, 56.' 163 167 ); 164 165 remove_filter( 'wp_editor_set_quality', array( $this, 'image_editor_change_quality' ) );166 168 } 167 169 168 170 /** -
tests/phpunit/tests/media.php
diff --git tests/phpunit/tests/media.php tests/phpunit/tests/media.php index 820da7ed3d..0d5ac75863 100644
EOF; 3621 3621 // Clean up the above filter. 3622 3622 remove_filter( 'wp_omit_loading_attr_threshold', '__return_null', 100 ); 3623 3623 } 3624 3625 /** 3626 * Test that generated files with the `image_editor_output_format` applied use the correct 3627 * quality level based on their mime type. 3628 * 3629 * @ticket 56442 3630 */ 3631 public function test_quality_with_image_conversion_file_sizes() { 3632 add_filter( 'image_editor_output_format', array( $this, 'image_editor_output_jpeg' ) ); 3633 $temp_dir = get_temp_dir(); 3634 $file = $temp_dir . '/33772.jpg'; 3635 copy( DIR_TESTDATA . '/images/33772.jpg', $file ); 3636 3637 // Set JPEG output quality very low and WebP quality very high, this should force all generated WebP images to 3638 // be larger than the the matching generated JPEGs. 3639 add_filter( 'wp_editor_set_quality', array( $this, 'image_editor_change_quality_low_jpeg' ), 10, 2 ); 3640 3641 $editor = wp_get_image_editor( $file ); 3642 3643 // Verify that the selected editor supports WebP output. 3644 if ( ! $editor->supports_mime_type( 'image/webp' ) ) { 3645 $this->markTestSkipped( 'WebP is not supported by the selected image editor.' ); 3646 } 3647 3648 $attachment_id = self::factory()->attachment->create_object( 3649 array( 3650 'post_mime_type' => 'image/jpeg', 3651 'file' => $file, 3652 ) 3653 ); 3654 3655 add_filter( 'big_image_size_threshold', array( $this, 'add_big_image_size_threshold' ) ); 3656 3657 // Generate all sizes as JPEGs. 3658 $jpeg_sizes = wp_generate_attachment_metadata( $attachment_id, $file ); 3659 remove_filter( 'image_editor_output_format', array( $this, 'image_editor_output_jpeg' ) ); 3660 3661 // Generate all sizes as WebP. 3662 add_filter( 'image_editor_output_format', array( $this, 'image_editor_output_webp' ) ); 3663 $webp_sizes = wp_generate_attachment_metadata( $attachment_id, $file ); 3664 remove_filter( 'image_editor_output_format', array( $this, 'image_editor_output_webp' ) ); 3665 3666 // The main (scaled) image: the JPEG should be smaller than the WebP. 3667 $this->assertLessThan( $webp_sizes['filesize'], $jpeg_sizes['filesize'], 'The JPEG should be smaller than the WebP.' ); 3668 3669 // Sub-sizes: for each size, the JPEGs should be smaller than the WebP. 3670 $sizes_to_compare = array_intersect_key( $jpeg_sizes['sizes'], $webp_sizes['sizes'] ); 3671 foreach ( $sizes_to_compare as $size => $size_data ) { 3672 $this->assertLessThan( $webp_sizes['sizes'][ $size ]['filesize'], $jpeg_sizes['sizes'][ $size ]['filesize'] ); 3673 } 3674 } 3675 3676 /** 3677 * Add threshold to create a `-scaled` output image for testing. 3678 */ 3679 public function add_big_image_size_threshold() { 3680 return 1000; 3681 } 3682 3683 /** 3684 * Output JPEG files. 3685 */ 3686 public function image_editor_output_jpeg() { 3687 return array( 'image/jpeg' => 'image/jpeg' ); 3688 } 3689 3690 /** 3691 * Output WebP files. 3692 */ 3693 public function image_editor_output_webp() { 3694 return array( 'image/jpeg' => 'image/webp' ); 3695 } 3696 3697 /** 3698 * Changes the quality using very low quality for JPEGs and very high quality 3699 * for WebPs, used to verify the filter is applying correctly. 3700 * 3701 * @param int $quality Default quality. 3702 * @param string $mime_type Image mime-type. 3703 * @return int The changed quality. 3704 */ 3705 public function image_editor_change_quality_low_jpeg( $quality, $mime_type ) { 3706 if ( 'image/jpeg' === $mime_type ) { 3707 return 1; 3708 } elseif ( 'image/webp' === $mime_type ) { 3709 return 100; 3710 } else { 3711 return 30; 3712 } 3713 } 3714 3624 3715 } 3625 3716 3626 3717 /**