home | career | drupal | java | mac | mysql | perl | php | scala | uml | unix

Drupal example source code file (views_pager.test)

This example Drupal source code file (views_pager.test) is included in the DevDaily.com "Drupal Source Code Warehouse" project. The intent of this project is to help you "Learn Drupal by Example".

PHP - Drupal tags/keywords

array, default, edit, false, function, items, node, none, pager, php, public, return, to, view

The views_pager.test Drupal example source code

<?php
// $Id: views_pager.test,v 1.1.2.6 2010/10/12 20:59:02 merlinofchaos Exp $
/**
 * @file
 *   Tests the pluggable pager system
 */

class ViewsPagerTest extends DrupalWebTestCase {
  public static function getInfo() {
    return array(
      'name' => 'Pager',
      'description' => 'Test the pluggable pager system',
      'group' => 'Views Plugins',
    );
  }

  public function setUp() {
    parent::setUp('views', 'views_ui', 'views_test');
  }

  /**
   * Pagers was sometimes not stored.
   *
   * See: http://drupal.org/node/652712.
   */
  public function testStorePagerSettings() {
    $admin_user = $this->drupalCreateUser(array('administer views', 'administer site configuration'));
    $this->drupalLogin($admin_user);
    // Test behaviour described in http://drupal.org/node/652712#comment-2354918.

    $this->drupalGet('admin/structure/views/edit/frontpage');


    $edit = array(
      'pager_options[items_per_page]' => 20,
    );
    $this->drupalPost('admin/structure/views/nojs/display/frontpage/default/pager_options', $edit, t('Update'));
    $this->assertText('20 items');

    // Change type and check whether the type is new type is stored.
    $edit = array();
    $edit = array(
      'pager[type]' => 'mini',
    );
    $this->drupalPost('admin/structure/views/nojs/display/frontpage/default/pager', $edit, t('Update'));
    $this->drupalGet('admin/structure/views/edit/frontpage');
    $this->assertText('Mini pager', 'Changed pager plugin, should change some text');

    // Test behaviour described in http://drupal.org/node/652712#comment-2354400
    $view = $this->viewsStorePagerSettings();
    // Make it editable in the admin interface.
    $view->save();

    $this->drupalGet('admin/structure/views/test_store_pager_settings');

    $edit = array();
    $edit = array(
      'pager[type]' => 'full',
    );
    $this->drupalPost('admin/structure/views/nojs/display/test_store_pager_settings/default/pager', $edit, t('Update'));
    $this->drupalGet('admin/structure/views/edit/test_store_pager_settings');
    $this->assertText('Paged');

    $edit = array(
      'pager_options[items_per_page]' => 20,
    );
    $this->drupalPost('admin/structure/views/nojs/display/test_store_pager_settings/default/pager_options', $edit, t('Update'));
    $this->assertText('20 items');

    // add new display and test the settings again, by override it.
    $edit = array(
      'display' => 'page',
    );
    // Add a display and override the pager settings.
    $this->drupalPost('admin/structure/views/edit/test_store_pager_settings', $edit, t('Add display'));
    $this->drupalPost('admin/structure/views/nojs/display/test_store_pager_settings/page_1/pager', array(), t('Override'));

    $edit = array(
      'pager[type]' => 'mini',
    );
    $this->drupalPost('admin/structure/views/nojs/display/test_store_pager_settings/page_1/pager', $edit, t('Update'));
    $this->drupalGet('admin/structure/views/edit/test_store_pager_settings');
    $this->assertText('Mini pager', 'Changed pager plugin, should change some text');

    $edit = array(
      'pager_options[items_per_page]' => 10,
    );
    $this->drupalPost('admin/structure/views/nojs/display/test_store_pager_settings/default/pager_options', $edit, t('Update'));
    $this->assertText('20 items');

  }

  public function viewsStorePagerSettings() {
    $view = new view;
    $view->name = 'test_store_pager_settings';
    $view->description = '';
    $view->tag = '';
    $view->view_php = '';
    $view->base_table = 'node';
    $view->is_cacheable = FALSE;
    $view->api_version = 2;
    $view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */

    /* Display: Defaults */
    $handler = $view->new_display('default', 'Defaults', 'default');
    $handler->display->display_options['access']['type'] = 'none';
    $handler->display->display_options['cache']['type'] = 'none';
    $handler->display->display_options['exposed_form']['type'] = 'basic';
    $handler->display->display_options['pager']['type'] = 'none';
    $handler->display->display_options['style_plugin'] = 'default';
    $handler->display->display_options['row_plugin'] = 'node';
    return $view;
  }

  /**
   * Test the none-pager-query.
   */
  public function testNoLimit() {
    // Create 11 nodes and take sure that everyone is returned.
    // We create 11 nodes, because the default pager plugin had 10 items per page.
    for ($i = 0; $i < 11; $i++) {
      $this->drupalCreateNode();
    }
    $view = $this->viewsPagerNoLimit();
    $view->set_display('default');
    $view->pre_execute();
    $view->execute();
    $this->assertEqual(count($view->result), 11, 'Take sure that every item is returned in the result');

    $view->destroy();

    // Setup and test a offset.
    $view = $this->viewsPagerNoLimit();
    $view->set_display('default');

    $pager = array(
      'type' => 'none',
      'options' => array(
        'offset' => 3,
      ),
    );
    $view->display_handler->set_option('pager', $pager);
    $view->pre_execute();
    $view->execute();

    $this->assertEqual(count($view->result), 8, 'Take sure that every item beside the first three is returned in the result');

    // Check some public functions.
    $this->assertFalse($view->query->pager->use_pager());
    $this->assertFalse($view->query->pager->use_count_query());
    $this->assertEqual($view->query->pager->get_items_per_page(), 0);
  }

  public function viewsPagerNoLimit() {
    $view = new view;
    $view->name = 'test_pager_none';
    $view->description = '';
    $view->tag = '';
    $view->view_php = '';
    $view->base_table = 'node';
    $view->is_cacheable = FALSE;
    $view->api_version = 2;
    $view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */

    /* Display: Defaults */
    $handler = $view->new_display('default', 'Defaults', 'default');
    $handler->display->display_options['access']['type'] = 'none';
    $handler->display->display_options['cache']['type'] = 'none';
    $handler->display->display_options['exposed_form']['type'] = 'basic';
    $handler->display->display_options['pager']['type'] = 'none';
    $handler->display->display_options['style_plugin'] = 'default';
    $handler->display->display_options['row_plugin'] = 'node';
    return $view;
  }

  /**
   * Test the some pager plugin.
   */
  public function testLimit() {
    // Create 11 nodes and take sure that everyone is returned.
    // We create 11 nodes, because the default pager plugin had 10 items per page.
    for ($i = 0; $i < 11; $i++) {
      $this->drupalCreateNode();
    }
    $view = $this->viewsPagerLimit();
    $view->set_display('default');
    $view->execute();
    $this->assertEqual(count($view->result), 5, 'Take sure that only a certain count of items is returned');
    $view->destroy();

    // Setup and test a offset.
    $view = $this->viewsPagerLimit();
    $view->set_display('default');

    $pager = array(
      'type' => 'none',
      'options' => array(
        'offset' => 8,
        'items_per_page' => 5,
      ),
    );
    $view->display_handler->set_option('pager', $pager);
    $view->pre_execute();
    $view->execute();
    $this->assertEqual(count($view->result), 3, 'Take sure that only a certain count of items is returned');

    // Check some public functions.
    $this->assertFalse($view->query->pager->use_pager());
    $this->assertFalse($view->query->pager->use_count_query());
  }

  public function viewsPagerLimit() {
    $view = new view;
    $view->name = 'test_pager_some';
    $view->description = '';
    $view->tag = '';
    $view->view_php = '';
    $view->base_table = 'node';
    $view->is_cacheable = FALSE;
    $view->api_version = 2;
    $view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */

    /* Display: Defaults */
    $handler = $view->new_display('default', 'Defaults', 'default');
    $handler->display->display_options['access']['type'] = 'none';
    $handler->display->display_options['cache']['type'] = 'none';
    $handler->display->display_options['exposed_form']['type'] = 'basic';
    $handler->display->display_options['pager']['type'] = 'some';
    $handler->display->display_options['pager']['options']['offset'] = 0;
    $handler->display->display_options['pager']['options']['items_per_page'] = 5;
    $handler->display->display_options['style_plugin'] = 'default';
    $handler->display->display_options['row_plugin'] = 'node';
    return $view;
  }

  /**
   * Test the normal pager.
   */
  public function testNormalPager() {
    // Create 11 nodes and take sure that everyone is returned.
    // We create 11 nodes, because the default pager plugin had 10 items per page.
    for ($i = 0; $i < 11; $i++) {
      $this->drupalCreateNode();
    }
    $view = $this->viewsPagerFull();
    $view->set_display('default');
    $view->pre_execute();
    $view->execute();
    $this->assertEqual(count($view->result), 5, 'Take sure that only a certain count of items is returned');
    $view->destroy();

    // Setup and test a offset.
    $view = $this->viewsPagerFull();
    $view->set_display('default');

    $pager = array(
      'type' => 'full',
      'options' => array(
        'offset' => 8,
        'items_per_page' => 5,
      ),
    );
    $view->display_handler->set_option('pager', $pager);
    $view->pre_execute();
    $view->execute();
    $this->assertEqual(count($view->result), 3, 'Take sure that only a certain count of items is returned');

    // Test items per page = 0
    $view = $this->viewPagerFullZeroItemsPerPage();
    $view->set_display('default');
    $view->pre_execute();
    $view->execute();

    $this->assertEqual(count($view->result), 11, 'All items are return');

    // TODO test number of pages.

    // Test items per page = 0.
    $view->destroy();

    // Setup and test a offset.
    $view = $this->viewsPagerFull();
    $view->set_display('default');

    $pager = array(
      'type' => 'full',
      'options' => array(
        'offset' => 0,
        'items_per_page' => 0,
      ),
    );

    $view->display_handler->set_option('pager', $pager);
    $view->execute();
    $this->assertEqual($view->query->pager->get_items_per_page(), 0);
    $this->assertEqual(count($view->result), 11);
  }
  
  function viewPagerFullZeroItemsPerPage() {
    $view = new view;
    $view->name = 'view_pager_full_zero_items_per_page';
    $view->description = '';
    $view->tag = '';
    $view->view_php = '';
    $view->base_table = 'node';
    $view->is_cacheable = FALSE;
    $view->api_version = 2;
    $view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */

    /* Display: Defaults */
    $handler = $view->new_display('default', 'Defaults', 'default');
    $handler->display->display_options['access']['type'] = 'none';
    $handler->display->display_options['cache']['type'] = 'none';
    $handler->display->display_options['exposed_form']['type'] = 'basic';
    $handler->display->display_options['pager']['type'] = 'full';
    $handler->display->display_options['pager']['options']['items_per_page'] = '0';
    $handler->display->display_options['pager']['options']['offset'] = '0';
    $handler->display->display_options['pager']['options']['id'] = '0';
    $handler->display->display_options['style_plugin'] = 'default';
    $handler->display->display_options['row_plugin'] = 'fields';
    /* Field: Node: Title */
    $handler->display->display_options['fields']['title']['id'] = 'title';
    $handler->display->display_options['fields']['title']['table'] = 'node';
    $handler->display->display_options['fields']['title']['field'] = 'title';
    $handler->display->display_options['fields']['title']['alter']['alter_text'] = 0;
    $handler->display->display_options['fields']['title']['alter']['make_link'] = 0;
    $handler->display->display_options['fields']['title']['alter']['trim'] = 0;
    $handler->display->display_options['fields']['title']['alter']['word_boundary'] = 1;
    $handler->display->display_options['fields']['title']['alter']['ellipsis'] = 1;
    $handler->display->display_options['fields']['title']['alter']['strip_tags'] = 0;
    $handler->display->display_options['fields']['title']['alter']['html'] = 0;
    $handler->display->display_options['fields']['title']['hide_empty'] = 0;
    $handler->display->display_options['fields']['title']['empty_zero'] = 0;
    $handler->display->display_options['fields']['title']['link_to_node'] = 0;

    return $view;
  }

  function viewsPagerFull() {
    $view = new view;
    $view->name = 'test_pager_full';
    $view->description = '';
    $view->tag = '';
    $view->view_php = '';
    $view->base_table = 'node';
    $view->is_cacheable = FALSE;
    $view->api_version = 2;
    $view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */

    /* Display: Defaults */
    $handler = $view->new_display('default', 'Defaults', 'default');
    $handler->display->display_options['access']['type'] = 'none';
    $handler->display->display_options['cache']['type'] = 'none';
    $handler->display->display_options['exposed_form']['type'] = 'basic';
    $handler->display->display_options['pager']['type'] = 'full';
    $handler->display->display_options['pager']['options']['items_per_page'] = '5';
    $handler->display->display_options['pager']['options']['offset'] = '0';
    $handler->display->display_options['pager']['options']['id'] = '0';
    $handler->display->display_options['style_plugin'] = 'default';
    $handler->display->display_options['row_plugin'] = 'node';

    return $view;
  }

  function viewsPagerFullFields() {
    $view = new view;
    $view->name = 'test_pager_full';
    $view->description = '';
    $view->tag = '';
    $view->view_php = '';
    $view->base_table = 'node';
    $view->is_cacheable = FALSE;
    $view->api_version = 2;
    $view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */

    /* Display: Defaults */
    $handler = $view->new_display('default', 'Defaults', 'default');
    $handler->display->display_options['access']['type'] = 'none';
    $handler->display->display_options['cache']['type'] = 'none';
    $handler->display->display_options['exposed_form']['type'] = 'basic';
    $handler->display->display_options['pager']['type'] = 'full';
    $handler->display->display_options['pager']['options']['items_per_page'] = '5';
    $handler->display->display_options['pager']['options']['offset'] = '0';
    $handler->display->display_options['pager']['options']['id'] = '0';
    $handler->display->display_options['style_plugin'] = 'default';
    $handler->display->display_options['row_plugin'] = 'fields';
    $handler->display->display_options['fields']['title']['id'] = 'title';
    $handler->display->display_options['fields']['title']['table'] = 'node';
    $handler->display->display_options['fields']['title']['field'] = 'title';
    $handler->display->display_options['fields']['title']['alter']['alter_text'] = 0;
    $handler->display->display_options['fields']['title']['alter']['make_link'] = 0;
    $handler->display->display_options['fields']['title']['alter']['trim'] = 0;
    $handler->display->display_options['fields']['title']['alter']['word_boundary'] = 1;
    $handler->display->display_options['fields']['title']['alter']['ellipsis'] = 1;
    $handler->display->display_options['fields']['title']['alter']['strip_tags'] = 0;
    $handler->display->display_options['fields']['title']['alter']['html'] = 0;
    $handler->display->display_options['fields']['title']['hide_empty'] = 0;
    $handler->display->display_options['fields']['title']['empty_zero'] = 0;
    $handler->display->display_options['fields']['title']['link_to_node'] = 0;
    return $view;
  }

  /**
   * Test the minipager.
   */
  public function testMiniPager() {
    // the functionality is the same as the normal pager, so i don't know what to test here.
  }

  /**
   * Test rendering with NULL pager.
   */
  public function testRenderNullPager() {
    // Create 11 nodes and take sure that everyone is returned.
    // We create 11 nodes, because the default pager plugin had 10 items per page.
    for ($i = 0; $i < 11; $i++) {
      $this->drupalCreateNode();
    }
    $view = $this->viewsPagerFullFields();
    $view->set_display('default');
    $view->execute();
    $view->use_ajax = TRUE; // force the value again here
    $view->query->pager = NULL;
    $output = $view->render();
    $this->assertEqual(preg_match('/<ul class="pager">/', $output), 0, t('The pager is not rendered.'));
  }
}

Other Drupal examples (source code examples)

Here is a short list of links related to this Drupal views_pager.test source code file:

new blog posts

"Drupal" is a registered trademark of Dries Buytaert.

my drupal tutorials and examples  

Copyright 1998-2016 Alvin Alexander, alvinalexander.com
All Rights Reserved.

Beginning in 2016, a portion of the proceeds from pages under the '/drupal-code-examples/' URI will be donated to charity.