mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2026-06-28 14:20:15 +00:00
In in_object_in_term(), only check numeric string values against term_id.
The previous `in_array()` check was playing too loose with mixed types, such that a string like '10_term_name' would incorrectly match a term_id 10. Props nobinobi, realloc. Fixes #29467. git-svn-id: https://develop.svn.wordpress.org/trunk@30205 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
@@ -81,4 +81,23 @@ class Tests_IsObjectInTerm extends WP_UnitTestCase {
|
||||
|
||||
_unregister_taxonomy( 'wptests_tax', 'post' );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 29467
|
||||
*/
|
||||
public function test_should_not_return_true_if_term_name_begins_with_existing_term_id() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$t = $this->factory->term->create( array( 'taxonomy' => 'wptests_tax' ) );
|
||||
|
||||
$post_ID = $this->factory->post->create();
|
||||
wp_set_object_terms( $post_ID, $t, 'wptests_tax' );
|
||||
|
||||
$int_tax_name = $t . '_term_name';
|
||||
|
||||
$this->assertFalse( is_object_in_term( $post_ID, 'wptests_tax', $int_tax_name ) );
|
||||
|
||||
// Verify it works properly when the post is actually in the term.
|
||||
wp_set_object_terms( $post_ID, array( $int_tax_name ), 'wptests_tax' );
|
||||
$this->assertTrue( is_object_in_term( $post_ID, 'wptests_tax', $int_tax_name ) );
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user