Further Drupal 8.6.4 changes. Some core files were not committed before a commit...
[yaffs-website] / web / core / modules / taxonomy / tests / src / Kernel / Migrate / d7 / MigrateTaxonomyTermTest.php
index fceaf0bdbc31085cd16c51424365650715c15540..8a7d912571179e797691a16e3676c73134304a29 100644 (file)
@@ -15,10 +15,15 @@ class MigrateTaxonomyTermTest extends MigrateDrupal7TestBase {
 
   public static $modules = [
     'comment',
+    'content_translation',
     'datetime',
+    'forum',
     'image',
+    'language',
     'link',
     'menu_ui',
+    // Required for translation migrations.
+    'migrate_drupal_multilingual',
     'node',
     'taxonomy',
     'telephone',
@@ -37,16 +42,23 @@ class MigrateTaxonomyTermTest extends MigrateDrupal7TestBase {
    */
   protected function setUp() {
     parent::setUp();
+    $this->installEntitySchema('comment');
+    $this->installEntitySchema('node');
     $this->installEntitySchema('taxonomy_term');
     $this->installConfig(static::$modules);
 
     $this->executeMigrations([
+      'language',
+      'd7_user_role',
+      'd7_user',
       'd7_node_type',
       'd7_comment_type',
       'd7_field',
       'd7_taxonomy_vocabulary',
       'd7_field_instance',
-      'd7_taxonomy_term'
+      'd7_taxonomy_term',
+      'd7_entity_translation_settings',
+      'd7_taxonomy_term_entity_translation',
     ]);
   }
 
@@ -71,17 +83,19 @@ class MigrateTaxonomyTermTest extends MigrateDrupal7TestBase {
    *   The value the migrated entity field should have.
    * @param int $expected_term_reference_tid
    *   The term reference id the migrated entity field should have.
+   * @param bool $expected_container_flag
+   *   The term should be a container entity.
    */
-  protected function assertEntity($id, $expected_label, $expected_vid, $expected_description = '', $expected_format = NULL, $expected_weight = 0, $expected_parents = [], $expected_field_integer_value = NULL, $expected_term_reference_tid = NULL) {
+  protected function assertEntity($id, $expected_label, $expected_vid, $expected_description = '', $expected_format = NULL, $expected_weight = 0, $expected_parents = [], $expected_field_integer_value = NULL, $expected_term_reference_tid = NULL, $expected_container_flag = 0) {
     /** @var \Drupal\taxonomy\TermInterface $entity */
     $entity = Term::load($id);
-    $this->assertTrue($entity instanceof TermInterface);
-    $this->assertIdentical($expected_label, $entity->label());
-    $this->assertIdentical($expected_vid, $entity->getVocabularyId());
-    $this->assertEqual($expected_description, $entity->getDescription());
+    $this->assertInstanceOf(TermInterface::class, $entity);
+    $this->assertEquals($expected_label, $entity->label());
+    $this->assertEquals($expected_vid, $entity->bundle());
+    $this->assertEquals($expected_description, $entity->getDescription());
     $this->assertEquals($expected_format, $entity->getFormat());
-    $this->assertEqual($expected_weight, $entity->getWeight());
-    $this->assertIdentical($expected_parents, $this->getParentIDs($id));
+    $this->assertEquals($expected_weight, $entity->getWeight());
+    $this->assertEquals($expected_parents, $this->getParentIDs($id));
     $this->assertHierarchy($expected_vid, $id, $expected_parents);
     if (!is_null($expected_field_integer_value)) {
       $this->assertTrue($entity->hasField('field_integer'));
@@ -91,6 +105,9 @@ class MigrateTaxonomyTermTest extends MigrateDrupal7TestBase {
       $this->assertTrue($entity->hasField('field_integer'));
       $this->assertEquals($expected_term_reference_tid, $entity->field_term_reference->target_id);
     }
+    if ($entity->hasField('forum_container')) {
+      $this->assertEquals($expected_container_flag, $entity->forum_container->value);
+    }
   }
 
   /**
@@ -98,13 +115,25 @@ class MigrateTaxonomyTermTest extends MigrateDrupal7TestBase {
    */
   public function testTaxonomyTerms() {
     $this->assertEntity(1, 'General discussion', 'forums', '', NULL, 2);
-    $this->assertEntity(2, 'Term1', 'test_vocabulary', 'The first term.', 'filtered_html', 0, [], NULL, 3);
+
+    // Tests that terms that used the Drupal 7 Title module and that have their
+    // name and description replaced by real fields are correctly migrated.
+    $this->assertEntity(2, 'Term1 (This is a real field!)', 'test_vocabulary', 'The first term. (This is a real field!)', 'filtered_html', 0, [], NULL, 3);
+
     $this->assertEntity(3, 'Term2', 'test_vocabulary', 'The second term.', 'filtered_html');
-    $this->assertEntity(4, 'Term3', 'test_vocabulary', 'The third term.', 'full_html', 0, [3], 6);
+    $this->assertEntity(4, 'Term3 in plain old English', 'test_vocabulary', 'The third term in plain old English.', 'full_html', 0, [3], 6);
     $this->assertEntity(5, 'Custom Forum', 'forums', 'Where the cool kids are.', NULL, 3);
-    $this->assertEntity(6, 'Games', 'forums', '', NULL, 4);
+    $this->assertEntity(6, 'Games', 'forums', '', NULL, 4, [], NULL, NULL, 1);
     $this->assertEntity(7, 'Minecraft', 'forums', '', NULL, 1, [6]);
     $this->assertEntity(8, 'Half Life 3', 'forums', '', NULL, 0, [6]);
+
+    // Verify that we still can create forum containers after the migration.
+    $term = Term::create(['vid' => 'forums', 'name' => 'Forum Container', 'forum_container' => 1]);
+    $term->save();
+
+    // Reset the forums tree data so this new term is included in the tree.
+    unset($this->treeData['forums']);
+    $this->assertEntity(19, 'Forum Container', 'forums', '', NULL, 0, [], NULL, NULL, 1);
   }
 
   /**
@@ -124,7 +153,7 @@ class MigrateTaxonomyTermTest extends MigrateDrupal7TestBase {
    * Assert that a term is present in the tree storage, with the right parents.
    *
    * @param string $vid
-   *   Vocabular ID.
+   *   Vocabulary ID.
    * @param int $tid
    *   ID of the term to check.
    * @param array $parent_ids
@@ -144,4 +173,56 @@ class MigrateTaxonomyTermTest extends MigrateDrupal7TestBase {
     $this->assertEquals($parent_ids, array_filter($term->parents), "Term $tid has correct parents in taxonomy tree");
   }
 
+  /**
+   * Tests the migration of taxonomy term entity translations.
+   */
+  public function testTaxonomyTermEntityTranslations() {
+    $manager = $this->container->get('content_translation.manager');
+
+    // Get the term and its translations.
+    $term = Term::load(4);
+    $term_fr = $term->getTranslation('fr');
+    $term_is = $term->getTranslation('is');
+
+    // Test that fields translated with Entity Translation are migrated.
+    $this->assertSame('Term3 in plain old English', $term->getName());
+    $this->assertSame('Term3 en français s\'il vous plaît', $term_fr->getName());
+    $this->assertSame('Term3 á íslensku', $term_is->getName());
+    $this->assertSame('The third term in plain old English.', $term->getDescription());
+    $this->assertSame('The third term en français s\'il vous plaît.', $term_fr->getDescription());
+    $this->assertSame('The third term á íslensku.', $term_is->getDescription());
+    $this->assertSame('full_html', $term->getFormat());
+    $this->assertSame('filtered_html', $term_fr->getFormat());
+    $this->assertSame('plain_text', $term_is->getFormat());
+    $this->assertSame('6', $term->field_integer->value);
+    $this->assertSame('5', $term_fr->field_integer->value);
+    $this->assertSame('4', $term_is->field_integer->value);
+
+    // Test that the French translation metadata is correctly migrated.
+    $metadata_fr = $manager->getTranslationMetadata($term_fr);
+    $this->assertTrue($metadata_fr->isPublished());
+    $this->assertSame('en', $metadata_fr->getSource());
+    $this->assertSame('2', $metadata_fr->getAuthor()->uid->value);
+    $this->assertSame('1531922267', $metadata_fr->getCreatedTime());
+    $this->assertSame('1531922268', $metadata_fr->getChangedTime());
+    $this->assertTrue($metadata_fr->isOutdated());
+
+    // Test that the Icelandic translation metadata is correctly migrated.
+    $metadata_is = $manager->getTranslationMetadata($term_is);
+    $this->assertFalse($metadata_is->isPublished());
+    $this->assertSame('en', $metadata_is->getSource());
+    $this->assertSame('1', $metadata_is->getAuthor()->uid->value);
+    $this->assertSame('1531922278', $metadata_is->getCreatedTime());
+    $this->assertSame('1531922279', $metadata_is->getChangedTime());
+    $this->assertFalse($metadata_is->isOutdated());
+
+    // Test that untranslatable properties are the same as the source language.
+    $this->assertSame($term->bundle(), $term_fr->bundle());
+    $this->assertSame($term->bundle(), $term_is->bundle());
+    $this->assertSame($term->getWeight(), $term_fr->getWeight());
+    $this->assertSame($term->getWeight(), $term_is->getWeight());
+    $this->assertSame($term->parent->terget_id, $term_fr->parent->terget_id);
+    $this->assertSame($term->parent->terget_id, $term_is->parent->terget_id);
+  }
+
 }