123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- <?php
- declare(strict_types=1);
- /*
- * This file is part of PHP CS Fixer.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- * Dariusz Rumiński <dariusz.ruminski@gmail.com>
- *
- * This source file is subject to the MIT license that is bundled
- * with this source code in the file LICENSE.
- */
- namespace PhpCsFixer\Tests;
- use org\bovigo\vfs\vfsStream;
- use org\bovigo\vfs\vfsStreamDirectory;
- use PhpCsFixer\FileRemoval;
- /**
- * @author ntzm
- *
- * @internal
- *
- * @covers \PhpCsFixer\FileRemoval
- */
- final class FileRemovalTest extends TestCase
- {
- /**
- * Should temporary files be removed on tear down?
- *
- * This is necessary for testShutdownRemovesObserved files, as the setup
- * runs in a separate process to trigger the shutdown function, and
- * tearDownAfterClass is called for every separate process
- *
- * @var bool
- */
- private static $removeFilesOnTearDown = true;
- public static function tearDownAfterClass(): void
- {
- if (self::$removeFilesOnTearDown) {
- @unlink(sys_get_temp_dir().'/cs_fixer_foo.php');
- @unlink(sys_get_temp_dir().'/cs_fixer_bar.php');
- }
- }
- public function testCleanRemovesObservedFiles(): void
- {
- $fs = $this->getMockFileSystem();
- $fileRemoval = new FileRemoval();
- $fileRemoval->observe($fs->url().'/foo.php');
- $fileRemoval->observe($fs->url().'/baz.php');
- $fileRemoval->clean();
- self::assertFileDoesNotExist($fs->url().'/foo.php');
- self::assertFileDoesNotExist($fs->url().'/baz.php');
- self::assertFileExists($fs->url().'/bar.php');
- }
- public function testDestructRemovesObservedFiles(): void
- {
- $fs = $this->getMockFileSystem();
- $fileRemoval = new FileRemoval();
- $fileRemoval->observe($fs->url().'/foo.php');
- $fileRemoval->observe($fs->url().'/baz.php');
- $fileRemoval->__destruct();
- self::assertFileDoesNotExist($fs->url().'/foo.php');
- self::assertFileDoesNotExist($fs->url().'/baz.php');
- self::assertFileExists($fs->url().'/bar.php');
- }
- public function testDeleteObservedFile(): void
- {
- $fs = $this->getMockFileSystem();
- $fileRemoval = new FileRemoval();
- $fileRemoval->observe($fs->url().'/foo.php');
- $fileRemoval->observe($fs->url().'/baz.php');
- $fileRemoval->delete($fs->url().'/foo.php');
- self::assertFileDoesNotExist($fs->url().'/foo.php');
- self::assertFileExists($fs->url().'/baz.php');
- }
- public function testDeleteNonObservedFile(): void
- {
- $fs = $this->getMockFileSystem();
- $fileRemoval = new FileRemoval();
- $fileRemoval->delete($fs->url().'/foo.php');
- self::assertFileDoesNotExist($fs->url().'/foo.php');
- }
- public function testSleep(): void
- {
- $this->expectException(\BadMethodCallException::class);
- $this->expectExceptionMessage('Cannot serialize PhpCsFixer\FileRemoval');
- $fileRemoval = new FileRemoval();
- $fileRemoval->__sleep();
- }
- public function testWakeup(): void
- {
- $this->expectException(\BadMethodCallException::class);
- $this->expectExceptionMessage('Cannot unserialize PhpCsFixer\FileRemoval');
- $fileRemoval = new FileRemoval();
- $fileRemoval->__wakeup();
- }
- /**
- * Must NOT be run as first test, see https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/pull/7104.
- *
- * @runInSeparateProcess
- *
- * @doesNotPerformAssertions
- */
- public function testShutdownRemovesObservedFilesSetup(): void
- {
- self::$removeFilesOnTearDown = false;
- $fileToBeDeleted = sys_get_temp_dir().'/cs_fixer_foo.php';
- $fileNotToBeDeleted = sys_get_temp_dir().'/cs_fixer_bar.php';
- file_put_contents($fileToBeDeleted, '');
- file_put_contents($fileNotToBeDeleted, '');
- $fileRemoval = new FileRemoval();
- $fileRemoval->observe($fileToBeDeleted);
- }
- /**
- * @depends testShutdownRemovesObservedFilesSetup
- */
- public function testShutdownRemovesObservedFiles(): void
- {
- self::assertFileDoesNotExist(sys_get_temp_dir().'/cs_fixer_foo.php');
- self::assertFileExists(sys_get_temp_dir().'/cs_fixer_bar.php');
- }
- private function getMockFileSystem(): vfsStreamDirectory
- {
- return vfsStream::setup('root', null, [
- 'foo.php' => '',
- 'bar.php' => '',
- 'baz.php' => '',
- ]);
- }
- }
|