Order terms by 'name' when populating object term cache.
[34217] removed the `ORDER BY` clause from `update_object_term_cache()`, for improved performance. But this proved to cause problems in cases where users were expecting the results of `get_the_terms()` to be ordered by 'name'. Let's revert the change for the time being, and look into more disciplined ordering in a future release. Merges [36056] to the 4.4 branch. Props afercia. See #28922. Fixes #35180. git-svn-id: https://develop.svn.wordpress.org/branches/4.4@36057 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
509f2dc5f7
commit
9b064872d0
@ -3607,7 +3607,7 @@ function update_object_term_cache($object_ids, $object_type) {
|
||||
|
||||
$terms = wp_get_object_terms( $ids, $taxonomies, array(
|
||||
'fields' => 'all_with_object_id',
|
||||
'orderby' => 'none',
|
||||
'orderby' => 'name',
|
||||
'update_term_meta_cache' => false,
|
||||
) );
|
||||
|
||||
|
@ -616,6 +616,26 @@ class Tests_Term extends WP_UnitTestCase {
|
||||
$this->assertEqualSets( array( 0, 1 ), array_keys( $found ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 35180
|
||||
* @ticket 28922
|
||||
*/
|
||||
public function test_get_the_terms_should_return_results_ordered_by_name_when_pulling_from_cache() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$p = self::$post_ids[0];
|
||||
|
||||
$t1 = self::factory()->term->create( array( 'taxonomy' => 'wptests_tax', 'name' => 'fff' ) );
|
||||
$t2 = self::factory()->term->create( array( 'taxonomy' => 'wptests_tax', 'name' => 'aaa' ) );
|
||||
$t3 = self::factory()->term->create( array( 'taxonomy' => 'wptests_tax', 'name' => 'zzz' ) );
|
||||
|
||||
wp_set_object_terms( $p, array( $t1, $t2, $t3 ), 'wptests_tax' );
|
||||
update_object_term_cache( $p, 'post' );
|
||||
|
||||
$found = get_the_terms( $p, 'wptests_tax' );
|
||||
|
||||
$this->assertSame( array( $t2, $t1, $t3 ), wp_list_pluck( $found, 'term_id' ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 19205
|
||||
*/
|
||||
|
Loading…
Reference in New Issue
Block a user