X-Git-Url: http://aleph1.co.uk/gitweb/?a=blobdiff_plain;f=web%2Fcore%2Fmodules%2Fmedia%2Ftests%2Fsrc%2FKernel%2FMediaCreationTest.php;h=7eac84e49811085405e31002ffc41cd91ab2a5ff;hb=1c1cb0980bfa6caf0c24cce671b6bb541dc87583;hp=baf837f2c25877e4db0cb1e36e59e7b6d02ca89b;hpb=9917807b03b64faf00f6a1f29dcb6eafc454efa5;p=yaffs-website diff --git a/web/core/modules/media/tests/src/Kernel/MediaCreationTest.php b/web/core/modules/media/tests/src/Kernel/MediaCreationTest.php index baf837f2c..7eac84e49 100644 --- a/web/core/modules/media/tests/src/Kernel/MediaCreationTest.php +++ b/web/core/modules/media/tests/src/Kernel/MediaCreationTest.php @@ -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.'); } }