Update to Drupal 8.2.4. For more information, see https://www.drupal.org/project/drupal/releases/8.2.4
This commit is contained in:
		
							parent
							
								
									0a95b8440e
								
							
						
					
					
						commit
						8544b60b39
					
				
					 284 changed files with 12980 additions and 3199 deletions
				
			
		|  | @ -152,7 +152,6 @@ class EntityOperations implements ContainerInjectionInterface { | |||
|     $entity_type_id = $entity->getEntityTypeId(); | ||||
|     $entity_id = $entity->id(); | ||||
|     $entity_revision_id = $entity->getRevisionId(); | ||||
|     $entity_langcode = $entity->language()->getId(); | ||||
| 
 | ||||
|     $storage = $this->entityTypeManager->getStorage('content_moderation_state'); | ||||
|     $entities = $storage->loadByProperties([ | ||||
|  | @ -174,11 +173,14 @@ class EntityOperations implements ContainerInjectionInterface { | |||
|     } | ||||
| 
 | ||||
|     // Sync translations.
 | ||||
|     if (!$content_moderation_state->hasTranslation($entity_langcode)) { | ||||
|       $content_moderation_state->addTranslation($entity_langcode); | ||||
|     } | ||||
|     if ($content_moderation_state->language()->getId() !== $entity_langcode) { | ||||
|       $content_moderation_state = $content_moderation_state->getTranslation($entity_langcode); | ||||
|     if ($entity->getEntityType()->hasKey('langcode')) { | ||||
|       $entity_langcode = $entity->language()->getId(); | ||||
|       if (!$content_moderation_state->hasTranslation($entity_langcode)) { | ||||
|         $content_moderation_state->addTranslation($entity_langcode); | ||||
|       } | ||||
|       if ($content_moderation_state->language()->getId() !== $entity_langcode) { | ||||
|         $content_moderation_state = $content_moderation_state->getTranslation($entity_langcode); | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     // Create the ContentModerationState entity for the inserted entity.
 | ||||
|  |  | |||
|  | @ -292,8 +292,8 @@ class EntityTypeInfo implements ContainerInjectionInterface { | |||
| 
 | ||||
|     $fields = []; | ||||
|     $fields['moderation_state'] = BaseFieldDefinition::create('entity_reference') | ||||
|       ->setLabel(t('Moderation state')) | ||||
|       ->setDescription(t('The moderation state of this piece of content.')) | ||||
|       ->setLabel($this->t('Moderation state')) | ||||
|       ->setDescription($this->t('The moderation state of this piece of content.')) | ||||
|       ->setComputed(TRUE) | ||||
|       ->setClass(ModerationStateFieldItemList::class) | ||||
|       ->setSetting('target_type', 'moderation_state') | ||||
|  | @ -310,6 +310,7 @@ class EntityTypeInfo implements ContainerInjectionInterface { | |||
|       ->addConstraint('ModerationState', []) | ||||
|       ->setDisplayConfigurable('form', FALSE) | ||||
|       ->setDisplayConfigurable('view', FALSE) | ||||
|       ->setReadOnly(FALSE) | ||||
|       ->setTranslatable(TRUE); | ||||
| 
 | ||||
|     return $fields; | ||||
|  |  | |||
|  | @ -43,12 +43,14 @@ class ModerationStateFieldItemList extends EntityReferenceFieldItemList { | |||
|           ->loadRevision($revision_to_load); | ||||
| 
 | ||||
|         // Return the correct translation.
 | ||||
|         $langcode = $entity->language()->getId(); | ||||
|         if (!$content_moderation_state->hasTranslation($langcode)) { | ||||
|           $content_moderation_state->addTranslation($langcode); | ||||
|         } | ||||
|         if ($content_moderation_state->language()->getId() !== $langcode) { | ||||
|           $content_moderation_state = $content_moderation_state->getTranslation($langcode); | ||||
|         if ($entity->getEntityType()->hasKey('langcode')) { | ||||
|           $langcode = $entity->language()->getId(); | ||||
|           if (!$content_moderation_state->hasTranslation($langcode)) { | ||||
|             $content_moderation_state->addTranslation($langcode); | ||||
|           } | ||||
|           if ($content_moderation_state->language()->getId() !== $langcode) { | ||||
|             $content_moderation_state = $content_moderation_state->getTranslation($langcode); | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|         return $content_moderation_state->get('moderation_state')->entity; | ||||
|  |  | |||
|  | @ -4,6 +4,8 @@ namespace Drupal\Tests\content_moderation\Kernel; | |||
| 
 | ||||
| use Drupal\content_moderation\Entity\ContentModerationState; | ||||
| use Drupal\content_moderation\Entity\ModerationState; | ||||
| use Drupal\entity_test\Entity\EntityTestBundle; | ||||
| use Drupal\entity_test\Entity\EntityTestWithBundle; | ||||
| use Drupal\KernelTests\KernelTestBase; | ||||
| use Drupal\language\Entity\ConfigurableLanguage; | ||||
| use Drupal\node\Entity\Node; | ||||
|  | @ -21,12 +23,14 @@ class ContentModerationStateTest extends KernelTestBase { | |||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = [ | ||||
|     'entity_test', | ||||
|     'node', | ||||
|     'content_moderation', | ||||
|     'user', | ||||
|     'system', | ||||
|     'language', | ||||
|     'content_translation', | ||||
|     'text', | ||||
|   ]; | ||||
| 
 | ||||
|   /** | ||||
|  | @ -38,6 +42,7 @@ class ContentModerationStateTest extends KernelTestBase { | |||
|     $this->installSchema('node', 'node_access'); | ||||
|     $this->installEntitySchema('node'); | ||||
|     $this->installEntitySchema('user'); | ||||
|     $this->installEntitySchema('entity_test_with_bundle'); | ||||
|     $this->installEntitySchema('content_moderation_state'); | ||||
|     $this->installConfig('content_moderation'); | ||||
|   } | ||||
|  | @ -210,6 +215,91 @@ class ContentModerationStateTest extends KernelTestBase { | |||
|     $this->assertEquals(6, $english_node->getRevisionId()); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests that a non-translatable entity type with a langcode can be moderated. | ||||
|    */ | ||||
|   public function testNonTranslatableEntityTypeModeration() { | ||||
|     // Make the 'entity_test_with_bundle' entity type revisionable.
 | ||||
|     $entity_type = clone \Drupal::entityTypeManager()->getDefinition('entity_test_with_bundle'); | ||||
|     $keys = $entity_type->getKeys(); | ||||
|     $keys['revision'] = 'revision_id'; | ||||
|     $entity_type->set('entity_keys', $keys); | ||||
|     \Drupal::state()->set('entity_test_with_bundle.entity_type', $entity_type); | ||||
|     \Drupal::entityDefinitionUpdateManager()->applyUpdates(); | ||||
| 
 | ||||
|     // Create a test bundle.
 | ||||
|     $entity_test_bundle = EntityTestBundle::create([ | ||||
|       'id' => 'example', | ||||
|     ]); | ||||
|     $entity_test_bundle->setThirdPartySetting('content_moderation', 'enabled', TRUE); | ||||
|     $entity_test_bundle->setThirdPartySetting('content_moderation', 'allowed_moderation_states', [ | ||||
|       'draft', | ||||
|       'published' | ||||
|     ]); | ||||
|     $entity_test_bundle->setThirdPartySetting('content_moderation', 'default_moderation_state', 'draft'); | ||||
|     $entity_test_bundle->save(); | ||||
| 
 | ||||
|     // Check that the tested entity type is not translatable.
 | ||||
|     $entity_type = \Drupal::entityTypeManager()->getDefinition('entity_test_with_bundle'); | ||||
|     $this->assertFalse($entity_type->isTranslatable(), 'The test entity type is not translatable.'); | ||||
| 
 | ||||
|     // Create a test entity.
 | ||||
|     $entity_test_with_bundle = EntityTestWithBundle::create([ | ||||
|       'type' => 'example' | ||||
|     ]); | ||||
|     $entity_test_with_bundle->save(); | ||||
|     $this->assertEquals('draft', $entity_test_with_bundle->moderation_state->entity->id()); | ||||
| 
 | ||||
|     $entity_test_with_bundle->moderation_state->target_id = 'published'; | ||||
|     $entity_test_with_bundle->save(); | ||||
| 
 | ||||
|     $this->assertEquals('published', EntityTestWithBundle::load($entity_test_with_bundle->id())->moderation_state->entity->id()); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests that a non-translatable entity type without a langcode can be | ||||
|    * moderated. | ||||
|    */ | ||||
|   public function testNonLangcodeEntityTypeModeration() { | ||||
|     // Make the 'entity_test_with_bundle' entity type revisionable and unset
 | ||||
|     // the langcode entity key.
 | ||||
|     $entity_type = clone \Drupal::entityTypeManager()->getDefinition('entity_test_with_bundle'); | ||||
|     $keys = $entity_type->getKeys(); | ||||
|     $keys['revision'] = 'revision_id'; | ||||
|     unset($keys['langcode']); | ||||
|     $entity_type->set('entity_keys', $keys); | ||||
|     \Drupal::state()->set('entity_test_with_bundle.entity_type', $entity_type); | ||||
|     \Drupal::entityDefinitionUpdateManager()->applyUpdates(); | ||||
| 
 | ||||
|     // Create a test bundle.
 | ||||
|     $entity_test_bundle = EntityTestBundle::create([ | ||||
|       'id' => 'example', | ||||
|     ]); | ||||
|     $entity_test_bundle->setThirdPartySetting('content_moderation', 'enabled', TRUE); | ||||
|     $entity_test_bundle->setThirdPartySetting('content_moderation', 'allowed_moderation_states', [ | ||||
|       'draft', | ||||
|       'published' | ||||
|     ]); | ||||
|     $entity_test_bundle->setThirdPartySetting('content_moderation', 'default_moderation_state', 'draft'); | ||||
|     $entity_test_bundle->save(); | ||||
| 
 | ||||
|     // Check that the tested entity type is not translatable.
 | ||||
|     $entity_type = \Drupal::entityTypeManager()->getDefinition('entity_test_with_bundle'); | ||||
|     $this->assertFalse($entity_type->isTranslatable(), 'The test entity type is not translatable.'); | ||||
| 
 | ||||
|     // Create a test entity.
 | ||||
|     $entity_test_with_bundle = EntityTestWithBundle::create([ | ||||
|       'type' => 'example' | ||||
|     ]); | ||||
|     $entity_test_with_bundle->save(); | ||||
|     $this->assertEquals('draft', $entity_test_with_bundle->moderation_state->entity->id()); | ||||
| 
 | ||||
|     $entity_test_with_bundle->moderation_state->target_id = 'published'; | ||||
|     $entity_test_with_bundle->save(); | ||||
| 
 | ||||
|     $this->assertEquals('published', EntityTestWithBundle::load($entity_test_with_bundle->id())->moderation_state->entity->id()); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Reloads the node after clearing the static cache. | ||||
|    * | ||||
|  |  | |||
|  | @ -0,0 +1,63 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\content_moderation\Kernel; | ||||
| 
 | ||||
| use Drupal\content_moderation\Entity\Handler\ModerationHandler; | ||||
| use Drupal\content_moderation\EntityTypeInfo; | ||||
| use Drupal\KernelTests\KernelTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @coversDefaultClass \Drupal\content_moderation\EntityTypeInfo | ||||
|  * | ||||
|  * @group content_moderation | ||||
|  */ | ||||
| class EntityTypeInfoTest extends KernelTestBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Modules to enable. | ||||
|    * | ||||
|    * @var array | ||||
|    */ | ||||
|   public static $modules = [ | ||||
|     'content_moderation', | ||||
|     'entity_test', | ||||
|   ]; | ||||
| 
 | ||||
|   /** | ||||
|    * The entity type manager. | ||||
|    * | ||||
|    * @var \Drupal\Core\Entity\EntityTypeManagerInterface | ||||
|    */ | ||||
|   protected $entityTypeManager; | ||||
| 
 | ||||
|   /** | ||||
|    * The entity type info class. | ||||
|    * | ||||
|    * @var \Drupal\content_moderation\EntityTypeInfo | ||||
|    */ | ||||
|   protected $entityTypeInfo; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function setUp() { | ||||
|     parent::setUp(); | ||||
|     $this->entityTypeInfo = $this->container->get('class_resolver')->getInstanceFromDefinition(EntityTypeInfo::class); | ||||
|     $this->entityTypeManager = $this->container->get('entity_type.manager'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * @covers ::entityBaseFieldInfo | ||||
|    */ | ||||
|   public function testEntityBaseFieldInfo() { | ||||
|     $definition = $this->entityTypeManager->getDefinition('entity_test'); | ||||
|     $definition->setHandlerClass('moderation', ModerationHandler::class); | ||||
| 
 | ||||
|     $base_fields = $this->entityTypeInfo->entityBaseFieldInfo($definition); | ||||
| 
 | ||||
|     $this->assertFalse($base_fields['moderation_state']->isReadOnly()); | ||||
|     $this->assertTrue($base_fields['moderation_state']->isComputed()); | ||||
|     $this->assertTrue($base_fields['moderation_state']->isTranslatable()); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
		Reference in a new issue
	
	 Pantheon Automation
						Pantheon Automation