Skip to content

Commit

Permalink
Improve ExceptionTest::testConnectionExceptionSqLite so that it passes
Browse files Browse the repository at this point in the history
on linux running as root.
  • Loading branch information
jwage committed Apr 23, 2019
1 parent 2124cd7 commit a8c902f
Showing 1 changed file with 32 additions and 6 deletions.
38 changes: 32 additions & 6 deletions tests/Doctrine/Tests/DBAL/Functional/ExceptionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,13 @@
use Doctrine\DBAL\Schema\Table;
use Doctrine\Tests\DbalFunctionalTestCase;
use Throwable;
use const PHP_OS;
use function array_merge;
use function chmod;
use function defined;
use function exec;
use function file_exists;
use function posix_geteuid;
use function posix_getpwuid;
use function sprintf;
use function sys_get_temp_dir;
use function touch;
Expand Down Expand Up @@ -296,13 +299,16 @@ public function testConnectionExceptionSqLite($mode, $exceptionClass)
$filename = sprintf('%s/%s', sys_get_temp_dir(), 'doctrine_failed_connection_' . $mode . '.db');

if (file_exists($filename)) {
chmod($filename, 0200); // make the file writable again, so it can be removed on Windows
unlink($filename);
$this->cleanupReadOnlyFile($filename);
}

touch($filename);
chmod($filename, $mode);

if ($this->isLinuxRoot()) {
exec(sprintf('chattr +i %s', $filename));
}

$params = [
'driver' => 'pdo_sqlite',
'path' => $filename,
Expand All @@ -314,16 +320,21 @@ public function testConnectionExceptionSqLite($mode, $exceptionClass)
$table->addColumn('id', 'integer');

$this->expectException($exceptionClass);
foreach ($schema->toSql($conn->getDatabasePlatform()) as $sql) {
$conn->exec($sql);

try {
foreach ($schema->toSql($conn->getDatabasePlatform()) as $sql) {
$conn->exec($sql);
}
} finally {
$this->cleanupReadOnlyFile($filename);
}
}

public function getSqLiteOpenConnection()
{
return [
// mode 0 is considered read-only on Windows
[0000, defined('PHP_WINDOWS_VERSION_BUILD') ? Exception\ReadOnlyException::class : Exception\ConnectionException::class],
[0000, Exception\ReadOnlyException::class],
[0444, Exception\ReadOnlyException::class],
];
}
Expand Down Expand Up @@ -395,4 +406,19 @@ private function tearDownForeignKeyConstraintViolationExceptionTest()
$schemaManager->dropTable('owning_table');
$schemaManager->dropTable('constraint_error_table');
}

private function isLinuxRoot() : bool
{
return PHP_OS === 'Linux' && posix_getpwuid(posix_geteuid())['name'] === 'root';
}

private function cleanupReadOnlyFile(string $filename) : void
{
if ($this->isLinuxRoot()) {
exec(sprintf('chattr -i %s', $filename));
}

chmod($filename, 0200); // make the file writable again, so it can be removed on Windows
unlink($filename);
}
}

0 comments on commit a8c902f

Please sign in to comment.