From ba94b81c7df96177d1fed4e4720413a07227d7a4 Mon Sep 17 00:00:00 2001 From: Adam Silverstein Date: Fri, 17 Nov 2023 09:17:41 -0700 Subject: [PATCH 1/3] Test that a revision with an array in meta saves correctly even when included in `_wp_post_revision_fields`. --- tests/phpunit/tests/post/metaRevisions.php | 84 +++++++++++++++++++++- 1 file changed, 83 insertions(+), 1 deletion(-) diff --git a/tests/phpunit/tests/post/metaRevisions.php b/tests/phpunit/tests/post/metaRevisions.php index 74442b53c82ad..b461b4c42b685 100644 --- a/tests/phpunit/tests/post/metaRevisions.php +++ b/tests/phpunit/tests/post/metaRevisions.php @@ -552,7 +552,7 @@ public function test_revisionining_of_meta_with_default_value() { $revisions = wp_get_post_revisions( $post_id ); $last_revision = array_shift( $revisions ); - // No ,eta data should be stored in the revision. + // No meta data should be stored in the revision. $this->assertEquals( array(), get_post_meta( $last_revision->ID ) ); // Set the test meta again. @@ -719,4 +719,86 @@ public function page_post_type_data_provider() { ), ); } + + /** + * Test that a revision with an array in meta saves correctly even when included in `_wp_post_revision_fields`. + * + * @ticket 59827 + */ + public function test_wp_save_post_revision_with_array_meta() { + + // Add a meta field to revision that includes a default value. + register_post_meta( + 'post', + 'meta_revision_test', + array( + 'single' => true, + 'type' => 'array', + 'revisions_enabled' => true, + ) + ); + + // Add the meta value to `_wp_post_revision_fields` which triggers it being compared for save consideration. + add_filter( '_wp_post_revision_fields', function( $fields ) { + $fields[ 'meta_revision_test' ] = 'Meta Revisions Test'; + return $fields; + } ); + + // Set up a new post. + $post_id = $this->factory->post->create( + array( + 'post_content' => 'initial content', + 'meta_input' => array( + 'meta_revision_test' => 'foo', + ), + ) + ); + + // Set the test meta to an array. + update_post_meta( $post_id, 'meta_revision_test', array( 'test' ) ); + + // Update to save. + wp_update_post( array( 'ID' => $post_id ) ); + + // Check that the meta is stored correctly. + $stored_data = get_post_meta( $post_id, 'meta_revision_test', true ); + $this->assertEquals( array( 'test' ) , $stored_data ); + + // Also verify that the latest revision has stored the meta. + $revisions = wp_get_post_revisions( $post_id ); + $last_revision = array_shift( $revisions ); + $stored_data = get_post_meta( $last_revision->ID, 'meta_revision_test', true ); + $this->assertEquals( array( 'test' ) , $stored_data ); + + // Update the meta. + update_post_meta( $post_id, 'meta_revision_test', array( 'changed' ) ); + + // Update to save. + wp_update_post( + array( + 'ID' => $post_id, + 'post_content' => 'content update 1', + ) + ); + + // Check that the correct meta value is returned. + $this->assertEquals( array( 'changed' ), get_post_meta( $post_id, 'meta_revision_test', true ) ); + + // Also verify that the latest revision has the correct meta value. + $revisions = wp_get_post_revisions( $post_id ); + $last_revision = array_shift( $revisions ); + + // Set the test meta again. + update_post_meta( $post_id, 'meta_revision_test', 'test' ); + + // Update to save. + wp_update_post( array( 'ID' => $post_id ) ); + + // Now restore the previous revision. + wp_restore_post_revision( $last_revision->ID ); + + // Verify the correct meta value is still returned. + $this->assertEquals( array( 'changed' ), get_post_meta( $post_id, 'meta_revision_test', true ) ); + + } } From d6dd548c68343f0d4fbbf6ab7f9418c6c353e3e7 Mon Sep 17 00:00:00 2001 From: Adam Silverstein Date: Fri, 17 Nov 2023 09:24:34 -0700 Subject: [PATCH 2/3] phpcbf --- tests/phpunit/tests/post/metaRevisions.php | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/tests/phpunit/tests/post/metaRevisions.php b/tests/phpunit/tests/post/metaRevisions.php index b461b4c42b685..1716ebe9e41de 100644 --- a/tests/phpunit/tests/post/metaRevisions.php +++ b/tests/phpunit/tests/post/metaRevisions.php @@ -739,10 +739,13 @@ public function test_wp_save_post_revision_with_array_meta() { ); // Add the meta value to `_wp_post_revision_fields` which triggers it being compared for save consideration. - add_filter( '_wp_post_revision_fields', function( $fields ) { - $fields[ 'meta_revision_test' ] = 'Meta Revisions Test'; - return $fields; - } ); + add_filter( + '_wp_post_revision_fields', + function ( $fields ) { + $fields['meta_revision_test'] = 'Meta Revisions Test'; + return $fields; + } + ); // Set up a new post. $post_id = $this->factory->post->create( @@ -762,13 +765,13 @@ public function test_wp_save_post_revision_with_array_meta() { // Check that the meta is stored correctly. $stored_data = get_post_meta( $post_id, 'meta_revision_test', true ); - $this->assertEquals( array( 'test' ) , $stored_data ); + $this->assertEquals( array( 'test' ), $stored_data ); // Also verify that the latest revision has stored the meta. $revisions = wp_get_post_revisions( $post_id ); $last_revision = array_shift( $revisions ); $stored_data = get_post_meta( $last_revision->ID, 'meta_revision_test', true ); - $this->assertEquals( array( 'test' ) , $stored_data ); + $this->assertEquals( array( 'test' ), $stored_data ); // Update the meta. update_post_meta( $post_id, 'meta_revision_test', array( 'changed' ) ); @@ -799,6 +802,5 @@ public function test_wp_save_post_revision_with_array_meta() { // Verify the correct meta value is still returned. $this->assertEquals( array( 'changed' ), get_post_meta( $post_id, 'meta_revision_test', true ) ); - } } From 3b586279705ab62eb2cd1dfaf6db8e7909cf35b7 Mon Sep 17 00:00:00 2001 From: Adam Silverstein Date: Fri, 17 Nov 2023 09:25:17 -0700 Subject: [PATCH 3/3] only normalize screens when checking for revision field changes --- src/wp-includes/revision.php | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/wp-includes/revision.php b/src/wp-includes/revision.php index 681d11736c0d1..aa53a66e24605 100644 --- a/src/wp-includes/revision.php +++ b/src/wp-includes/revision.php @@ -187,7 +187,9 @@ function wp_save_post_revision( $post_id ) { $post_has_changed = false; foreach ( array_keys( _wp_post_revision_fields( $post ) ) as $field ) { - if ( normalize_whitespace( $post->$field ) !== normalize_whitespace( $latest_revision->$field ) ) { + $compare_from = is_string( $post->$field ) ? normalize_whitespace( $post->$field ) : $post->$field; + $compare_to = is_string( $latest_revision->$field ) ? normalize_whitespace( $latest_revision->$field ) : $latest_revision->$field; + if ( $compare_from !== $compare_to ) { $post_has_changed = true; break; }