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
129
core/tests/Drupal/KernelTests/AssertLegacyTrait.php
Normal file
129
core/tests/Drupal/KernelTests/AssertLegacyTrait.php
Normal file
|
@ -0,0 +1,129 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Contains \Drupal\KernelTests\AssertLegacyTrait.
|
||||
*/
|
||||
|
||||
namespace Drupal\KernelTests;
|
||||
|
||||
/**
|
||||
* Translates Simpletest assertion methods to PHPUnit.
|
||||
*
|
||||
* Protected methods are custom. Public static methods override methods of
|
||||
* \PHPUnit_Framework_Assert.
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use PHPUnit's native
|
||||
* assert methods instead.
|
||||
*/
|
||||
trait AssertLegacyTrait {
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assert()
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use self::assertTrue()
|
||||
* instead.
|
||||
*/
|
||||
protected function assert($actual, $message = '') {
|
||||
parent::assertTrue((bool) $actual, $message);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assertTrue()
|
||||
*/
|
||||
public static function assertTrue($actual, $message = '') {
|
||||
if (is_bool($actual)) {
|
||||
parent::assertTrue($actual, $message);
|
||||
}
|
||||
else {
|
||||
parent::assertNotEmpty($actual, $message);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assertFalse()
|
||||
*/
|
||||
public static function assertFalse($actual, $message = '') {
|
||||
if (is_bool($actual)) {
|
||||
parent::assertFalse($actual, $message);
|
||||
}
|
||||
else {
|
||||
parent::assertEmpty($actual, $message);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assertEqual()
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use self::assertEquals()
|
||||
* instead.
|
||||
*/
|
||||
protected function assertEqual($actual, $expected, $message = '') {
|
||||
$this->assertEquals($expected, $actual, $message);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assertNotEqual()
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use
|
||||
* self::assertNotEquals() instead.
|
||||
*/
|
||||
protected function assertNotEqual($actual, $expected, $message = '') {
|
||||
$this->assertNotEquals($expected, $actual, $message);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assertIdentical()
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use self::assertSame()
|
||||
* instead.
|
||||
*/
|
||||
protected function assertIdentical($actual, $expected, $message = '') {
|
||||
$this->assertSame($expected, $actual, $message);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assertNotIdentical()
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use
|
||||
* self::assertNotSame() instead.
|
||||
*/
|
||||
protected function assertNotIdentical($actual, $expected, $message = '') {
|
||||
$this->assertNotSame($expected, $actual, $message);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::assertIdenticalObject()
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use self::assertEquals()
|
||||
* instead.
|
||||
*/
|
||||
protected function assertIdenticalObject($actual, $expected, $message = '') {
|
||||
// Note: ::assertSame checks whether its the same object. ::assertEquals
|
||||
// though compares
|
||||
|
||||
$this->assertEquals($expected, $actual, $message);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::pass()
|
||||
*
|
||||
* @deprecated Scheduled for removal in Drupal 9.0.0. Use self::assertTrue()
|
||||
* instead.
|
||||
*/
|
||||
protected function pass($message) {
|
||||
$this->assertTrue(TRUE, $message);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see \Drupal\simpletest\TestBase::verbose()
|
||||
*/
|
||||
protected function verbose($message) {
|
||||
if (in_array('--debug', $_SERVER['argv'], TRUE)) {
|
||||
// Write directly to STDOUT to not produce unexpected test output.
|
||||
// The STDOUT stream does not obey output buffering.
|
||||
fwrite(STDOUT, $message . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
}
|
1073
core/tests/Drupal/KernelTests/KernelTestBase.php
Normal file
1073
core/tests/Drupal/KernelTests/KernelTestBase.php
Normal file
File diff suppressed because it is too large
Load diff
229
core/tests/Drupal/KernelTests/KernelTestBaseTest.php
Normal file
229
core/tests/Drupal/KernelTests/KernelTestBaseTest.php
Normal file
|
@ -0,0 +1,229 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Contains \Drupal\KernelTests\KernelTestBaseTest.
|
||||
*/
|
||||
|
||||
namespace Drupal\KernelTests;
|
||||
|
||||
use Drupal\Core\Database\Database;
|
||||
use org\bovigo\vfs\vfsStream;
|
||||
use org\bovigo\vfs\visitor\vfsStreamStructureVisitor;
|
||||
|
||||
/**
|
||||
* @coversDefaultClass \Drupal\KernelTests\KernelTestBase
|
||||
* @group PHPUnit
|
||||
*/
|
||||
class KernelTestBaseTest extends KernelTestBase {
|
||||
|
||||
/**
|
||||
* @covers ::setUpBeforeClass
|
||||
*/
|
||||
public function testSetUpBeforeClass() {
|
||||
// Note: PHPUnit automatically restores the original working directory.
|
||||
$this->assertSame(realpath(__DIR__ . '/../../../../'), getcwd());
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::bootEnvironment
|
||||
*/
|
||||
public function testBootEnvironment() {
|
||||
$this->assertRegExp('/^simpletest\d{6}$/', $this->databasePrefix);
|
||||
$this->assertStringStartsWith('vfs://root/sites/simpletest/', $this->siteDirectory);
|
||||
$this->assertEquals(array(
|
||||
'root' => array(
|
||||
'sites' => array(
|
||||
'simpletest' => array(
|
||||
substr($this->databasePrefix, 10) => array(
|
||||
'files' => array(
|
||||
'config' => array(
|
||||
'active' => array(),
|
||||
'staging' => array(),
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
), vfsStream::inspect(new vfsStreamStructureVisitor())->getStructure());
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::getDatabaseConnectionInfo
|
||||
*/
|
||||
public function testGetDatabaseConnectionInfoWithOutManualSetDbUrl() {
|
||||
$options = $this->container->get('database')->getConnectionOptions();
|
||||
$this->assertSame($this->databasePrefix, $options['prefix']['default']);
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::setUp
|
||||
*/
|
||||
public function testSetUp() {
|
||||
$this->assertTrue($this->container->has('request_stack'));
|
||||
$this->assertTrue($this->container->initialized('request_stack'));
|
||||
$request = $this->container->get('request_stack')->getCurrentRequest();
|
||||
$this->assertNotEmpty($request);
|
||||
$this->assertEquals('/', $request->getPathInfo());
|
||||
|
||||
$this->assertSame($request, \Drupal::request());
|
||||
|
||||
$this->assertEquals($this, $GLOBALS['conf']['container_service_providers']['test']);
|
||||
|
||||
$GLOBALS['destroy-me'] = TRUE;
|
||||
$this->assertArrayHasKey('destroy-me', $GLOBALS);
|
||||
|
||||
$schema = $this->container->get('database')->schema();
|
||||
$schema->createTable('foo', array(
|
||||
'fields' => array(
|
||||
'number' => array(
|
||||
'type' => 'int',
|
||||
'unsigned' => TRUE,
|
||||
'not null' => TRUE,
|
||||
),
|
||||
),
|
||||
));
|
||||
$this->assertTrue($schema->tableExists('foo'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::setUp
|
||||
* @depends testSetUp
|
||||
*/
|
||||
public function testSetUpDoesNotLeak() {
|
||||
$this->assertArrayNotHasKey('destroy-me', $GLOBALS);
|
||||
|
||||
// Ensure that we have a different database prefix.
|
||||
$schema = $this->container->get('database')->schema();
|
||||
$this->assertFalse($schema->tableExists('foo'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::register
|
||||
*/
|
||||
public function testRegister() {
|
||||
// Verify that this container is identical to the actual container.
|
||||
$this->assertInstanceOf('Symfony\Component\DependencyInjection\ContainerInterface', $this->container);
|
||||
$this->assertSame($this->container, \Drupal::getContainer());
|
||||
|
||||
// The request service should never exist.
|
||||
$this->assertFalse($this->container->has('request'));
|
||||
|
||||
// Verify that there is a request stack.
|
||||
$request = $this->container->get('request_stack')->getCurrentRequest();
|
||||
$this->assertInstanceOf('Symfony\Component\HttpFoundation\Request', $request);
|
||||
$this->assertSame($request, \Drupal::request());
|
||||
|
||||
// Trigger a container rebuild.
|
||||
$this->enableModules(array('system'));
|
||||
|
||||
// Verify that this container is identical to the actual container.
|
||||
$this->assertInstanceOf('Symfony\Component\DependencyInjection\ContainerInterface', $this->container);
|
||||
$this->assertSame($this->container, \Drupal::getContainer());
|
||||
|
||||
// The request service should never exist.
|
||||
$this->assertFalse($this->container->has('request'));
|
||||
|
||||
// Verify that there is a request stack (and that it persisted).
|
||||
$new_request = $this->container->get('request_stack')->getCurrentRequest();
|
||||
$this->assertInstanceOf('Symfony\Component\HttpFoundation\Request', $new_request);
|
||||
$this->assertSame($new_request, \Drupal::request());
|
||||
$this->assertSame($request, $new_request);
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::getCompiledContainerBuilder
|
||||
*
|
||||
* The point of this test is to have integration level testing.
|
||||
*/
|
||||
public function testCompiledContainer() {
|
||||
$this->enableModules(['system', 'user']);
|
||||
$this->assertNull($this->installConfig('user'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::getCompiledContainerBuilder
|
||||
* @depends testCompiledContainer
|
||||
*
|
||||
* The point of this test is to have integration level testing.
|
||||
*/
|
||||
public function testCompiledContainerIsDestructed() {
|
||||
$this->enableModules(['system', 'user']);
|
||||
$this->assertNull($this->installConfig('user'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::render
|
||||
*/
|
||||
public function testRender() {
|
||||
$type = 'processed_text';
|
||||
$element_info = $this->container->get('element_info');
|
||||
$this->assertSame(['#defaults_loaded' => TRUE], $element_info->getInfo($type));
|
||||
|
||||
$this->enableModules(array('filter'));
|
||||
|
||||
$this->assertNotSame($element_info, $this->container->get('element_info'));
|
||||
$this->assertNotEmpty($this->container->get('element_info')->getInfo($type));
|
||||
|
||||
$build = array(
|
||||
'#type' => 'html_tag',
|
||||
'#tag' => 'h3',
|
||||
'#value' => 'Inner',
|
||||
);
|
||||
$expected = "<h3>Inner</h3>\n";
|
||||
|
||||
$this->assertEquals('core', \Drupal::theme()->getActiveTheme()->getName());
|
||||
$output = \Drupal::service('renderer')->renderRoot($build);
|
||||
$this->assertEquals('core', \Drupal::theme()->getActiveTheme()->getName());
|
||||
|
||||
$this->assertEquals($expected, $build['#children']);
|
||||
$this->assertEquals($expected, $output);
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers ::render
|
||||
*/
|
||||
public function testRenderWithTheme() {
|
||||
$this->enableModules(array('system'));
|
||||
|
||||
$build = array(
|
||||
'#type' => 'textfield',
|
||||
'#name' => 'test',
|
||||
);
|
||||
$expected = '/' . preg_quote('<input type="text" name="test"', '/') . '/';
|
||||
|
||||
$this->assertArrayNotHasKey('theme', $GLOBALS);
|
||||
$output = \Drupal::service('renderer')->renderRoot($build);
|
||||
$this->assertEquals('core', \Drupal::theme()->getActiveTheme()->getName());
|
||||
|
||||
$this->assertRegExp($expected, (string) $build['#children']);
|
||||
$this->assertRegExp($expected, (string) $output);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
protected function tearDown() {
|
||||
parent::tearDown();
|
||||
|
||||
// Check that all tables of the test instance have been deleted. At this
|
||||
// point the original database connection is restored so we need to prefix
|
||||
// the tables.
|
||||
$connection = Database::getConnection();
|
||||
if ($connection->databaseType() != 'sqlite') {
|
||||
$tables = $connection->schema()->findTables($this->databasePrefix . '%');
|
||||
$this->assertTrue(empty($tables), 'All test tables have been removed.');
|
||||
}
|
||||
else {
|
||||
$result = $connection->query("SELECT name FROM " . $this->databasePrefix . ".sqlite_master WHERE type = :type AND name LIKE :table_name AND name NOT LIKE :pattern", array(
|
||||
':type' => 'table',
|
||||
':table_name' => '%',
|
||||
':pattern' => 'sqlite_%',
|
||||
))->fetchAllKeyed(0, 0);
|
||||
|
||||
$this->assertTrue(empty($result), 'All test tables have been removed.');
|
||||
}
|
||||
}
|
||||
|
||||
}
|
Reference in a new issue