Ticket #30335: 30335.4.patch
File 30335.4.patch, 9.0 KB (added by , 10 years ago) |
---|
-
src/wp-includes/taxonomy.php
1233 1233 " ); 1234 1234 break; 1235 1235 default: 1236 $terms = implode( ',', array_map( 'intval', $query['terms'] ) ); 1236 $terms = $query['terms']; 1237 1238 // If any passed term_ids were previously split, substitute the correct term_id. 1239 foreach ( $terms as $term_index => $term_id ) { 1240 if ( $split_term = _get_split_term( $term_id, $query['taxonomy'] ) ) { 1241 $terms[ $term_index ] = $split_term; 1242 } 1243 } 1244 1245 $terms = implode( ',', array_map( 'intval', $terms ) ); 1246 1237 1247 $terms = $wpdb->get_col( " 1238 1248 SELECT $resulting_field 1239 1249 FROM $wpdb->term_taxonomy … … 1315 1325 return null; 1316 1326 if ( ! $_term = wp_cache_get( $term, $taxonomy . ':terms:' . $incrementor ) ) { 1317 1327 $_term = $wpdb->get_row( $wpdb->prepare( "SELECT t.*, tt.* FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON t.term_id = tt.term_id WHERE tt.taxonomy = %s AND t.term_id = %d LIMIT 1", $taxonomy, $term) ); 1328 1329 // If no term is found, check whether this was a previously split term. 1330 if ( ! $_term && $old_term_id = _get_split_term( $term, $taxonomy ) ) { 1331 return get_term( $old_term_id, $taxonomy, $output, $filter ); 1332 } 1333 1318 1334 if ( ! $_term ) 1319 1335 return null; 1320 1336 wp_cache_add( $term, $_term, $taxonomy . ':terms:' . $incrementor ); … … 1675 1691 */ 1676 1692 $args = apply_filters( 'get_terms_args', $args, $taxonomies ); 1677 1693 1694 /* 1695 * For parameters that accept term_ids, check to see whether any of the IDs passed to the parameter correspond 1696 * to previously split taxonomy terms. If so, swap out the old term_id for the new one, so the query matches. 1697 */ 1698 $term_id_params = array( 'exclude', 'exclude_tree', 'include', 'parent', 'child_of' ); 1699 foreach ( $term_id_params as $term_id_param ) { 1700 if ( empty( $args[ $term_id_param ] ) ) { 1701 continue; 1702 } 1703 1704 $param_is_array = is_array( $args[ $term_id_param ] ); 1705 1706 $passed_term_ids = (array) $args[ $term_id_param ]; 1707 foreach ( $passed_term_ids as $passed_term_index => $passed_term_id ) { 1708 foreach ( $taxonomies as $taxonomy ) { 1709 if ( $split_term = _get_split_term( $passed_term_id, $taxonomy ) ) { 1710 $passed_term_ids[ $passed_term_index ] = $split_term; 1711 continue 2; 1712 } 1713 } 1714 } 1715 1716 if ( $param_is_array ) { 1717 $args[ $term_id_param ] = $passed_term_ids; 1718 } else { 1719 $args[ $term_id_param ] = $passed_term_ids[0]; 1720 } 1721 } 1722 1678 1723 $child_of = $args['child_of']; 1679 1724 if ( $child_of ) { 1680 1725 $hierarchy = _get_term_hierarchy( reset( $taxonomies ) ); … … 3903 3948 } 3904 3949 3905 3950 /** 3951 * Look up a previously split taxonomy term by its old term_id. 3952 * 3953 * Terms that have been split by _split_shared_term() are stored, so that 3954 * attempts to retrieve terms by the previous term_id still work. 3955 * 3956 * @since 4.1.0 3957 * @access private 3958 * 3959 * @param int $old_term_id Old, pre-split term_id. 3960 * @param string $taxonomy Taxonomy name. 3961 */ 3962 function _get_split_term( $old_term_id, $taxonomy ) { 3963 $split_terms = get_option( '_split_terms_' . $taxonomy ); 3964 3965 return ! empty( $split_terms[ $old_term_id ] ) ? $split_terms[ $old_term_id ] : null; 3966 } 3967 3968 /** 3906 3969 * Add count of children to parent count. 3907 3970 * 3908 3971 * Recalculates term counts by including items from child terms. Assumes all … … 4115 4178 clean_term_cache( $term_id, $shared_term_taxonomy ); 4116 4179 } 4117 4180 4181 // Keep a record of term_ids that have been split, keyed by old term_id. 4182 $split_term_data = get_option( '_split_terms_' . $term_taxonomy->taxonomy, array() ); 4183 $split_term_data[ $term_id ] = $new_term_id; 4184 if ( false === get_option( '_split_terms_' . $term_taxonomy->taxonomy, false ) ) { 4185 add_option( '_split_terms_' . $term_taxonomy->taxonomy, $split_term_data, '', 'no' ); 4186 } else { 4187 update_option( '_split_terms_' . $term_taxonomy->taxonomy, $split_term_data ); 4188 } 4189 4118 4190 /** 4119 4191 * Fires after a previously shared taxonomy term is split into two separate terms. 4120 4192 * -
tests/phpunit/tests/term/splitSharedTerm.php
4 4 * @group taxonomy 5 5 */ 6 6 class Tests_Term_SplitSharedTerm extends WP_UnitTestCase { 7 protected $t t_ids = array();7 protected $terms = array(); 8 8 9 9 public function setUp() { 10 10 global $wpdb; … … 40 40 'parent' => $t1['term_id'], 41 41 ) ); 42 42 43 $this->t t_ids = array(44 't1' => $t1 ['term_taxonomy_id'],45 't2' => $t2 ['term_taxonomy_id'],46 't3' => $t3 ['term_taxonomy_id'],47 't2_child' => $t2_child ['term_taxonomy_id'],43 $this->terms = array( 44 't1' => $t1, 45 't2' => $t2, 46 't3' => $t3, 47 't2_child' => $t2_child, 48 48 ); 49 49 50 50 _split_shared_term( $t1['term_id'], $t2['term_taxonomy_id'] ); … … 55 55 * @ticket 5809 56 56 */ 57 57 public function test_should_create_new_term_ids() { 58 $t1_term = get_term_by( 'term_taxonomy_id', $this->t t_ids['t1'], 'wptests_tax' );59 $t2_term = get_term_by( 'term_taxonomy_id', $this->t t_ids['t2'], 'wptests_tax_2' );60 $t3_term = get_term_by( 'term_taxonomy_id', $this->t t_ids['t3'], 'wptests_tax_3' );58 $t1_term = get_term_by( 'term_taxonomy_id', $this->terms['t1']['term_taxonomy_id'], 'wptests_tax' ); 59 $t2_term = get_term_by( 'term_taxonomy_id', $this->terms['t2']['term_taxonomy_id'], 'wptests_tax_2' ); 60 $t3_term = get_term_by( 'term_taxonomy_id', $this->terms['t3']['term_taxonomy_id'], 'wptests_tax_3' ); 61 61 62 62 $this->assertNotEquals( $t1_term->term_id, $t2_term->term_id ); 63 63 $this->assertNotEquals( $t1_term->term_id, $t3_term->term_id ); … … 68 68 * @ticket 5809 69 69 */ 70 70 public function test_should_retain_child_terms_when_using_get_terms_parent() { 71 $t2_term = get_term_by( 'term_taxonomy_id', $this->t t_ids['t2'], 'wptests_tax_2' );71 $t2_term = get_term_by( 'term_taxonomy_id', $this->terms['t2']['term_taxonomy_id'], 'wptests_tax_2' ); 72 72 $children = get_terms( 'wptests_tax_2', array( 73 73 'parent' => $t2_term->term_id, 74 74 'hide_empty' => false, 75 75 ) ); 76 76 77 $this->assertEquals( $this->t t_ids['t2_child'], $children[0]->term_taxonomy_id );77 $this->assertEquals( $this->terms['t2_child']['term_taxonomy_id'], $children[0]->term_taxonomy_id ); 78 78 } 79 79 80 80 /** 81 81 * @ticket 5809 82 82 */ 83 83 public function test_should_retain_child_terms_when_using_get_terms_child_of() { 84 $t2_term = get_term_by( 'term_taxonomy_id', $this->t t_ids['t2'], 'wptests_tax_2' );84 $t2_term = get_term_by( 'term_taxonomy_id', $this->terms['t2']['term_taxonomy_id'], 'wptests_tax_2' ); 85 85 $children = get_terms( 'wptests_tax_2', array( 86 86 'child_of' => $t2_term->term_id, 87 87 'hide_empty' => false, 88 88 ) ); 89 89 90 $this->assertEquals( $this->t t_ids['t2_child'], $children[0]->term_taxonomy_id );90 $this->assertEquals( $this->terms['t2_child']['term_taxonomy_id'], $children[0]->term_taxonomy_id ); 91 91 } 92 92 93 93 /** … … 121 121 $t2_children = get_term_children( $t2['term_id'], 'wptests_tax_4' ); 122 122 $this->assertEquals( array( $new_term_id ), $t2_children ); 123 123 } 124 125 /** 126 * @ticket 30335 127 */ 128 public function test_should_remain_available_at_old_term_id_using_get_term_by() { 129 $t2_term = get_term_by( 'term_taxonomy_id', $this->terms['t2']['term_taxonomy_id'], 'wptests_tax_2' ); 130 131 $this->assertEquals( $t2_term, get_term_by( 'id', $this->terms['t1']['term_id'], 'wptests_tax_2' ) ); 132 } 133 134 /** 135 * @ticket 30335 136 */ 137 public function test_should_remain_available_at_old_term_id_using_get_term() { 138 $t2_term = get_term_by( 'term_taxonomy_id', $this->terms['t2']['term_taxonomy_id'], 'wptests_tax_2' ); 139 140 $this->assertEquals( $t2_term, get_term( intval( $this->terms['t1']['term_id'] ), 'wptests_tax_2' ) ); 141 } 142 143 /** 144 * @ticket 30335 145 */ 146 public function test_should_remain_available_at_old_term_id_using_get_terms_with_parent_param() { 147 $found = get_terms( 'wptests_tax_2', array( 148 'parent' => $this->terms['t1']['term_id'], 149 'hide_empty' => false, 150 ) ); 151 $this->assertEquals( $this->terms['t2_child']['term_id'], $found[0]->term_id ); 152 } 153 154 /** 155 * @ticket 30335 156 */ 157 public function test_should_remain_available_at_old_term_id_using_get_terms_with_include_param() { 158 $t2_term = get_term_by( 'term_taxonomy_id', $this->terms['t2']['term_taxonomy_id'], 'wptests_tax_2' ); 159 160 $found = get_terms( 'wptests_tax_2', array( 161 'include' => array( $this->terms['t1']['term_id'] ), 162 'hide_empty' => false, 163 ) ); 164 $this->assertEquals( $t2_term->term_id, $found[0]->term_id ); 165 } 166 167 /** 168 * @ticket 30335 169 */ 170 public function test_should_remain_available_at_old_term_id_using_tax_query() { 171 $t2_term = get_term_by( 'term_taxonomy_id', $this->terms['t2']['term_taxonomy_id'], 'wptests_tax_2' ); 172 173 $tq = new WP_Tax_Query( array( 174 array( 175 'field' => 'term_id', 176 'taxonomy' => 'wptests_tax_2', 177 'terms' => array( $this->terms['t1']['term_id'] ), 178 ), 179 ) ); 180 $tq->transform_query( $tq->queries[0], 'term_taxonomy_id' ); 181 182 $this->assertEquals( array( $t2_term->term_taxonomy_id ), $tq->queries[0]['terms'] ); 183 } 124 184 }