c1b8f1f72a
As of [32484], `wp_dropdown_categories()` uses the `$value_field` value to decide whether a given `<option>` should be 'selected'. However, `$value_field` can refer to a value that is a string, such as a category's slug. This causes problems when doing a loose comparison (`==`) with the value of the `'selected'` parameter, which defaults to `0`, because when doing a loose comparison between an integer and a string, PHP will cast the string to an integer. This creates false matches, resulting in `<option>` elements getting a 'selected' attribute incorrectly. We address the issue by casting the comparison values to strings, and then using the strict comparison operator `===`. Fixes #33452 for trunk. git-svn-id: https://develop.svn.wordpress.org/trunk@33681 602fd350-edb4-49c9-b593-d223f7449a82
398 lines
12 KiB
PHP
398 lines
12 KiB
PHP
<?php
|
|
/**
|
|
* Validate Category API
|
|
*
|
|
* Notes:
|
|
* cat_is_ancestor_of is validated under test\term\term_is_ancestor_of
|
|
*
|
|
* @group category.php
|
|
*/
|
|
class Tests_Category extends WP_UnitTestCase {
|
|
|
|
function tearDown() {
|
|
_unregister_taxonomy( 'test_tax_cat' );
|
|
parent::tearDown();
|
|
}
|
|
|
|
/**
|
|
* Validate get_all_category_ids
|
|
*
|
|
* @expectedDeprecated get_all_category_ids
|
|
*/
|
|
function test_get_all_category_ids() {
|
|
// create categories
|
|
$this->factory->category->create_many(15);
|
|
|
|
// create new taxonomy to ensure not included
|
|
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' );
|
|
|
|
// Validate length is 1 + created due to uncategorized
|
|
$cat_ids = get_all_category_ids();
|
|
$this->assertEquals( 16, count($cat_ids));
|
|
}
|
|
|
|
/**
|
|
* Validate get_category_by_slug function
|
|
*/
|
|
function test_get_category_by_slug() {
|
|
|
|
// create Test Categories
|
|
$testcat = $this->factory->category->create_and_get(
|
|
array(
|
|
'slug' => 'testcat',
|
|
'name' => 'Test Category 1'
|
|
)
|
|
);
|
|
$testcat2 = $this->factory->category->create_and_get(
|
|
array(
|
|
'slug' => 'testcat2',
|
|
'name' => 'Test Category 2'
|
|
)
|
|
);
|
|
|
|
// validate category is returned by slug
|
|
$ret_testcat = get_category_by_slug( 'testcat' );
|
|
$this->assertEquals( $testcat->term_id, $ret_testcat->term_id );
|
|
$ret_testcat = get_category_by_slug( 'TeStCaT' );
|
|
$this->assertEquals( $testcat->term_id, $ret_testcat->term_id );
|
|
|
|
// validate unknown category returns false
|
|
$this->assertFalse( get_category_by_slug( 'testcat3' ) );
|
|
|
|
}
|
|
|
|
/**
|
|
* Validate _make_cat_compat function
|
|
*/
|
|
function test__make_cat_compat() {
|
|
|
|
// create Test Categories and Array Representations
|
|
$testcat_array = array(
|
|
'slug' => 'testmcc',
|
|
'name' => 'Test MCC',
|
|
'description' => 'Category Test'
|
|
);
|
|
$testcat = $this->factory->category->create_and_get( $testcat_array );
|
|
$testcat_array['term_id'] = $testcat->term_id;
|
|
|
|
$testcat2_array = array(
|
|
'slug' => 'testmcc',
|
|
'name' => 'Test MCC',
|
|
'description' => 'Category Test',
|
|
'parent' => $testcat->term_id
|
|
);
|
|
$testcat2 = $this->factory->category->create_and_get( $testcat2_array );
|
|
$testcat2_array['term_id'] = $testcat2->term_id;
|
|
|
|
// unset properties to enable validation of object
|
|
unset( $testcat->cat_ID );
|
|
unset( $testcat->category_count );
|
|
unset( $testcat->category_description );
|
|
unset( $testcat->cat_name );
|
|
unset( $testcat->category_nicename );
|
|
unset( $testcat->category_parent );
|
|
|
|
unset( $testcat2->cat_ID );
|
|
unset( $testcat2->category_count );
|
|
unset( $testcat2->category_description );
|
|
unset( $testcat2->cat_name );
|
|
unset( $testcat2->category_nicename );
|
|
unset( $testcat2->category_parent );
|
|
|
|
// make Compatible
|
|
_make_cat_compat( $testcat );
|
|
_make_cat_compat( $testcat2 );
|
|
_make_cat_compat( $testcat_array );
|
|
_make_cat_compat( $testcat2_array );
|
|
|
|
// Validate Compatibility Object
|
|
$this->assertEquals( $testcat->cat_ID, $testcat->term_id );
|
|
$this->assertEquals( $testcat->category_count, $testcat->count );
|
|
$this->assertEquals( $testcat->category_description, $testcat->description );
|
|
$this->assertEquals( $testcat->cat_name, $testcat->name );
|
|
$this->assertEquals( $testcat->category_nicename, $testcat->slug );
|
|
$this->assertEquals( $testcat->category_parent, $testcat->parent );
|
|
|
|
// Validate Compatibility Object with Parent
|
|
$this->assertEquals( $testcat->cat_ID, $testcat->term_id );
|
|
$this->assertEquals( $testcat->category_count, $testcat->count );
|
|
$this->assertEquals( $testcat->category_description, $testcat->description );
|
|
$this->assertEquals( $testcat->cat_name, $testcat->name );
|
|
$this->assertEquals( $testcat->category_nicename, $testcat->slug );
|
|
$this->assertEquals( $testcat->category_parent, $testcat->parent );
|
|
|
|
// Validate Compatibility Array
|
|
$this->assertEquals( $testcat_array['cat_ID'], $testcat_array['term_id'] );
|
|
$this->assertEquals( $testcat_array['category_count'], $testcat_array['count'] );
|
|
$this->assertEquals( $testcat_array['category_description'], $testcat_array['description'] );
|
|
$this->assertEquals( $testcat_array['cat_name'], $testcat_array['name'] );
|
|
$this->assertEquals( $testcat_array['category_nicename'], $testcat_array['slug'] );
|
|
$this->assertEquals( $testcat_array['category_parent'], $testcat_array['parent'] );
|
|
|
|
// Validate Compatibility Array with Parent
|
|
$this->assertEquals( $testcat_array['cat_ID'], $testcat_array['term_id'] );
|
|
$this->assertEquals( $testcat_array['category_count'], $testcat_array['count'] );
|
|
$this->assertEquals( $testcat_array['category_description'], $testcat_array['description'] );
|
|
$this->assertEquals( $testcat_array['cat_name'], $testcat_array['name'] );
|
|
$this->assertEquals( $testcat_array['category_nicename'], $testcat_array['slug'] );
|
|
$this->assertEquals( $testcat_array['category_parent'], $testcat_array['parent'] );
|
|
}
|
|
|
|
/**
|
|
* Validate get_cat_name function
|
|
*/
|
|
function test_get_cat_name() {
|
|
|
|
// create Test Category
|
|
$testcat = $this->factory->category->create_and_get(
|
|
array(
|
|
'slug' => 'testcat',
|
|
'name' => 'Test Category 1'
|
|
)
|
|
);
|
|
|
|
// Validate
|
|
$this->assertEquals( $testcat->name, get_cat_name( $testcat->term_id ) );
|
|
$this->assertEquals( '', get_cat_name( -1 ) );
|
|
$this->assertEquals( '', get_cat_name( $testcat->term_id + 100 ) );
|
|
|
|
}
|
|
|
|
/**
|
|
* Validate get_cat_name function
|
|
*/
|
|
function test_get_cat_ID() {
|
|
|
|
// create Test Category
|
|
$testcat = $this->factory->category->create_and_get(
|
|
array(
|
|
'slug' => 'testcat',
|
|
'name' => 'Test Category 1'
|
|
)
|
|
);
|
|
|
|
// Validate
|
|
$this->assertEquals( $testcat->term_id, get_cat_ID( $testcat->name ) );
|
|
$this->assertEquals( 0, get_cat_ID( "NO CAT" ) );
|
|
$this->assertEquals( 0, get_cat_ID( 12 ) );
|
|
|
|
}
|
|
|
|
/**
|
|
* Validate get_category_by_path function
|
|
*/
|
|
function test_get_category_by_path() {
|
|
|
|
// create Test Categories
|
|
$root_id = $this->factory->category->create(
|
|
array(
|
|
'slug' => 'root',
|
|
)
|
|
);
|
|
$root_cat_id = $this->factory->category->create(
|
|
array(
|
|
'slug' => 'cat',
|
|
'parent' => $root_id
|
|
)
|
|
);
|
|
$root_cat_cat_id = $this->factory->category->create(
|
|
array(
|
|
'slug' => 'cat', //note this is modified on create
|
|
'parent' => $root_cat_id
|
|
)
|
|
);
|
|
$root_path_id = $this->factory->category->create(
|
|
array(
|
|
'slug' => 'path',
|
|
'parent' => $root_id
|
|
)
|
|
);
|
|
$root_path_cat_id = $this->factory->category->create(
|
|
array(
|
|
'slug' => 'cat', //note this is modified on create
|
|
'parent' => $root_path_id
|
|
)
|
|
);
|
|
$root_level_id = $this->factory->category->create(
|
|
array(
|
|
'slug' => 'level-1',
|
|
'parent' => $root_id
|
|
)
|
|
);
|
|
$root_level_cat_id = $this->factory->category->create(
|
|
array(
|
|
'slug' => 'cat', //note this is modified on create
|
|
'parent' => $root_level_id
|
|
)
|
|
);
|
|
|
|
// Validate Full Match
|
|
$ret_cat = get_category_by_path( '/root/level-1', true );
|
|
$this->assertEquals( $root_level_id, $ret_cat->term_id );
|
|
$this->assertNull( get_category_by_path( 'level-1', true ) );
|
|
$this->assertNull( get_category_by_path( 'nocat/nocat/', true) );
|
|
|
|
// Validate Partial Match
|
|
$ret_cat = get_category_by_path( 'level-1', false );
|
|
$this->assertEquals( $root_level_id, $ret_cat->term_id );
|
|
$ret_cat = get_category_by_path( 'root/cat/level-1', false );
|
|
$this->assertEquals( $root_level_id, $ret_cat->term_id );
|
|
$ret_cat = get_category_by_path( 'root$2Fcat%20%2Flevel-1', false );
|
|
$this->assertEquals( $root_level_id, $ret_cat->term_id );
|
|
$this->assertNull( get_category_by_path( 'nocat/nocat/', false) );
|
|
}
|
|
|
|
/**
|
|
* @ticket 30306
|
|
*/
|
|
public function test_wp_dropdown_categories_value_field_should_default_to_term_id() {
|
|
// Create a test category.
|
|
$cat_id = $this->factory->category->create( array(
|
|
'name' => 'Test Category',
|
|
'slug' => 'test_category',
|
|
) );
|
|
|
|
// Get the default functionality of wp_dropdown_categories().
|
|
$dropdown_default = wp_dropdown_categories( array(
|
|
'echo' => 0,
|
|
'hide_empty' => 0,
|
|
) );
|
|
|
|
// Test to see if it returns the default with the category ID.
|
|
$this->assertContains( 'value="' . $cat_id . '"', $dropdown_default );
|
|
}
|
|
|
|
/**
|
|
* @ticket 30306
|
|
*/
|
|
public function test_wp_dropdown_categories_value_field_term_id() {
|
|
// Create a test category.
|
|
$cat_id = $this->factory->category->create( array(
|
|
'name' => 'Test Category',
|
|
'slug' => 'test_category',
|
|
) );
|
|
|
|
// Get the default functionality of wp_dropdown_categories().
|
|
$found = wp_dropdown_categories( array(
|
|
'echo' => 0,
|
|
'hide_empty' => 0,
|
|
'value_field' => 'term_id',
|
|
) );
|
|
|
|
// Test to see if it returns the default with the category ID.
|
|
$this->assertContains( 'value="' . $cat_id . '"', $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 30306
|
|
*/
|
|
public function test_wp_dropdown_categories_value_field_slug() {
|
|
// Create a test category.
|
|
$cat_id = $this->factory->category->create( array(
|
|
'name' => 'Test Category',
|
|
'slug' => 'test_category',
|
|
) );
|
|
|
|
// Get the default functionality of wp_dropdown_categories().
|
|
$found = wp_dropdown_categories( array(
|
|
'echo' => 0,
|
|
'hide_empty' => 0,
|
|
'value_field' => 'slug',
|
|
) );
|
|
|
|
// Test to see if it returns the default with the category slug.
|
|
$this->assertContains( 'value="test_category"', $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 30306
|
|
*/
|
|
public function test_wp_dropdown_categories_value_field_should_fall_back_on_term_id_when_an_invalid_value_is_provided() {
|
|
// Create a test category.
|
|
$cat_id = $this->factory->category->create( array(
|
|
'name' => 'Test Category',
|
|
'slug' => 'test_category',
|
|
) );
|
|
|
|
// Get the default functionality of wp_dropdown_categories().
|
|
$found = wp_dropdown_categories( array(
|
|
'echo' => 0,
|
|
'hide_empty' => 0,
|
|
'value_field' => 'foo',
|
|
) );
|
|
|
|
// Test to see if it returns the default with the category slug.
|
|
$this->assertContains( 'value="' . $cat_id . '"', $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 32330
|
|
*/
|
|
public function test_wp_dropdown_categories_selected_should_respect_custom_value_field() {
|
|
$c1 = $this->factory->category->create( array(
|
|
'name' => 'Test Category 1',
|
|
'slug' => 'test_category_1',
|
|
) );
|
|
|
|
$c2 = $this->factory->category->create( array(
|
|
'name' => 'Test Category 2',
|
|
'slug' => 'test_category_2',
|
|
) );
|
|
|
|
$found = wp_dropdown_categories( array(
|
|
'echo' => 0,
|
|
'hide_empty' => 0,
|
|
'value_field' => 'slug',
|
|
'selected' => 'test_category_2',
|
|
) );
|
|
|
|
$this->assertContains( "value=\"test_category_2\" selected=\"selected\"", $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 33452
|
|
*/
|
|
public function test_wp_dropdown_categories_show_option_all_should_be_selected_if_no_selected_value_is_explicitly_passed_and_value_field_does_not_have_string_values() {
|
|
$cats = $this->factory->category->create_many( 3 );
|
|
|
|
$found = wp_dropdown_categories( array(
|
|
'echo' => 0,
|
|
'hide_empty' => 0,
|
|
'show_option_all' => 'Foo',
|
|
'value_field' => 'slug',
|
|
) );
|
|
|
|
$this->assertContains( "value='0' selected='selected'", $found );
|
|
|
|
foreach ( $cats as $cat ) {
|
|
$_cat = get_term( $cat, 'category' );
|
|
$this->assertNotContains( 'value="' . $_cat->slug . '" selected="selected"', $found );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @ticket 33452
|
|
*/
|
|
public function test_wp_dropdown_categories_show_option_all_should_be_selected_if_selected_value_of_0_string_is_explicitly_passed_and_value_field_does_not_have_string_values() {
|
|
$cats = $this->factory->category->create_many( 3 );
|
|
|
|
$found = wp_dropdown_categories( array(
|
|
'echo' => 0,
|
|
'hide_empty' => 0,
|
|
'show_option_all' => 'Foo',
|
|
'value_field' => 'slug',
|
|
'selected' => '0',
|
|
) );
|
|
|
|
$this->assertContains( "value='0' selected='selected'", $found );
|
|
|
|
foreach ( $cats as $cat ) {
|
|
$_cat = get_term( $cat, 'category' );
|
|
$this->assertNotContains( 'value="' . $_cat->slug . '" selected="selected"', $found );
|
|
}
|
|
}
|
|
}
|