X-Git-Url: http://aleph1.co.uk/gitweb/?a=blobdiff_plain;f=web%2Fcore%2Fmodules%2Ftaxonomy%2Ftests%2Fsrc%2FKernel%2FMigrate%2Fd7%2FMigrateTaxonomyTermTest.php;h=8a7d912571179e797691a16e3676c73134304a29;hb=refs%2Fheads%2Fd864;hp=fceaf0bdbc31085cd16c51424365650715c15540;hpb=a2bd1bf0c2c1f1a17d188f4dc0726a45494cefae;p=yaffs-website diff --git a/web/core/modules/taxonomy/tests/src/Kernel/Migrate/d7/MigrateTaxonomyTermTest.php b/web/core/modules/taxonomy/tests/src/Kernel/Migrate/d7/MigrateTaxonomyTermTest.php index fceaf0bdb..8a7d91257 100644 --- a/web/core/modules/taxonomy/tests/src/Kernel/Migrate/d7/MigrateTaxonomyTermTest.php +++ b/web/core/modules/taxonomy/tests/src/Kernel/Migrate/d7/MigrateTaxonomyTermTest.php @@ -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); + } + }