summaryrefslogtreecommitdiff
path: root/sites/all/modules/views/tests/views_view.test
diff options
context:
space:
mode:
Diffstat (limited to 'sites/all/modules/views/tests/views_view.test')
-rw-r--r--sites/all/modules/views/tests/views_view.test290
1 files changed, 290 insertions, 0 deletions
diff --git a/sites/all/modules/views/tests/views_view.test b/sites/all/modules/views/tests/views_view.test
new file mode 100644
index 000000000..d268a0c12
--- /dev/null
+++ b/sites/all/modules/views/tests/views_view.test
@@ -0,0 +1,290 @@
+<?php
+
+/**
+ * @file
+ * Definition of ViewsViewTest.
+ */
+
+/**
+ * Views class tests.
+ */
+class ViewsViewTest extends ViewsSqlTest {
+ public static function getInfo() {
+ return array(
+ 'name' => 'Test the view class',
+ 'description' => 'Tests some functionality of the view class',
+ 'group' => 'Views',
+ );
+ }
+
+ /**
+ * Tests the deconstructor to be sure that every kind of heavy objects are removed.
+ */
+ function testDestroy() {
+ $view = $this->view_test_destroy();
+
+ $view->preview();
+ $view->destroy();
+
+ $this->assertViewDestroy($view);
+
+ // Manipulate the display variable to test a previous bug.
+ $view = $this->view_test_destroy();
+ $view->preview();
+
+ $view->destroy();
+ $this->assertViewDestroy($view);
+ }
+
+ function assertViewDestroy($view) {
+ $this->assertFalse(isset($view->display['default']->handler), 'Make sure all displays are destroyed.');
+ $this->assertFalse(isset($view->display['attachment_1']->handler), 'Make sure all displays are destroyed.');
+
+ $this->assertFalse(isset($view->filter), 'Make sure all handlers are destroyed');
+ $this->assertFalse(isset($view->field), 'Make sure all handlers are destroyed');
+ $this->assertFalse(isset($view->argument), 'Make sure all handlers are destroyed');
+ $this->assertFalse(isset($view->relationship), 'Make sure all handlers are destroyed');
+ $this->assertFalse(isset($view->sort), 'Make sure all handlers are destroyed');
+ $this->assertFalse(isset($view->area), 'Make sure all handlers are destroyed');
+
+ $keys = array('current_display', 'display_handler', 'field', 'argument', 'filter', 'sort', 'relationship', 'header', 'footer', 'empty', 'query', 'result', 'inited', 'style_plugin', 'plugin_name', 'exposed_data', 'exposed_input', 'many_to_one_tables');
+ foreach ($keys as $key) {
+ $this->assertFalse(isset($view->{$key}), $key);
+ }
+ $this->assertEqual($view->built, FALSE);
+ $this->assertEqual($view->executed, FALSE);
+ $this->assertEqual($view->build_info, array());
+ $this->assertEqual($view->attachment_before, '');
+ $this->assertEqual($view->attachment_after, '');
+ }
+
+ function testDelete() {
+ // Delete a database view
+ $view = $this->view_test_delete();
+ $view->save();
+ $view = views_get_view($view->name);
+ $view->delete();
+
+ $view = views_get_view($view->name);
+ $this->assertNotNull($view, 'Make sure that the old view is still in the static cache.');
+
+ $view = views_get_view($view->name, TRUE);
+ $this->assertNull($view, "Make sure that the old view gets cleared by the reset parameter.");
+ }
+
+ function testValidate() {
+ // Test a view with multiple displays.
+ // Validating a view shouldn't change the active display.
+ // @todo: Create an extra validation view.
+ $view = $this->view_test_destroy();
+ $view->set_display('page_1');
+
+ $view->validate();
+
+ $this->assertEqual('page_1', $view->current_display, "The display should be constant while validating");
+
+ // @todo: Write real tests for the validation.
+ // In general the following things could be tested:
+ // - Deleted displays shouldn't be validated
+ // - Multiple displays are validating and the errors are merged together.
+ }
+
+ /**
+ * This view provides some filters, fields, arguments, relationships, sorts, areas and attachments.
+ */
+ function view_test_destroy() {
+ $view = new view;
+ $view->name = 'test_destroy';
+ $view->description = '';
+ $view->tag = '';
+ $view->base_table = 'node';
+ $view->human_name = '';
+ $view->api_version = '3.0-alpha1';
+ $view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */
+
+ /* Display: Master */
+ $handler = $view->new_display('default', 'Master', 'default');
+ $handler->display->display_options['access']['type'] = 'none';
+ $handler->display->display_options['cache']['type'] = 'none';
+ $handler->display->display_options['query']['type'] = 'views_query';
+ $handler->display->display_options['exposed_form']['type'] = 'basic';
+ $handler->display->display_options['pager']['type'] = 'full';
+ $handler->display->display_options['style_plugin'] = 'default';
+ $handler->display->display_options['row_plugin'] = 'fields';
+ /* Header: Global: Text area */
+ $handler->display->display_options['header']['area']['id'] = 'area';
+ $handler->display->display_options['header']['area']['table'] = 'views';
+ $handler->display->display_options['header']['area']['field'] = 'area';
+ $handler->display->display_options['header']['area']['empty'] = FALSE;
+ /* Header: Global: Text area */
+ $handler->display->display_options['header']['area_1']['id'] = 'area_1';
+ $handler->display->display_options['header']['area_1']['table'] = 'views';
+ $handler->display->display_options['header']['area_1']['field'] = 'area';
+ $handler->display->display_options['header']['area_1']['empty'] = FALSE;
+ /* Footer: Global: Text area */
+ $handler->display->display_options['footer']['area']['id'] = 'area';
+ $handler->display->display_options['footer']['area']['table'] = 'views';
+ $handler->display->display_options['footer']['area']['field'] = 'area';
+ $handler->display->display_options['footer']['area']['empty'] = FALSE;
+ /* Footer: Global: Text area */
+ $handler->display->display_options['footer']['area_1']['id'] = 'area_1';
+ $handler->display->display_options['footer']['area_1']['table'] = 'views';
+ $handler->display->display_options['footer']['area_1']['field'] = 'area';
+ $handler->display->display_options['footer']['area_1']['empty'] = FALSE;
+ /* Empty text: Global: Text area */
+ $handler->display->display_options['empty']['area']['id'] = 'area';
+ $handler->display->display_options['empty']['area']['table'] = 'views';
+ $handler->display->display_options['empty']['area']['field'] = 'area';
+ $handler->display->display_options['empty']['area']['empty'] = FALSE;
+ /* Empty text: Global: Text area */
+ $handler->display->display_options['empty']['area_1']['id'] = 'area_1';
+ $handler->display->display_options['empty']['area_1']['table'] = 'views';
+ $handler->display->display_options['empty']['area_1']['field'] = 'area';
+ $handler->display->display_options['empty']['area_1']['empty'] = FALSE;
+ /* Relationship: Comment: Node */
+ $handler->display->display_options['relationships']['nid']['id'] = 'nid';
+ $handler->display->display_options['relationships']['nid']['table'] = 'comments';
+ $handler->display->display_options['relationships']['nid']['field'] = 'nid';
+ /* Relationship: Comment: Parent comment */
+ $handler->display->display_options['relationships']['pid']['id'] = 'pid';
+ $handler->display->display_options['relationships']['pid']['table'] = 'comments';
+ $handler->display->display_options['relationships']['pid']['field'] = 'pid';
+ /* Relationship: Comment: User */
+ $handler->display->display_options['relationships']['uid']['id'] = 'uid';
+ $handler->display->display_options['relationships']['uid']['table'] = 'comments';
+ $handler->display->display_options['relationships']['uid']['field'] = 'uid';
+ /* Field: Content: Nid */
+ $handler->display->display_options['fields']['nid']['id'] = 'nid';
+ $handler->display->display_options['fields']['nid']['table'] = 'node';
+ $handler->display->display_options['fields']['nid']['field'] = 'nid';
+ /* Field: Content: Path */
+ $handler->display->display_options['fields']['path']['id'] = 'path';
+ $handler->display->display_options['fields']['path']['table'] = 'node';
+ $handler->display->display_options['fields']['path']['field'] = 'path';
+ /* Field: Content: Post date */
+ $handler->display->display_options['fields']['created']['id'] = 'created';
+ $handler->display->display_options['fields']['created']['table'] = 'node';
+ $handler->display->display_options['fields']['created']['field'] = 'created';
+ /* Sort criterion: Content: In moderation */
+ $handler->display->display_options['sorts']['moderate']['id'] = 'moderate';
+ $handler->display->display_options['sorts']['moderate']['table'] = 'node';
+ $handler->display->display_options['sorts']['moderate']['field'] = 'moderate';
+ /* Sort criterion: Content: Last comment author */
+ $handler->display->display_options['sorts']['last_comment_name']['id'] = 'last_comment_name';
+ $handler->display->display_options['sorts']['last_comment_name']['table'] = 'node_comment_statistics';
+ $handler->display->display_options['sorts']['last_comment_name']['field'] = 'last_comment_name';
+ /* Sort criterion: Content: Last comment time */
+ $handler->display->display_options['sorts']['last_comment_timestamp']['id'] = 'last_comment_timestamp';
+ $handler->display->display_options['sorts']['last_comment_timestamp']['table'] = 'node_comment_statistics';
+ $handler->display->display_options['sorts']['last_comment_timestamp']['field'] = 'last_comment_timestamp';
+ /* Argument: Content: Created date */
+ $handler->display->display_options['arguments']['created_fulldate']['id'] = 'created_fulldate';
+ $handler->display->display_options['arguments']['created_fulldate']['table'] = 'node';
+ $handler->display->display_options['arguments']['created_fulldate']['field'] = 'created_fulldate';
+ $handler->display->display_options['arguments']['created_fulldate']['style_plugin'] = 'default_summary';
+ $handler->display->display_options['arguments']['created_fulldate']['default_argument_type'] = 'fixed';
+ /* Argument: Content: Created day */
+ $handler->display->display_options['arguments']['created_day']['id'] = 'created_day';
+ $handler->display->display_options['arguments']['created_day']['table'] = 'node';
+ $handler->display->display_options['arguments']['created_day']['field'] = 'created_day';
+ $handler->display->display_options['arguments']['created_day']['style_plugin'] = 'default_summary';
+ $handler->display->display_options['arguments']['created_day']['default_argument_type'] = 'fixed';
+ /* Argument: Content: Created month */
+ $handler->display->display_options['arguments']['created_month']['id'] = 'created_month';
+ $handler->display->display_options['arguments']['created_month']['table'] = 'node';
+ $handler->display->display_options['arguments']['created_month']['field'] = 'created_month';
+ $handler->display->display_options['arguments']['created_month']['style_plugin'] = 'default_summary';
+ $handler->display->display_options['arguments']['created_month']['default_argument_type'] = 'fixed';
+ /* Filter: Content: Nid */
+ $handler->display->display_options['filters']['nid']['id'] = 'nid';
+ $handler->display->display_options['filters']['nid']['table'] = 'node';
+ $handler->display->display_options['filters']['nid']['field'] = 'nid';
+ /* Filter: Content: Published */
+ $handler->display->display_options['filters']['status']['id'] = 'status';
+ $handler->display->display_options['filters']['status']['table'] = 'node';
+ $handler->display->display_options['filters']['status']['field'] = 'status';
+ /* Filter: Content: Title */
+ $handler->display->display_options['filters']['title']['id'] = 'title';
+ $handler->display->display_options['filters']['title']['table'] = 'node';
+ $handler->display->display_options['filters']['title']['field'] = 'title';
+
+ /* Display: Page */
+ $handler = $view->new_display('page', 'Page', 'page_1');
+ $handler->display->display_options['path'] = 'test_destroy';
+
+ /* Display: Attachment */
+ $handler = $view->new_display('attachment', 'Attachment', 'attachment_1');
+ $handler->display->display_options['pager']['type'] = 'some';
+ $handler->display->display_options['displays'] = array(
+ 'default' => 'default',
+ 'page_1' => 'page_1',
+ );
+
+ /* Display: Attachment */
+ $handler = $view->new_display('attachment', 'Attachment', 'attachment_2');
+ $handler->display->display_options['pager']['type'] = 'some';
+ $handler->display->display_options['displays'] = array(
+ 'default' => 'default',
+ 'page_1' => 'page_1',
+ );
+ $translatables['test_destroy'] = array(
+ t('Master'),
+ t('more'),
+ t('Apply'),
+ t('Reset'),
+ t('Sort By'),
+ t('Asc'),
+ t('Desc'),
+ t('Items per page'),
+ t('- All -'),
+ t('Offset'),
+ t('Text area'),
+ t('Content'),
+ t('Parent comment'),
+ t('User'),
+ t('Nid'),
+ t('Path'),
+ t('Post date'),
+ t('All'),
+ t('Page'),
+ t('Attachment'),
+ );
+
+ return $view;
+ }
+ function view_test_delete() {
+ $view = new view;
+ $view->name = 'test_view_delete';
+ $view->description = '';
+ $view->tag = '';
+ $view->base_table = 'node';
+ $view->human_name = 'test_view_delete';
+ $view->core = 7;
+ $view->api_version = '3.0-alpha1';
+ $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['query']['type'] = 'views_query';
+ $handler->display->display_options['exposed_form']['type'] = 'basic';
+ $handler->display->display_options['pager']['type'] = 'full';
+ $handler->display->display_options['style_plugin'] = 'default';
+ $handler->display->display_options['row_plugin'] = 'fields';
+ $translatables['test_view_delete'] = array(
+ t('Defaults'),
+ t('more'),
+ t('Apply'),
+ t('Reset'),
+ t('Sort By'),
+ t('Asc'),
+ t('Desc'),
+ t('Items per page'),
+ t('- All -'),
+ t('Offset'),
+ );
+
+ return $view;
+ }
+}