views_plugin_style_mapping.test
Definition of ViewsPluginStyleMappingTest.
File
-
tests/
styles/ views_plugin_style_mapping.test
View source
<?php
/**
* @file
* Definition of ViewsPluginStyleMappingTest.
*/
/**
* Tests the default/mapping row style.
*/
class ViewsPluginStyleMappingTest extends ViewsPluginStyleTestBase {
/**
*
*/
public static function getInfo() {
return array(
'name' => 'Style: Mapping',
'description' => 'Test mapping style functionality.',
'group' => 'Views Plugins',
);
}
/**
* {@inheritdoc}
*/
public function setUp(array $modules = array()) {
parent::setUp($modules);
// Reset the plugin data.
views_fetch_plugin_data(NULL, NULL, TRUE);
}
/**
*
*/
protected function viewsPlugins() {
return array(
'style' => array(
'test_mapping' => array(
'title' => t('Field mapping'),
'help' => t('Maps specific fields to specific purposes.'),
'handler' => 'views_test_plugin_style_test_mapping',
'path' => drupal_get_path('module', 'views_test') . '/test_plugins',
'theme' => 'views_view_mapping_test',
'theme path' => drupal_get_path('module', 'views_test'),
'theme file' => 'views_test.module',
'uses row plugin' => FALSE,
'uses fields' => TRUE,
'uses options' => TRUE,
'uses grouping' => FALSE,
'type' => 'normal',
),
),
);
}
/**
* Overrides ViewsTestCase::getBasicView().
*/
protected function getBasicView() {
$view = parent::getBasicView();
$view->display['default']->handler
->override_option('style_plugin', 'test_mapping');
$view->display['default']->handler
->override_option('style_options', array(
'mapping' => array(
'name_field' => 'name',
'numeric_field' => array(
'age',
),
'title_field' => 'name',
'toggle_numeric_field' => TRUE,
'toggle_title_field' => TRUE,
),
));
$view->display['default']->handler
->override_option('fields', array(
'age' => array(
'id' => 'age',
'table' => 'views_test',
'field' => 'age',
'relationship' => 'none',
),
'name' => array(
'id' => 'name',
'table' => 'views_test',
'field' => 'name',
'relationship' => 'none',
),
'job' => array(
'id' => 'job',
'table' => 'views_test',
'field' => 'job',
'relationship' => 'none',
),
));
return $view;
}
/**
* Verifies that the fields were mapped correctly.
*/
public function testMappedOutput() {
$view = $this->getBasicView();
$output = $this->mappedOutputHelper($view);
$this->assertTrue(strpos($output, 'job') === FALSE, 'The job field is added to the view but not in the mapping.');
$view = $this->getBasicView();
$view->display['default']->display_options['style_options']['mapping']['name_field'] = 'job';
$output = $this->mappedOutputHelper($view);
$this->assertTrue(strpos($output, 'job') !== FALSE, 'The job field is added to the view and is in the mapping.');
}
/**
* Tests the mapping of fields.
*
* @param view $view
* The view to test.
*
* @return string
* The view rendered as HTML.
*/
protected function mappedOutputHelper($view) {
$rendered_output = $view->preview();
$this->storeViewPreview($rendered_output);
$rows = $this->elements->body->div->div->div;
$data_set = $this->dataSet();
$count = 0;
foreach ($rows as $row) {
$attributes = $row->attributes();
$class = (string) $attributes['class'][0];
$this->assertTrue(strpos($class, 'views-row-mapping-test') !== FALSE, 'Make sure that each row has the correct CSS class.');
foreach ($row->div as $field) {
// Split up the field-level class, the first part is the mapping name
// and the second is the field ID.
$field_attributes = $field->attributes();
$name = strtok((string) $field_attributes['class'][0], '-');
$field_id = strtok('-');
// The expected result is the mapping name and the field value,
// separated by ':'.
$expected_result = $name . ':' . $data_set[$count][$field_id];
$actual_result = (string) $field;
$this->assertIdentical($expected_result, $actual_result, format_string('The fields were mapped successfully: %name => %field_id', array(
'%name' => $name,
'%field_id' => $field_id,
)));
}
$count++;
}
return $rendered_output;
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
ViewsPluginStyleMappingTest | Tests the default/mapping row style. |