Core and composer updates
This commit is contained in:
		
							parent
							
								
									a82634bb98
								
							
						
					
					
						commit
						62cac30480
					
				
					 1118 changed files with 21770 additions and 6306 deletions
				
			
		|  | @ -100,17 +100,34 @@ class RelationLinkManager extends LinkManagerBase implements RelationLinkManager | |||
|    *   Context from the normalizer/serializer operation. | ||||
|    * | ||||
|    * @return array | ||||
|    *   An array of typed data ids (entity_type, bundle, and field name) keyed | ||||
|    *   by corresponding relation URI. | ||||
|    *   An array of typed data IDs keyed by corresponding relation URI. The keys | ||||
|    *   are: | ||||
|    *   - 'entity_type_id' | ||||
|    *   - 'bundle' | ||||
|    *   - 'field_name' | ||||
|    *   - 'entity_type' (deprecated) | ||||
|    *   The values for 'entity_type_id', 'bundle' and 'field_name' are strings. | ||||
|    *   The 'entity_type' key exists for backwards compatibility and its value is | ||||
|    *   the full entity type object. The 'entity_type' key will be removed before | ||||
|    *   Drupal 9.0. | ||||
|    * | ||||
|    * @see https://www.drupal.org/node/2877608 | ||||
|    */ | ||||
|   protected function getRelations($context = []) { | ||||
|     $cid = 'hal:links:relations'; | ||||
|     $cache = $this->cache->get($cid); | ||||
|     if (!$cache) { | ||||
|       $this->writeCache($context); | ||||
|       $cache = $this->cache->get($cid); | ||||
|       $data = $this->writeCache($context); | ||||
|     } | ||||
|     return $cache->data; | ||||
|     else { | ||||
|       $data = $cache->data; | ||||
|     } | ||||
| 
 | ||||
|     // @todo https://www.drupal.org/node/2716163 Remove this in Drupal 9.0.
 | ||||
|     foreach ($data as $relation_uri => $ids) { | ||||
|       $data[$relation_uri]['entity_type'] = $this->entityManager->getDefinition($ids['entity_type_id']); | ||||
|     } | ||||
|     return $data; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|  | @ -118,6 +135,14 @@ class RelationLinkManager extends LinkManagerBase implements RelationLinkManager | |||
|    * | ||||
|    * @param array $context | ||||
|    *   Context from the normalizer/serializer operation. | ||||
|    * | ||||
|    * @return array | ||||
|    *   An array of typed data IDs keyed by corresponding relation URI. The keys | ||||
|    *   are: | ||||
|    *   - 'entity_type_id' | ||||
|    *   - 'bundle' | ||||
|    *   - 'field_name' | ||||
|    *   The values for 'entity_type_id', 'bundle' and 'field_name' are strings. | ||||
|    */ | ||||
|   protected function writeCache($context = []) { | ||||
|     $data = []; | ||||
|  | @ -128,7 +153,7 @@ class RelationLinkManager extends LinkManagerBase implements RelationLinkManager | |||
|           foreach ($this->entityManager->getFieldDefinitions($entity_type->id(), $bundle) as $field_definition) { | ||||
|             $relation_uri = $this->getRelationUri($entity_type->id(), $bundle, $field_definition->getName(), $context); | ||||
|             $data[$relation_uri] = [ | ||||
|               'entity_type' => $entity_type, | ||||
|               'entity_type_id' => $entity_type->id(), | ||||
|               'bundle' => $bundle, | ||||
|               'field_name' => $field_definition->getName(), | ||||
|             ]; | ||||
|  | @ -139,6 +164,7 @@ class RelationLinkManager extends LinkManagerBase implements RelationLinkManager | |||
|     // These URIs only change when field info changes, so cache it permanently
 | ||||
|     // and only clear it when the fields cache is cleared.
 | ||||
|     $this->cache->set('hal:links:relations', $data, Cache::PERMANENT, ['entity_field_info']); | ||||
|     return $data; | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -21,7 +21,7 @@ interface RelationLinkManagerInterface extends ConfigurableLinkManagerInterface | |||
|    *   (optional) Optional serializer/normalizer context. | ||||
|    * | ||||
|    * @return string | ||||
|    *   The corresponding URI for the field. | ||||
|    *   The corresponding URI (or IANA link relation type) for the field. | ||||
|    */ | ||||
|   public function getRelationUri($entity_type, $bundle, $field_name, $context = []); | ||||
| 
 | ||||
|  | @ -29,10 +29,12 @@ interface RelationLinkManagerInterface extends ConfigurableLinkManagerInterface | |||
|    * Translates a REST URI into internal IDs. | ||||
|    * | ||||
|    * @param string $relation_uri | ||||
|    *   Relation URI to transform into internal IDs | ||||
|    *   Relation URI (or IANA link relation type) to transform into internal IDs. | ||||
|    * | ||||
|    * @return array | ||||
|    *   Array with keys 'entity_type', 'bundle' and 'field_name'. | ||||
|    *   Array with keys 'entity_type_id', 'bundle' and 'field_name'. For | ||||
|    *   backwards compatibility, the entity_type key returns the full entity type | ||||
|    *   object, this will be removed before Drupal 9.0. | ||||
|    */ | ||||
|   public function getRelationInternalIds($relation_uri); | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\BaseFieldOverride; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\BaseFieldOverride\BaseFieldOverrideResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class BaseFieldOverrideHalJsonAnonTest extends BaseFieldOverrideResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\BaseFieldOverride; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\BaseFieldOverride\BaseFieldOverrideResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class BaseFieldOverrideHalJsonBasicAuthTest extends BaseFieldOverrideResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\BaseFieldOverride; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\BaseFieldOverride\BaseFieldOverrideResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class BaseFieldOverrideHalJsonCookieTest extends BaseFieldOverrideResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\BlockContentType; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\BlockContentType\BlockContentTypeResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class BlockContentTypeHalJsonAnonTest extends BlockContentTypeResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\BlockContentType; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\BlockContentType\BlockContentTypeResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class BlockContentTypeHalJsonBasicAuthTest extends BlockContentTypeResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\BlockContentType; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\BlockContentType\BlockContentTypeResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class BlockContentTypeHalJsonCookieTest extends BlockContentTypeResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\ContentLanguageSettings; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\ContentLanguageSettings\ContentLanguageSettingsResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class ContentLanguageSettingsHalJsonAnonTest extends ContentLanguageSettingsResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\ContentLanguageSettings; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\ContentLanguageSettings\ContentLanguageSettingsResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class ContentLanguageSettingsHalJsonBasicAuthTest extends ContentLanguageSettingsResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\ContentLanguageSettings; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\ContentLanguageSettings\ContentLanguageSettingsResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class ContentLanguageSettingsHalJsonCookieTest extends ContentLanguageSettingsResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\Editor; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\Editor\EditorResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class EditorHalJsonAnonTest extends EditorResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\Editor; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\Editor\EditorResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class EditorHalJsonBasicAuthTest extends EditorResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\Editor; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\Editor\EditorResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class EditorHalJsonCookieTest extends EditorResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,19 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\Feed; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FeedHalJsonAnonTest extends FeedHalJsonTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,24 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\Feed; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FeedHalJsonBasicAuthTest extends FeedHalJsonTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,19 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\Feed; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FeedHalJsonCookieTest extends FeedHalJsonTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,60 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\Feed; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\EntityResource\Feed\FeedResourceTestBase; | ||||
| use Drupal\Tests\hal\Functional\EntityResource\HalEntityNormalizationTrait; | ||||
| 
 | ||||
| abstract class FeedHalJsonTestBase extends FeedResourceTestBase { | ||||
| 
 | ||||
|   use HalEntityNormalizationTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function getExpectedNormalizedEntity() { | ||||
|     $default_normalization = parent::getExpectedNormalizedEntity(); | ||||
| 
 | ||||
|     $normalization = $this->applyHalFieldNormalization($default_normalization); | ||||
| 
 | ||||
|     return $normalization + [ | ||||
|       '_links' => [ | ||||
|         'self' => [ | ||||
|           'href' => $this->baseUrl . '/aggregator/sources/1?_format=hal_json' | ||||
|         ], | ||||
|         'type' => [ | ||||
|           'href' => $this->baseUrl . '/rest/type/aggregator_feed/aggregator_feed' | ||||
|         ], | ||||
|       ], | ||||
|     ]; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function getNormalizedPostEntity() { | ||||
|     return parent::getNormalizedPostEntity() + [ | ||||
|       '_links' => [ | ||||
|         'type' => [ | ||||
|           'href' => $this->baseUrl . '/rest/type/aggregator_feed/aggregator_feed' | ||||
|         ], | ||||
|       ], | ||||
|     ]; | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\FieldConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\FieldConfig\FieldConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FieldConfigHalJsonAnonTest extends FieldConfigResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\FieldConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\FieldConfig\FieldConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FieldConfigHalJsonBasicAuthTest extends FieldConfigResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\FieldConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\FieldConfig\FieldConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FieldConfigHalJsonCookieTest extends FieldConfigResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\FieldStorageConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\FieldStorageConfig\FieldStorageConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FieldStorageConfigHalJsonAnonTest extends FieldStorageConfigResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\FieldStorageConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\FieldStorageConfig\FieldStorageConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FieldStorageConfigHalJsonBasicAuthTest extends FieldStorageConfigResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\FieldStorageConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\FieldStorageConfig\FieldStorageConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class FieldStorageConfigHalJsonCookieTest extends FieldStorageConfigResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\RdfMapping; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\RdfMapping\RdfMappingResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class RdfMappingHalJsonAnonTest extends RdfMappingResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\RdfMapping; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\RdfMapping\RdfMappingResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class RdfMappingHalJsonBasicAuthTest extends RdfMappingResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\RdfMapping; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\RdfMapping\RdfMappingResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class RdfMappingHalJsonCookieTest extends RdfMappingResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\RestResourceConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\RestResourceConfig\RestResourceConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class RestResourceConfigHalJsonAnonTest extends RestResourceConfigResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\RestResourceConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\RestResourceConfig\RestResourceConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class RestResourceConfigHalJsonBasicAuthTest extends RestResourceConfigResourceTestBase { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,35 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\RestResourceConfig; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\RestResourceConfig\RestResourceConfigResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class RestResourceConfigHalJsonCookieTest extends RestResourceConfigResourceTestBase { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\ShortcutSet; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\AnonResourceTestTrait; | ||||
| use Drupal\Tests\rest\Functional\EntityResource\ShortcutSet\ShortcutSetResourceTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class ShortcutSetHalJsonAnonTest extends ShortcutSetResourceTestBase { | ||||
| 
 | ||||
|   use AnonResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $format = 'hal_json'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $mimeType = 'application/hal+json'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,24 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\ShortcutSet; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\BasicAuthResourceTestTrait; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class ShortcutSetHalJsonBasicAuthTest extends ShortcutSetHalJsonAnonTest { | ||||
| 
 | ||||
|   use BasicAuthResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['basic_auth']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'basic_auth'; | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,19 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Tests\hal\Functional\EntityResource\ShortcutSet; | ||||
| 
 | ||||
| use Drupal\Tests\rest\Functional\CookieResourceTestTrait; | ||||
| 
 | ||||
| /** | ||||
|  * @group hal | ||||
|  */ | ||||
| class ShortcutSetHalJsonCookieTest extends ShortcutSetHalJsonAnonTest { | ||||
| 
 | ||||
|   use CookieResourceTestTrait; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected static $auth = 'cookie'; | ||||
| 
 | ||||
| } | ||||
|  | @ -3,7 +3,10 @@ | |||
| namespace Drupal\Tests\hal\Kernel; | ||||
| 
 | ||||
| use Drupal\Core\Url; | ||||
| use Drupal\field\Entity\FieldConfig; | ||||
| use Drupal\field\Entity\FieldStorageConfig; | ||||
| use Drupal\KernelTests\KernelTestBase; | ||||
| use Drupal\node\Entity\NodeType; | ||||
| 
 | ||||
| /** | ||||
|  * @coversDefaultClass \Drupal\hal\LinkManager\LinkManager | ||||
|  | @ -14,13 +17,30 @@ class HalLinkManagerTest extends KernelTestBase { | |||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['hal', 'hal_test', 'serialization', 'system']; | ||||
|   public static $modules = [ 'hal', 'hal_test', 'serialization', 'system', 'node', 'user', 'field']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function setUp() { | ||||
|     parent::setUp(); | ||||
| 
 | ||||
|     $this->installEntitySchema('node'); | ||||
| 
 | ||||
|     NodeType::create([ | ||||
|       'type' => 'page', | ||||
|     ])->save(); | ||||
|     FieldStorageConfig::create([ | ||||
|       'entity_type' => 'node', | ||||
|       'type' => 'entity_reference', | ||||
|       'field_name' => 'field_ref', | ||||
|     ])->save(); | ||||
|     FieldConfig::create([ | ||||
|       'entity_type' => 'node', | ||||
|       'bundle' => 'page', | ||||
|       'field_name' => 'field_ref', | ||||
|     ])->save(); | ||||
| 
 | ||||
|     \Drupal::service('router.builder')->rebuild(); | ||||
|   } | ||||
| 
 | ||||
|  | @ -58,6 +78,23 @@ class HalLinkManagerTest extends KernelTestBase { | |||
|     $this->assertSame($link, 'rest_test_relation'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * @covers ::getRelationInternalIds | ||||
|    */ | ||||
|   public function testGetRelationInternalIds() { | ||||
|     /* @var \Drupal\rest\LinkManager\RelationLinkManagerInterface $relation_manager */ | ||||
|     $relation_manager = \Drupal::service('hal.link_manager.relation'); | ||||
|     $link = $relation_manager->getRelationUri('node', 'page', 'field_ref'); | ||||
|     $internal_ids = $relation_manager->getRelationInternalIds($link); | ||||
| 
 | ||||
|     $this->assertEquals([ | ||||
|       'entity_type_id' => 'node', | ||||
|       'entity_type' => \Drupal::entityTypeManager()->getDefinition('node'), | ||||
|       'bundle' => 'page', | ||||
|       'field_name' => 'field_ref' | ||||
|     ], $internal_ids); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * @covers ::setLinkDomain | ||||
|    */ | ||||
|  |  | |||
		Reference in a new issue
	
	 Rob Davies
						Rob Davies