drupalPlaceBlock('page_title_block'); } public function testViewsWizardAndListing() { $this->drupalCreateContentType(['type' => 'article']); $this->drupalCreateContentType(['type' => 'page']); // Check if we can access the main views admin page. $this->drupalGet('admin/structure/views'); $this->assertText(t('Add view')); // Create a simple and not at all useful view. $view1 = []; $view1['label'] = $this->randomMachineName(16); $view1['id'] = strtolower($this->randomMachineName(16)); $view1['description'] = $this->randomMachineName(16); $view1['page[create]'] = FALSE; $this->drupalPostForm('admin/structure/views/add', $view1, t('Save and edit')); $this->assertResponse(200); $this->drupalGet('admin/structure/views'); $this->assertText($view1['label']); $this->assertText($view1['description']); $this->assertLinkByHref(\Drupal::url('entity.view.edit_form', ['view' => $view1['id']])); $this->assertLinkByHref(\Drupal::url('entity.view.delete_form', ['view' => $view1['id']])); $this->assertLinkByHref(\Drupal::url('entity.view.duplicate_form', ['view' => $view1['id']])); // The view should not have a REST export display. $this->assertNoText('REST export', 'When no options are enabled in the wizard, the resulting view does not have a REST export display.'); // This view should not have a block. $this->drupalGet('admin/structure/block'); $this->assertNoText($view1['label']); // Create two nodes. $node1 = $this->drupalCreateNode(['type' => 'page']); $node2 = $this->drupalCreateNode(['type' => 'article']); // Now create a page with simple node listing and an attached feed. $view2 = []; $view2['label'] = $this->randomMachineName(16); $view2['id'] = strtolower($this->randomMachineName(16)); $view2['description'] = $this->randomMachineName(16); $view2['page[create]'] = 1; $view2['page[title]'] = $this->randomMachineName(16); $view2['page[path]'] = $this->randomMachineName(16); $view2['page[feed]'] = 1; $view2['page[feed_properties][path]'] = $this->randomMachineName(16); $this->drupalPostForm('admin/structure/views/add', $view2, t('Save and edit')); $this->drupalGet($view2['page[path]']); $this->assertResponse(200); // Since the view has a page, we expect to be automatically redirected to // it. $this->assertUrl($view2['page[path]']); $this->assertText($view2['page[title]']); $this->assertText($node1->label()); $this->assertText($node2->label()); // Check if we have the feed. $this->assertLinkByHref(Url::fromRoute('view.' . $view2['id'] . '.feed_1')->toString()); $elements = $this->cssSelect('link[href="' . Url::fromRoute('view.' . $view2['id'] . '.feed_1', [], ['absolute' => TRUE])->toString() . '"]'); $this->assertEqual(count($elements), 1, 'Feed found.'); $this->drupalGet($view2['page[feed_properties][path]']); // Because the response is XML we can't use the page which depends on an // HTML tag being present. $this->assertEquals('2.0', $this->getSession()->getDriver()->getAttribute('//rss', 'version')); // The feed should have the same title and nodes as the page. $this->assertText($view2['page[title]']); $this->assertRaw($node1->url('canonical', ['absolute' => TRUE])); $this->assertText($node1->label()); $this->assertRaw($node2->url('canonical', ['absolute' => TRUE])); $this->assertText($node2->label()); // Go back to the views page and check if this view is there. $this->drupalGet('admin/structure/views'); $this->assertText($view2['label']); $this->assertText($view2['description']); $this->assertLinkByHref(Url::fromRoute('view.' . $view2['id'] . '.page_1')->toString()); // The view should not have a REST export display. $this->assertNoText('REST export', 'If only the page option was enabled in the wizard, the resulting view does not have a REST export display.'); // This view should not have a block. $this->drupalGet('admin/structure/block'); $this->assertNoText('View: ' . $view2['label']); // Create a view with a page and a block, and filter the listing. $view3 = []; $view3['label'] = $this->randomMachineName(16); $view3['id'] = strtolower($this->randomMachineName(16)); $view3['description'] = $this->randomMachineName(16); $view3['show[wizard_key]'] = 'node'; $view3['show[type]'] = 'page'; $view3['page[create]'] = 1; $view3['page[title]'] = $this->randomMachineName(16); $view3['page[path]'] = $this->randomMachineName(16); $view3['block[create]'] = 1; $view3['block[title]'] = $this->randomMachineName(16); $this->drupalPostForm('admin/structure/views/add', $view3, t('Save and edit')); $this->drupalGet($view3['page[path]']); $this->assertResponse(200); // Make sure the view only displays the node we expect. $this->assertUrl($view3['page[path]']); $this->assertText($view3['page[title]']); $this->assertText($node1->label()); $this->assertNoText($node2->label()); // Go back to the views page and check if this view is there. $this->drupalGet('admin/structure/views'); $this->assertText($view3['label']); $this->assertText($view3['description']); $this->assertLinkByHref(Url::fromRoute('view.' . $view3['id'] . '.page_1')->toString()); // The view should not have a REST export display. $this->assertNoText('REST export', 'If only the page and block options were enabled in the wizard, the resulting view does not have a REST export display.'); // Confirm that the block is available in the block administration UI. $this->drupalGet('admin/structure/block/list/' . $this->config('system.theme')->get('default')); $this->clickLink('Place block'); $this->assertText($view3['label']); // Place the block. $this->drupalPlaceBlock("views_block:{$view3['id']}-block_1"); // Visit a random page (not the one that displays the view itself) and look // for the expected node title in the block. $this->drupalGet('user'); $this->assertText($node1->label()); $this->assertNoText($node2->label()); // Make sure the listing page doesn't show disabled default views. $this->assertNoText('tracker', 'Default tracker view does not show on the listing page.'); // Create a view with only a REST export. $view4 = []; $view4['label'] = $this->randomMachineName(16); $view4['id'] = strtolower($this->randomMachineName(16)); $view4['description'] = $this->randomMachineName(16); $view4['show[wizard_key]'] = 'node'; $view4['show[type]'] = 'page'; $view4['rest_export[create]'] = 1; $view4['rest_export[path]'] = $this->randomMachineName(16); $this->drupalPostForm('admin/structure/views/add', $view4, t('Save and edit')); $this->assertRaw(t('The view %view has been saved.', ['%view' => $view4['label']])); // Check that the REST export path works. JSON will work, as all core // formats will be allowed. JSON and XML by default. $this->drupalGet($view4['rest_export[path]'], ['query' => ['_format' => 'json']]); $this->assertResponse(200); $data = Json::decode($this->getSession()->getPage()->getContent()); $this->assertEqual(count($data), 1, 'Only the node of type page is exported.'); $node = reset($data); $this->assertEqual($node['nid'][0]['value'], $node1->id(), 'The node of type page is exported.'); } /** * Tests default plugin values are populated from the wizard form. * * @see \Drupal\views\Plugin\views\display\DisplayPluginBase::mergeDefaults() */ public function testWizardDefaultValues() { $random_id = strtolower($this->randomMachineName(16)); // Create a basic view. $view = []; $view['label'] = $this->randomMachineName(16); $view['id'] = $random_id; $view['description'] = $this->randomMachineName(16); $view['page[create]'] = FALSE; $this->drupalPostForm('admin/structure/views/add', $view, t('Save and edit')); // Make sure the plugin types that should not have empty options don't have. // Test against all values is unit tested. // @see \Drupal\Tests\views\Kernel\Plugin\DisplayKernelTest $view = Views::getView($random_id); $displays = $view->storage->get('display'); foreach ($displays as $display) { foreach (['query', 'exposed_form', 'pager', 'style', 'row'] as $type) { $this->assertFalse(empty($display['display_options'][$type]['options']), new FormattableMarkup('Default options found for @plugin.', ['@plugin' => $type])); } } } }