Further Drupal 8.6.4 changes. Some core files were not committed before a commit...
[yaffs-website] / web / core / modules / media / tests / src / Kernel / MediaCreationTest.php
index baf837f2c25877e4db0cb1e36e59e7b6d02ca89b..7eac84e49811085405e31002ffc41cd91ab2a5ff 100644 (file)
@@ -6,6 +6,8 @@ use Drupal\media\Entity\Media;
 use Drupal\media\Entity\MediaType;
 use Drupal\media\MediaInterface;
 use Drupal\media\MediaTypeInterface;
+use Drupal\user\Entity\Role;
+use Drupal\user\Entity\User;
 
 /**
  * Tests creation of media types and media items.
@@ -26,13 +28,34 @@ class MediaCreationTest extends MediaKernelTestBase {
     $this->container->get('module_installer')->install(['media_test_type']);
     $test_media_type = $media_type_storage->load('test');
     $this->assertInstanceOf(MediaTypeInterface::class, $test_media_type, 'The media type from default configuration has not been created in the database.');
-    $this->assertEquals('Test type', $test_media_type->get('label'), 'Could not assure the correct type name.');
-    $this->assertEquals('Test type.', $test_media_type->get('description'), 'Could not assure the correct type description.');
-    $this->assertEquals('test', $test_media_type->get('source'), 'Could not assure the correct media source.');
+    $this->assertSame('Test type', $test_media_type->get('label'), 'Could not assure the correct type name.');
+    $this->assertSame('Test type.', $test_media_type->get('description'), 'Could not assure the correct type description.');
+    $this->assertSame('test', $test_media_type->get('source'), 'Could not assure the correct media source.');
     // Source field is not set on the media source, but it should never
     // be created automatically when a config is being imported.
-    $this->assertEquals(['source_field' => '', 'test_config_value' => 'Kakec'], $test_media_type->get('source_configuration'), 'Could not assure the correct media source configuration.');
-    $this->assertEquals(['metadata_attribute' => 'field_attribute_config_test'], $test_media_type->get('field_map'), 'Could not assure the correct field map.');
+    $this->assertSame(['source_field' => '', 'test_config_value' => 'Kakec'], $test_media_type->get('source_configuration'), 'Could not assure the correct media source configuration.');
+    $this->assertSame(['metadata_attribute' => 'field_attribute_config_test'], $test_media_type->get('field_map'), 'Could not assure the correct field map.');
+    // Check the Media Type access handler behavior.
+    // We grant access to the 'view label' operation to all users having
+    // permission to 'view media'.
+    $user1 = User::create([
+      'name' => 'username1',
+      'status' => 1,
+    ]);
+    $user1->save();
+    $user2 = User::create([
+      'name' => 'username2',
+      'status' => 1,
+    ]);
+    $user2->save();
+    $role = Role::create([
+      'id' => 'role1',
+      'label' => 'role1',
+    ]);
+    $role->grantPermission('view media')->trustData()->save();
+    $user2->addRole($role->id());
+    $this->assertFalse($test_media_type->access('view label', $user1));
+    $this->assertTrue($test_media_type->access('view label', $user2));
   }
 
   /**
@@ -49,10 +72,10 @@ class MediaCreationTest extends MediaKernelTestBase {
     $this->assertNotInstanceOf(MediaInterface::class, Media::load(rand(1000, 9999)), 'Failed asserting a non-existent media.');
 
     $this->assertInstanceOf(MediaInterface::class, Media::load($media->id()), 'The new media item has not been created in the database.');
-    $this->assertEquals($this->testMediaType->id(), $media->bundle(), 'The media item was not created with the correct type.');
-    $this->assertEquals('Unnamed', $media->getName(), 'The media item was not created with the correct name.');
+    $this->assertSame($this->testMediaType->id(), $media->bundle(), 'The media item was not created with the correct type.');
+    $this->assertSame('Unnamed', $media->getName(), 'The media item was not created with the correct name.');
     $source_field_name = $media->bundle->entity->getSource()->getSourceFieldDefinition($media->bundle->entity)->getName();
-    $this->assertEquals('Nation of sheep, ruled by wolves, owned by pigs.', $media->get($source_field_name)->value, 'Source returns incorrect source field value.');
+    $this->assertSame('Nation of sheep, ruled by wolves, owned by pigs.', $media->get($source_field_name)->value, 'Source returns incorrect source field value.');
   }
 
 }