diff --git a/src/wp-includes/meta.php b/src/wp-includes/meta.php index e8bc2acdd3..dc19833612 100644 --- a/src/wp-includes/meta.php +++ b/src/wp-includes/meta.php @@ -323,7 +323,7 @@ function metadata_exists( $meta_type, $object_id, $meta_key ) { $check = apply_filters( "get_{$meta_type}_metadata", null, $object_id, $meta_key, true ); if ( null !== $check ) - return true; + return (bool) $check; $meta_cache = wp_cache_get( $object_id, $meta_type . '_meta' ); diff --git a/tests/phpunit/tests/meta.php b/tests/phpunit/tests/meta.php index d9e0e903dd..5d6413a5f6 100644 --- a/tests/phpunit/tests/meta.php +++ b/tests/phpunit/tests/meta.php @@ -83,6 +83,17 @@ class Tests_Meta extends WP_UnitTestCase { $this->assertFalse( metadata_exists( 'user', 1234567890, 'meta_key' ) ); } + /** + * @ticket 22746 + */ + function test_metadata_exists_with_filter() { + // Let's see if it returns the correct value when adding a filter. + add_filter( 'get_user_metadata', '__return_zero' ); + $this->assertFalse( metadata_exists( 'user', $this->author->ID, 'meta_key' ) ); // existing meta key + $this->assertFalse( metadata_exists( 'user', 1234567890, 'meta_key' ) ); + remove_filter( 'get_user_metadata', '__return_zero' ); + } + /** * @ticket 18158 */