function DisplayTest::testDisplayPlugin

Tests the display test plugin.

See also

Drupal\views_test_data\Plugin\views\display\DisplayTest

File

drupal/core/modules/views/lib/Drupal/views/Tests/Plugin/DisplayTest.php, line 58
Definition of Drupal\views\Tests\Plugin\DisplayTest.

Class

DisplayTest
Tests the basic display plugin.

Namespace

Drupal\views\Tests\Plugin

Code

function testDisplayPlugin() {
  $view = views_get_view('test_view');

  // Add a new 'display_test' display and test it's there.
  $view->storage
    ->addDisplay('display_test');
  $displays = $view->storage
    ->get('display');
  $this
    ->assertTrue(isset($displays['display_test_1']), 'Added display has been assigned to "display_test_1"');

  // Check the the display options are like expected.
  $options = array(
    'display_options' => array(),
    'display_plugin' => 'display_test',
    'id' => 'display_test_1',
    'display_title' => 'Display test',
    'position' => 1,
  );
  $this
    ->assertEqual($displays['display_test_1'], $options);

  // Add another one to ensure that position is counted up.
  $view->storage
    ->addDisplay('display_test');
  $displays = $view->storage
    ->get('display');
  $options = array(
    'display_options' => array(),
    'display_plugin' => 'display_test',
    'id' => 'display_test_2',
    'display_title' => 'Display test 2',
    'position' => 2,
  );
  $this
    ->assertEqual($displays['display_test_2'], $options);

  // Move the second display before the first one in order to test custom
  // sorting.
  $displays['display_test_1']['position'] = 2;
  $displays['display_test_2']['position'] = 1;
  $view->storage
    ->set('display', $displays);
  $view
    ->save();
  $view
    ->setDisplay('display_test_1');
  $this
    ->assertTrue($view->display_handler instanceof DisplayTestPlugin, 'The correct display handler instance is on the view object.');

  // Check the test option.
  $this
    ->assertIdentical($view->display_handler
    ->getOption('test_option'), '');
  $output = $view
    ->preview();
  $output = drupal_render($output);
  $this
    ->assertTrue(strpos($output, '<h1></h1>') !== FALSE, 'An empty value for test_option found in output.');

  // Change this option and check the title of out output.
  $view->display_handler
    ->overrideOption('test_option', 'Test option title');
  $view
    ->save();
  $output = $view
    ->preview();
  $output = drupal_render($output);

  // Test we have our custom <h1> tag in the output of the view.
  $this
    ->assertTrue(strpos($output, '<h1>Test option title</h1>') !== FALSE, 'The test_option value found in display output title.');

  // Test that the display category/summary is in the UI.
  $this
    ->drupalGet('admin/structure/views/view/test_view/edit/display_test_1');
  $this
    ->assertText('Display test settings');

  // Ensure that the order is as expected.
  $result = $this
    ->xpath('//ul[@id="views-display-menu-tabs"]/li');
  $this
    ->assertEqual((string) $result[0]->a, 'Display test 2');
  $this
    ->assertEqual((string) $result[1]->a, 'Display test');
  $this
    ->clickLink('Test option title');
  $this->randomString = $this
    ->randomString();
  $this
    ->drupalPost(NULL, array(
    'test_option' => $this->randomString,
  ), t('Apply'));

  // Check the new value has been saved by checking the UI summary text.
  $this
    ->drupalGet('admin/structure/views/view/test_view/edit/display_test_1');
  $this
    ->assertRaw($this->randomString);

  // Test the enable/disable status of a display.
  $view->display_handler
    ->setOption('enabled', FALSE);
  $this
    ->assertFalse($view->display_handler
    ->isEnabled(), 'Make sure that isEnabled returns FALSE on a disabled display.');
  $view->display_handler
    ->setOption('enabled', TRUE);
  $this
    ->assertTrue($view->display_handler
    ->isEnabled(), 'Make sure that isEnabled returns TRUE on a disabled display.');
}