annotate core/modules/taxonomy/src/Tests/TermTranslationTest.php @ 13:5fb285c0d0e3

Update Drupal core to 8.4.7 via Composer. Security update; I *think* we've been lucky to get away with this so far, as we don't support self-registration which seems to be used by the so-called "drupalgeddon 2" attack that 8.4.5 was vulnerable to.
author Chris Cannam
date Mon, 23 Apr 2018 09:33:26 +0100
parents 4c8ae668cc8c
children
rev   line source
Chris@0 1 <?php
Chris@0 2
Chris@0 3 namespace Drupal\taxonomy\Tests;
Chris@0 4
Chris@0 5 use Drupal\Core\Url;
Chris@0 6 use Drupal\system\Tests\Menu\AssertBreadcrumbTrait;
Chris@0 7
Chris@0 8 /**
Chris@0 9 * Tests for proper breadcrumb translation.
Chris@0 10 *
Chris@0 11 * @group taxonomy
Chris@0 12 */
Chris@0 13 class TermTranslationTest extends TaxonomyTestBase {
Chris@0 14
Chris@0 15 use AssertBreadcrumbTrait;
Chris@0 16 use TaxonomyTranslationTestTrait;
Chris@0 17
Chris@0 18 /**
Chris@0 19 * Term to translated term mapping.
Chris@0 20 *
Chris@0 21 * @var array
Chris@0 22 */
Chris@0 23 protected $termTranslationMap = [
Chris@0 24 'one' => 'translatedOne',
Chris@0 25 'two' => 'translatedTwo',
Chris@0 26 'three' => 'translatedThree',
Chris@0 27 ];
Chris@0 28
Chris@0 29 /**
Chris@0 30 * Created terms.
Chris@0 31 *
Chris@0 32 * @var \Drupal\taxonomy\Entity\Term[]
Chris@0 33 */
Chris@0 34 protected $terms = [];
Chris@0 35
Chris@0 36 /**
Chris@0 37 * {@inheritdoc}
Chris@0 38 */
Chris@0 39 public static $modules = ['taxonomy', 'language', 'content_translation'];
Chris@0 40
Chris@0 41 /**
Chris@0 42 * {@inheritdoc}
Chris@0 43 */
Chris@0 44 protected function setUp() {
Chris@0 45 parent::setUp();
Chris@0 46 $this->setupLanguages();
Chris@0 47 $this->vocabulary = $this->createVocabulary();
Chris@0 48 $this->enableTranslation();
Chris@0 49 $this->setUpTerms();
Chris@0 50 $this->setUpTermReferenceField();
Chris@0 51 }
Chris@0 52
Chris@0 53 /**
Chris@0 54 * Test translated breadcrumbs.
Chris@0 55 */
Chris@0 56 public function testTranslatedBreadcrumbs() {
Chris@0 57 // Ensure non-translated breadcrumb is correct.
Chris@0 58 $breadcrumb = [Url::fromRoute('<front>')->toString() => 'Home'];
Chris@0 59 foreach ($this->terms as $term) {
Chris@0 60 $breadcrumb[$term->url()] = $term->label();
Chris@0 61 }
Chris@0 62 // The last item will not be in the breadcrumb.
Chris@0 63 array_pop($breadcrumb);
Chris@0 64
Chris@0 65 // Check the breadcrumb on the leaf term page.
Chris@0 66 $term = $this->getLeafTerm();
Chris@0 67 $this->assertBreadcrumb($term->urlInfo(), $breadcrumb, $term->label());
Chris@0 68
Chris@0 69 $languages = \Drupal::languageManager()->getLanguages();
Chris@0 70
Chris@0 71 // Construct the expected translated breadcrumb.
Chris@0 72 $breadcrumb = [Url::fromRoute('<front>', [], ['language' => $languages[$this->translateToLangcode]])->toString() => 'Home'];
Chris@0 73 foreach ($this->terms as $term) {
Chris@0 74 $translated = $term->getTranslation($this->translateToLangcode);
Chris@0 75 $url = $translated->url('canonical', ['language' => $languages[$this->translateToLangcode]]);
Chris@0 76 $breadcrumb[$url] = $translated->label();
Chris@0 77 }
Chris@0 78 array_pop($breadcrumb);
Chris@0 79
Chris@0 80 // Check for the translated breadcrumb on the translated leaf term page.
Chris@0 81 $term = $this->getLeafTerm();
Chris@0 82 $translated = $term->getTranslation($this->translateToLangcode);
Chris@0 83 $this->assertBreadcrumb($translated->urlInfo('canonical', ['language' => $languages[$this->translateToLangcode]]), $breadcrumb, $translated->label());
Chris@0 84
Chris@0 85 }
Chris@0 86
Chris@0 87 /**
Chris@0 88 * Test translation of terms are showed in the node.
Chris@0 89 */
Chris@0 90 public function testTermsTranslation() {
Chris@0 91
Chris@0 92 // Set the display of the term reference field on the article content type
Chris@0 93 // to "Check boxes/radio buttons".
Chris@0 94 entity_get_form_display('node', 'article', 'default')
Chris@0 95 ->setComponent($this->termFieldName, [
Chris@0 96 'type' => 'options_buttons',
Chris@0 97 ])
Chris@0 98 ->save();
Chris@0 99 $this->drupalLogin($this->drupalCreateUser(['create article content']));
Chris@0 100
Chris@0 101 // Test terms are listed.
Chris@0 102 $this->drupalget('node/add/article');
Chris@0 103 $this->assertText('one');
Chris@0 104 $this->assertText('two');
Chris@0 105 $this->assertText('three');
Chris@0 106
Chris@0 107 // Test terms translated are listed.
Chris@0 108 $this->drupalget('hu/node/add/article');
Chris@0 109 $this->assertText('translatedOne');
Chris@0 110 $this->assertText('translatedTwo');
Chris@0 111 $this->assertText('translatedThree');
Chris@0 112 }
Chris@0 113
Chris@0 114 /**
Chris@0 115 * Setup translated terms in a hierarchy.
Chris@0 116 */
Chris@0 117 protected function setUpTerms() {
Chris@0 118 $parent_vid = 0;
Chris@0 119 foreach ($this->termTranslationMap as $name => $translation) {
Chris@0 120
Chris@0 121 $term = $this->createTerm($this->vocabulary, [
Chris@0 122 'name' => $name,
Chris@0 123 'langcode' => $this->baseLangcode,
Chris@0 124 'parent' => $parent_vid,
Chris@0 125 ]);
Chris@0 126
Chris@0 127 $term->addTranslation($this->translateToLangcode, [
Chris@0 128 'name' => $translation,
Chris@0 129 ]);
Chris@0 130 $term->save();
Chris@0 131
Chris@0 132 // Each term is nested under the last.
Chris@0 133 $parent_vid = $term->id();
Chris@0 134
Chris@0 135 $this->terms[] = $term;
Chris@0 136 }
Chris@0 137 }
Chris@0 138
Chris@0 139 /**
Chris@0 140 * Get the final (leaf) term in the hierarchy.
Chris@0 141 *
Chris@0 142 * @return \Drupal\taxonomy\Entity\Term
Chris@0 143 * The final term in the hierarchy.
Chris@0 144 */
Chris@0 145 protected function getLeafTerm() {
Chris@0 146 return $this->terms[count($this->termTranslationMap) - 1];
Chris@0 147 }
Chris@0 148
Chris@0 149 }