Update to Drupal 8.0.0-beta15. For more information, see: https://www.drupal.org/node/2563023
This commit is contained in:
		
							parent
							
								
									2720a9ec4b
								
							
						
					
					
						commit
						f3791f1da3
					
				
					 1898 changed files with 54300 additions and 11481 deletions
				
			
		|  | @ -7,11 +7,13 @@ | |||
| 
 | ||||
| namespace Drupal\rest\Tests; | ||||
| 
 | ||||
| use Drupal\comment\Tests\CommentTestTrait; | ||||
| use Drupal\Component\Serialization\Json; | ||||
| use Drupal\Core\Entity\EntityInterface; | ||||
| use Drupal\entity_test\Entity\EntityTest; | ||||
| use Drupal\node\Entity\Node; | ||||
| use Drupal\user\Entity\User; | ||||
| use Drupal\comment\Entity\Comment; | ||||
| 
 | ||||
| /** | ||||
|  * Tests the creation of resources. | ||||
|  | @ -20,12 +22,13 @@ use Drupal\user\Entity\User; | |||
|  */ | ||||
| class CreateTest extends RESTTestBase { | ||||
| 
 | ||||
|   use CommentTestTrait; | ||||
|   /** | ||||
|    * Modules to install. | ||||
|    * | ||||
|    * @var array | ||||
|    */ | ||||
|   public static $modules = array('hal', 'rest', 'entity_test'); | ||||
|   public static $modules = array('hal', 'rest', 'entity_test', 'comment'); | ||||
| 
 | ||||
|   /** | ||||
|    * The 'serializer' service. | ||||
|  | @ -36,6 +39,7 @@ class CreateTest extends RESTTestBase { | |||
| 
 | ||||
|   protected function setUp() { | ||||
|     parent::setUp(); | ||||
|     $this->addDefaultCommentField('node', 'resttest'); | ||||
|     // Get the 'serializer' service.
 | ||||
|     $this->serializer = $this->container->get('serializer'); | ||||
|   } | ||||
|  | @ -224,6 +228,52 @@ class CreateTest extends RESTTestBase { | |||
| 
 | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test comment creation. | ||||
|    */ | ||||
|   protected function testCreateComment() { | ||||
|     $node = Node::create([ | ||||
|       'type' => 'resttest', | ||||
|       'title' => 'some node', | ||||
|     ]); | ||||
|     $node->save(); | ||||
|     $entity_type = 'comment'; | ||||
|     // Enable the REST service for 'comment' entity type.
 | ||||
|     $this->enableService('entity:' . $entity_type, 'POST'); | ||||
|     // Create two accounts that have the required permissions to create
 | ||||
|     // resources, The second one has administrative permissions.
 | ||||
|     $accounts = $this->createAccountPerEntity($entity_type); | ||||
|     $account = end($accounts); | ||||
| 
 | ||||
|     $this->drupalLogin($account); | ||||
|     $entity_values = $this->entityValues($entity_type); | ||||
|     $entity_values['entity_id'] = $node->id(); | ||||
| 
 | ||||
|     $entity = Comment::create($entity_values); | ||||
| 
 | ||||
|     // Changed field can never be added.
 | ||||
|     unset($entity->changed); | ||||
| 
 | ||||
|     $serialized = $this->serializer->serialize($entity, $this->defaultFormat, ['account' => $account]); | ||||
| 
 | ||||
|     // Create the entity over the REST API.
 | ||||
|     $this->assertCreateEntityOverRestApi($entity_type, $serialized); | ||||
| 
 | ||||
|     // Get the new entity ID from the location header and try to read it from
 | ||||
|     // the database.
 | ||||
|     $this->assertReadEntityIdFromHeaderAndDb($entity_type, $entity, $entity_values); | ||||
| 
 | ||||
|     // Try to send invalid data that cannot be correctly deserialized.
 | ||||
|     $this->assertCreateEntityInvalidData($entity_type); | ||||
| 
 | ||||
|     // Try to send no data at all, which does not make sense on POST requests.
 | ||||
|     $this->assertCreateEntityNoData($entity_type); | ||||
| 
 | ||||
|     // Try to send invalid data to trigger the entity validation constraints.
 | ||||
|     // Send a UUID that is too long.
 | ||||
|     $this->assertCreateEntityInvalidSerialized($entity, $entity_type); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests several valid and invalid create requests for 'user' entity type. | ||||
|    */ | ||||
|  | @ -293,6 +343,7 @@ class CreateTest extends RESTTestBase { | |||
|     // Add administrative permissions for nodes and users.
 | ||||
|     $permissions[] = 'administer nodes'; | ||||
|     $permissions[] = 'administer users'; | ||||
|     $permissions[] = 'administer comments'; | ||||
|     // Create an administrative user.
 | ||||
|     $accounts[] = $this->drupalCreateUser($permissions); | ||||
| 
 | ||||
|  |  | |||
|  | @ -213,6 +213,17 @@ abstract class RESTTestBase extends WebTestBase { | |||
|         ); | ||||
|       case 'user': | ||||
|         return array('name' => $this->randomMachineName()); | ||||
| 
 | ||||
|       case 'comment': | ||||
|         return [ | ||||
|           'subject' => $this->randomMachineName(), | ||||
|           'entity_type' => 'node', | ||||
|           'comment_type' => 'comment', | ||||
|           'comment_body' => $this->randomString(), | ||||
|           'entity_id' => 'invalid', | ||||
|           'field_name' => 'comment', | ||||
|         ]; | ||||
| 
 | ||||
|       default: | ||||
|         return array(); | ||||
|     } | ||||
|  | @ -313,6 +324,22 @@ abstract class RESTTestBase extends WebTestBase { | |||
|             return array('delete any resttest content'); | ||||
|         } | ||||
| 
 | ||||
|       case 'comment': | ||||
|         switch ($operation) { | ||||
|           case 'view': | ||||
|             return ['access comments']; | ||||
| 
 | ||||
|           case 'create': | ||||
|             return ['post comments', 'skip comment approval']; | ||||
| 
 | ||||
|           case 'update': | ||||
|             return ['edit own comments']; | ||||
| 
 | ||||
|           case 'delete': | ||||
|             return ['administer comments']; | ||||
|         } | ||||
|         break; | ||||
| 
 | ||||
|       case 'user': | ||||
|         switch ($operation) { | ||||
|           case 'view': | ||||
|  |  | |||
|  | @ -6,6 +6,8 @@ | |||
|  */ | ||||
| 
 | ||||
| namespace Drupal\rest\Tests; | ||||
| use Drupal\Core\Session\AccountInterface; | ||||
| use Drupal\user\Entity\Role; | ||||
| 
 | ||||
| /** | ||||
|  * Tests the structure of a REST resource. | ||||
|  | @ -38,6 +40,10 @@ class ResourceTest extends RESTTestBase { | |||
|     // Create an entity programmatically.
 | ||||
|     $this->entity = $this->entityCreate('entity_test'); | ||||
|     $this->entity->save(); | ||||
| 
 | ||||
|     Role::load(AccountInterface::ANONYMOUS_ROLE) | ||||
|       ->grantPermission('view test entity') | ||||
|       ->save(); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|  |  | |||
|  | @ -7,9 +7,12 @@ | |||
| 
 | ||||
| namespace Drupal\rest\Tests\Views; | ||||
| 
 | ||||
| use Drupal\Component\Utility\SafeMarkup; | ||||
| use Drupal\Component\Utility\Html; | ||||
| use Drupal\Core\Cache\Cache; | ||||
| use Drupal\Core\Field\FieldStorageDefinitionInterface; | ||||
| use Drupal\entity_test\Entity\EntityTest; | ||||
| use Drupal\field\Entity\FieldConfig; | ||||
| use Drupal\field\Entity\FieldStorageConfig; | ||||
| use Drupal\system\Tests\Cache\AssertPageCacheContextsAndTagsTrait; | ||||
| use Drupal\views\Entity\View; | ||||
| use Drupal\views\Plugin\views\display\DisplayPluginBase; | ||||
|  | @ -480,16 +483,16 @@ class StyleSerializerTest extends PluginTestBase { | |||
|       $entities[] = $row->_entity; | ||||
|     } | ||||
| 
 | ||||
|     $expected = SafeMarkup::checkPlain($serializer->serialize($entities, 'json')); | ||||
|     $expected = $serializer->serialize($entities, 'json'); | ||||
| 
 | ||||
|     $view->live_preview = TRUE; | ||||
| 
 | ||||
|     $build = $view->preview(); | ||||
|     $rendered_json = $build['#markup']; | ||||
|     $this->assertEqual($rendered_json, $expected, 'Ensure the previewed json is escaped.'); | ||||
|     $rendered_json = $build['#plain_text']; | ||||
|     $this->assertTrue(!isset($build['#markup']) && $rendered_json == $expected, 'Ensure the previewed json is escaped.'); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     $expected = SafeMarkup::checkPlain($serializer->serialize($entities, 'xml')); | ||||
|     $expected = $serializer->serialize($entities, 'xml'); | ||||
| 
 | ||||
|     // Change the request format to xml.
 | ||||
|     $view->setDisplay('rest_export_1'); | ||||
|  | @ -505,7 +508,7 @@ class StyleSerializerTest extends PluginTestBase { | |||
| 
 | ||||
|     $this->executeView($view); | ||||
|     $build = $view->preview(); | ||||
|     $rendered_xml = $build['#markup']; | ||||
|     $rendered_xml = $build['#plain_text']; | ||||
|     $this->assertEqual($rendered_xml, $expected, 'Ensure we preview xml when we change the request format.'); | ||||
|   } | ||||
| 
 | ||||
|  | @ -544,4 +547,67 @@ class StyleSerializerTest extends PluginTestBase { | |||
|     $this->assertEqual($result[1]['nid'], $node->id()); | ||||
|     $this->assertTrue(strpos($this->getRawContent(), "<script") === FALSE, "No script tag is present in the raw page contents."); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests the "Grouped rows" functionality. | ||||
|    */ | ||||
|   public function testGroupRows() { | ||||
|     /** @var \Drupal\Core\Render\RendererInterface $renderer */ | ||||
|     $renderer = $this->container->get('renderer'); | ||||
|     $this->drupalCreateContentType(['type' => 'page']); | ||||
|     // Create a text field with cardinality set to unlimited.
 | ||||
|     $field_name = 'field_group_rows'; | ||||
|     $field_storage = FieldStorageConfig::create([ | ||||
|       'field_name' => $field_name, | ||||
|       'entity_type' => 'node', | ||||
|       'type' => 'string', | ||||
|       'cardinality' => FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED, | ||||
|     ]); | ||||
|     $field_storage->save(); | ||||
|     // Create an instance of the text field on the content type.
 | ||||
|     $field = FieldConfig::create([ | ||||
|       'field_storage' => $field_storage, | ||||
|       'bundle' => 'page', | ||||
|     ]); | ||||
|     $field->save(); | ||||
|     $grouped_field_values = ['a', 'b', 'c']; | ||||
|     $edit = [ | ||||
|       'title' => $this->randomMachineName(), | ||||
|       $field_name => $grouped_field_values, | ||||
|     ]; | ||||
|     $this->drupalCreateNode($edit); | ||||
|     $view = Views::getView('test_serializer_node_display_field'); | ||||
|     $view->setDisplay('rest_export_1'); | ||||
|     // Override the view's fields to include the field_group_rows field, set the
 | ||||
|     // group_rows setting to true.
 | ||||
|     $fields = [ | ||||
|       $field_name => [ | ||||
|         'id' => $field_name, | ||||
|         'table' => 'node__' . $field_name, | ||||
|         'field' => $field_name, | ||||
|         'type' => 'string', | ||||
|         'group_rows' => TRUE, | ||||
|       ], | ||||
|     ]; | ||||
|     $view->displayHandlers->get('default')->overrideOption('fields', $fields); | ||||
|     $build = $view->preview(); | ||||
|     // Get the serializer service.
 | ||||
|     $serializer = $this->container->get('serializer'); | ||||
|     // Check if the field_group_rows field is grouped.
 | ||||
|     $expected = []; | ||||
|     $expected[] = [$field_name => implode(', ', $grouped_field_values)]; | ||||
|     $this->assertEqual($serializer->serialize($expected, 'json'), (string) $renderer->renderRoot($build)); | ||||
|     // Set the group rows setting to false.
 | ||||
|     $view = Views::getView('test_serializer_node_display_field'); | ||||
|     $view->setDisplay('rest_export_1'); | ||||
|     $fields[$field_name]['group_rows'] = FALSE; | ||||
|     $view->displayHandlers->get('default')->overrideOption('fields', $fields); | ||||
|     $build = $view->preview(); | ||||
|     // Check if the field_group_rows field is ungrouped and displayed per row.
 | ||||
|     $expected = []; | ||||
|     foreach ($grouped_field_values as $grouped_field_value) { | ||||
|       $expected[] = [$field_name => $grouped_field_value]; | ||||
|     } | ||||
|     $this->assertEqual($serializer->serialize($expected, 'json'), (string) $renderer->renderRoot($build)); | ||||
|   } | ||||
| } | ||||
|  |  | |||
		Reference in a new issue
	
	 Pantheon Automation
						Pantheon Automation