In `WP_Query::parse_tax_query()`, allow taxonomy querystring to be formatted as an array.
Props Veraxus. Fixes #32454. git-svn-id: https://develop.svn.wordpress.org/trunk@33095 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
17854c6464
commit
53021ef6fe
|
@ -1867,6 +1867,10 @@ class WP_Query {
|
||||||
|
|
||||||
$term = $q[$t->query_var];
|
$term = $q[$t->query_var];
|
||||||
|
|
||||||
|
if ( is_array( $term ) ) {
|
||||||
|
$term = implode( ',', $term );
|
||||||
|
}
|
||||||
|
|
||||||
if ( strpos($term, '+') !== false ) {
|
if ( strpos($term, '+') !== false ) {
|
||||||
$terms = preg_split( '/[+]+/', $term );
|
$terms = preg_split( '/[+]+/', $term );
|
||||||
foreach ( $terms as $term ) {
|
foreach ( $terms as $term ) {
|
||||||
|
|
|
@ -133,4 +133,83 @@ class Tests_Query extends WP_UnitTestCase {
|
||||||
|
|
||||||
$this->assertContains( "ORDER BY $wpdb->posts.post_title DESC, $wpdb->posts.post_date DESC", $q->request );
|
$this->assertContains( "ORDER BY $wpdb->posts.post_title DESC, $wpdb->posts.post_date DESC", $q->request );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_custom_taxonomy_querystring_single_term() {
|
||||||
|
register_taxonomy( 'test_tax_cat', 'post' );
|
||||||
|
|
||||||
|
wp_insert_term( 'test1', 'test_tax_cat' );
|
||||||
|
wp_insert_term( 'test2', 'test_tax_cat' );
|
||||||
|
wp_insert_term( 'test3', 'test_tax_cat' );
|
||||||
|
|
||||||
|
$p1 = $this->factory->post->create();
|
||||||
|
$p2 = $this->factory->post->create();
|
||||||
|
$p3 = $this->factory->post->create();
|
||||||
|
|
||||||
|
wp_set_object_terms( $p1, 'test1', 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p2, array( 'test1', 'test2' ), 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p3, 'test2', 'test_tax_cat' );
|
||||||
|
|
||||||
|
$url = add_query_arg( array(
|
||||||
|
'test_tax_cat' => 'test1',
|
||||||
|
), '/' );
|
||||||
|
|
||||||
|
$this->go_to( $url );
|
||||||
|
|
||||||
|
$this->assertEquals( array( $p1, $p2 ), wp_list_pluck( $GLOBALS['wp_query']->posts, 'ID' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_custom_taxonomy_querystring_multiple_terms_comma_separated() {
|
||||||
|
register_taxonomy( 'test_tax_cat', 'post' );
|
||||||
|
|
||||||
|
wp_insert_term( 'test1', 'test_tax_cat' );
|
||||||
|
wp_insert_term( 'test2', 'test_tax_cat' );
|
||||||
|
wp_insert_term( 'test3', 'test_tax_cat' );
|
||||||
|
|
||||||
|
$p1 = $this->factory->post->create();
|
||||||
|
$p2 = $this->factory->post->create();
|
||||||
|
$p3 = $this->factory->post->create();
|
||||||
|
$p4 = $this->factory->post->create();
|
||||||
|
|
||||||
|
wp_set_object_terms( $p1, 'test1', 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p2, array( 'test1', 'test2' ), 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p3, 'test2', 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p4, "test3", 'test_tax_cat' );
|
||||||
|
|
||||||
|
$url = add_query_arg( array(
|
||||||
|
'test_tax_cat' => 'test1,test2',
|
||||||
|
), '/' );
|
||||||
|
|
||||||
|
$this->go_to( $url );
|
||||||
|
|
||||||
|
$this->assertEquals( array( $p1, $p2, $p3 ), wp_list_pluck( $GLOBALS['wp_query']->posts, 'ID' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ticket 32454
|
||||||
|
*/
|
||||||
|
public function test_custom_taxonomy_querystring_multiple_terms_formatted_as_array() {
|
||||||
|
register_taxonomy( 'test_tax_cat', 'post' );
|
||||||
|
|
||||||
|
wp_insert_term( 'test1', 'test_tax_cat' );
|
||||||
|
wp_insert_term( 'test2', 'test_tax_cat' );
|
||||||
|
wp_insert_term( 'test3', 'test_tax_cat' );
|
||||||
|
|
||||||
|
$p1 = $this->factory->post->create();
|
||||||
|
$p2 = $this->factory->post->create();
|
||||||
|
$p3 = $this->factory->post->create();
|
||||||
|
$p4 = $this->factory->post->create();
|
||||||
|
|
||||||
|
wp_set_object_terms( $p1, 'test1', 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p2, array( 'test1', 'test2' ), 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p3, 'test2', 'test_tax_cat' );
|
||||||
|
wp_set_object_terms( $p4, "test3", 'test_tax_cat' );
|
||||||
|
|
||||||
|
$url = add_query_arg( array(
|
||||||
|
'test_tax_cat' => array( 'test1', 'test2' ),
|
||||||
|
), '/' );
|
||||||
|
|
||||||
|
$this->go_to( $url );
|
||||||
|
|
||||||
|
$this->assertEquals( array( $p1, $p2, $p3 ), wp_list_pluck( $GLOBALS['wp_query']->posts, 'ID' ) );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue