wordpress-develop/tests/phpunit/tests/walker.php
Sergey Biryukov 3e50f2861f Code Modernization: Use a consistent check for parent items in WP_Walker.
This affects the `::walk()`, `::paged_walk()`, and `::get_number_of_root_elements()` methods.

PHP 8 changes the way string to number comparisons are performed: https://wiki.php.net/rfc/string_to_number_comparison

In particular, checking if an empty string is equal to zero in PHP 8 evaluates to `false`, not `true`.

For the `WP_Walker` class, this resulted in an incorrect handling of parent items in a few methods.

By explicitly checking for an `empty()` value instead, we make sure the check works as expected in PHP 8 and earlier versions.

Follow-up to [35876], [48960], [49043], [49076].

Props sunxiyuan, aristath, SergeyBiryukov.
Fixes #53474.

git-svn-id: https://develop.svn.wordpress.org/trunk@51204 602fd350-edb4-49c9-b593-d223f7449a82
2021-06-22 19:07:26 +00:00

340 lines
6.7 KiB
PHP

<?php
/**
* @group post
* @group menu
* @group taxonomy
* @group walker
*/
class Tests_Walker extends WP_UnitTestCase {
function setUp() {
parent::setUp();
$this->walker = new Walker_Test();
}
function test_single_item() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
);
$output = $this->walker->walk( $items, 0 );
$this->assertSame( 1, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li>', $output );
}
function test_single_item_flat() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
);
$output = $this->walker->walk( $items, -1 );
$this->assertSame( 1, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li>', $output );
}
function test_single_item_depth_1() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
);
$output = $this->walker->walk( $items, 1 );
$this->assertSame( 1, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li>', $output );
}
function test_multiple_items_single_level() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
(object) array(
'id' => 2,
'parent' => 0,
),
);
$output = $this->walker->walk( $items, 0 );
$this->assertSame( 2, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li><li>2</li>', $output );
}
function test_multiple_items_multiple_levels() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
(object) array(
'id' => 2,
'parent' => 1,
),
);
$output = $this->walker->walk( $items, 0 );
$this->assertSame( 1, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1<ul><li>2</li></ul></li>', $output );
}
function test_multiple_items_multiple_levels_flat() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
(object) array(
'id' => 2,
'parent' => 1,
),
);
$output = $this->walker->walk( $items, -1 );
$this->assertSame( 1, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li><li>2</li>', $output );
}
function test_multiple_items_multiple_levels_depth_1() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
(object) array(
'id' => 2,
'parent' => 1,
),
);
$output = $this->walker->walk( $items, 1 );
$this->assertSame( 1, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li>', $output );
}
function test_multiple_items_multiple_levels_depth_2() {
$items = array(
(object) array(
'id' => 1,
'parent' => 0,
),
(object) array(
'id' => 2,
'parent' => 1,
),
(object) array(
'id' => 3,
'parent' => 2,
),
);
$output = $this->walker->walk( $items, 2 );
$this->assertSame( 1, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1<ul><li>2</li></ul></li>', $output );
}
function test_multiple_items_recursive() {
$items = array(
(object) array(
'id' => 1,
'parent' => 2,
),
(object) array(
'id' => 2,
'parent' => 1,
),
);
$output = $this->walker->walk( $items, 0 );
$this->assertSame( 0, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1<ul><li>2</li></ul></li>', $output );
}
function test_single_item_child() {
$items = array(
(object) array(
'id' => 1,
'parent' => 3,
),
);
$output = $this->walker->walk( $items, 0 );
$this->assertSame( 0, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li>', $output );
}
function test_single_item_missing_parent_depth_1() {
$items = array(
(object) array(
'id' => 1,
'parent' => 3,
),
);
$output = $this->walker->walk( $items, 1 );
$this->assertSame( 0, $this->walker->get_number_of_root_elements( $items ) );
// It's not clear what the output of this "should" be.
// Currently the item is simply returned.
$this->assertSame( '<li>1</li>', $output );
// But as we've only asked for the first depth maybe nothing should be returned?
// $this->assertSame( '', $output );
}
function test_multiple_items_missing_parents() {
$items = array(
(object) array(
'id' => 4,
'parent' => 1,
),
(object) array(
'id' => 5,
'parent' => 2,
),
(object) array(
'id' => 6,
'parent' => 3,
),
);
$output = $this->walker->walk( $items, 0 );
$this->assertSame( 0, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>4</li><li>5</li><li>6</li>', $output );
}
function test_multiple_items_missing_parents_depth_1() {
$items = array(
(object) array(
'id' => 4,
'parent' => 1,
),
(object) array(
'id' => 5,
'parent' => 2,
),
(object) array(
'id' => 6,
'parent' => 3,
),
);
$output = $this->walker->walk( $items, 1 );
$this->assertSame( 0, $this->walker->get_number_of_root_elements( $items ) );
// It's not clear what the output of this "should" be.
// Currently the first item is simply returned.
$this->assertSame( '<li>4</li>', $output );
// But as we've only asked for the first depth maybe nothing should be returned?
// $this->assertSame( '', $output );
// Or maybe all items which are missing parents should simply be treat top level?
// $this->assertSame( '<li>4</li><li>5</li><li>6</li>', $output );
}
/**
* @ticket 53474
*/
function test_multiple_items_non_numeric_parent() {
$items = array(
(object) array(
'id' => 1,
'parent' => '',
),
(object) array(
'id' => 2,
'parent' => '',
),
);
$output = $this->walker->walk( $items, 0 );
$this->assertSame( 2, $this->walker->get_number_of_root_elements( $items ) );
$this->assertSame( '<li>1</li><li>2</li>', $output );
$output = $this->walker->paged_walk( $items, 0, 1, 1 );
$this->assertSame( '<li>1</li>', $output );
$output = $this->walker->paged_walk( $items, 0, 2, 1 );
$this->assertSame( '<li>2</li>', $output );
}
}
class Walker_Test extends Walker {
public $tree_type = 'test';
public $db_fields = array(
'parent' => 'parent',
'id' => 'id',
);
function start_lvl( &$output, $depth = 0, $args = array() ) {
$output .= '<ul>';
}
function end_lvl( &$output, $depth = 0, $args = array() ) {
$output .= '</ul>';
}
function start_el( &$output, $item, $depth = 0, $args = array(), $current_page = 0 ) {
$output .= '<li>' . $item->id;
}
function end_el( &$output, $page, $depth = 0, $args = array() ) {
$output .= '</li>';
}
}