123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261 |
- <?php
- /*
- * 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\Smoke;
- use Keradus\CliExecutor\CommandExecutor;
- use Keradus\CliExecutor\ScriptExecutor;
- use PhpCsFixer\Tests\TestCase;
- /**
- * @author Dariusz Rumiński <dariusz.ruminski@gmail.com>
- *
- * @internal
- *
- * @requires OS Linux|Darwin
- * @coversNothing
- * @group covers-nothing
- * @large
- */
- final class CiIntegrationTest extends TestCase
- {
- public static $fixtureDir;
- public static function setUpBeforeClass()
- {
- parent::setUpBeforeClass();
- self::$fixtureDir = __DIR__.'/../Fixtures/ci-integration';
- try {
- self::executeScript([
- 'rm -rf .git',
- 'git init -q',
- 'git config user.name test',
- 'git config user.email test',
- 'git add .',
- 'git commit -m "init" -q',
- ]);
- } catch (\RuntimeException $e) {
- self::markTestSkipped($e->getMessage());
- }
- }
- public static function tearDownAfterClass()
- {
- parent::tearDownAfterClass();
- self::executeCommand('rm -rf .git');
- }
- protected function tearDown()
- {
- parent::tearDown();
- self::executeScript([
- 'git reset . -q',
- 'git checkout . -q',
- 'git clean -fdq',
- 'git checkout master -q',
- ]);
- }
- /**
- * @param string $branchName
- * @param string[] $caseCommands
- * @param string[] $expectedResult1Lines
- * @param string[] $expectedResult2Lines
- * @param string $expectedResult3FilesLine
- *
- * @dataProvider provideIntegrationCases
- */
- public function testIntegration(
- $branchName,
- array $caseCommands,
- array $expectedResult1Lines,
- array $expectedResult2Lines,
- $expectedResult3FilesLine
- ) {
- self::executeScript(array_merge(
- [
- "git checkout -b ${branchName} -q",
- ],
- $caseCommands
- ));
- $integrationScript = explode("\n", str_replace('vendor/bin/', './../../../', file_get_contents(__DIR__.'/../../dev-tools/ci-integration.sh')));
- $steps = [
- "COMMIT_RANGE=\"master..${branchName}\"",
- "{$integrationScript[3]}\n{$integrationScript[4]}",
- $integrationScript[5],
- $integrationScript[6],
- $integrationScript[7],
- ];
- $result1 = self::executeScript([
- $steps[0],
- $steps[1],
- $steps[2],
- 'echo "$CHANGED_FILES"',
- ]);
- $this->assertSame(implode("\n", $expectedResult1Lines)."\n", $result1->getOutput());
- $result2 = self::executeScript([
- $steps[0],
- $steps[1],
- $steps[2],
- $steps[3],
- 'echo "${EXTRA_ARGS}"',
- ]);
- $this->assertSame(implode("\n", $expectedResult2Lines), $result2->getOutput());
- $result3 = self::executeScript([
- $steps[0],
- $steps[1],
- $steps[2],
- $steps[3],
- $steps[4],
- ]);
- $optionalIncompatibilityWarning = 'PHP needs to be a minimum version of PHP 5.6.0 and maximum version of PHP 7.3.*.
- Ignoring environment requirements because `PHP_CS_FIXER_IGNORE_ENV` is set. Execution may be unstable.
- ';
- $optionalXdebugWarning = 'You are running PHP CS Fixer with xdebug enabled. This has a major impact on runtime performance.
- If you need help while solving warnings, ask at https://gitter.im/PHP-CS-Fixer, we will help you!
- ';
- $expectedResult3Files = substr($expectedResult3FilesLine, 0, strpos($expectedResult3FilesLine, ' '));
- $pattern = sprintf(
- '/^(?:%s)?(?:%s)?%s\n([\.S]{%d})(?: [^\n]*)?\n%s$/',
- preg_quote($optionalIncompatibilityWarning, '/'),
- preg_quote($optionalXdebugWarning, '/'),
- preg_quote('Loaded config default from ".php_cs.dist".', '/'),
- \strlen($expectedResult3Files),
- preg_quote('Legend: ?-unknown, I-invalid file syntax, file ignored, S-Skipped, .-no changes, F-fixed, E-error', '/')
- );
- $this->assertRegExp($pattern, $result3->getError());
- preg_match($pattern, $result3->getError(), $matches);
- $this->assertArrayHasKey(1, $matches);
- $this->assertSame(substr_count($expectedResult3Files, '.'), substr_count($matches[1], '.'));
- $this->assertSame(substr_count($expectedResult3Files, 'S'), substr_count($matches[1], 'S'));
- $this->assertRegExp(
- '/^\s*Checked all files in \d+\.\d+ seconds, \d+\.\d+ MB memory used\s*$/',
- $result3->getOutput()
- );
- }
- public function provideIntegrationCases()
- {
- return [
- 'random-changes' => [
- 'random-changes',
- [
- 'touch dir\ a/file.php',
- 'rm -r dir\ c',
- 'echo "" >> dir\ b/file\ b.php',
- 'echo "echo 1;" >> dir\ b/file\ b.php',
- 'git add .',
- 'git commit -m "Random changes" -q',
- ],
- [
- 'dir a/file.php',
- 'dir b/file b.php',
- ],
- [
- '--path-mode=intersection',
- '--',
- 'dir a/file.php',
- 'dir b/file b.php',
- '',
- ],
- 'S. 2 / 2 (100%)',
- ],
- 'changes-including-dist-config-file' => [
- 'changes-including-dist-config-file',
- [
- 'echo "" >> dir\ b/file\ b.php',
- 'echo "echo 1;" >> dir\ b/file\ b.php',
- // `sed -i ...` is not handled the same on Linux and macOS
- 'sed -e \'s/@Symfony/@PSR2/\' .php_cs.dist > .php_cs.dist.new',
- 'mv .php_cs.dist.new .php_cs.dist',
- 'git add .',
- 'git commit -m "Random changes including config file" -q',
- ],
- [
- '.php_cs.dist',
- 'dir b/file b.php',
- ],
- [
- '',
- '',
- ],
- '... 3 / 3 (100%)',
- ],
- 'changes-including-custom-config-file-creation' => [
- 'changes-including-custom-config-file-creation',
- [
- 'echo "" >> dir\ b/file\ b.php',
- 'echo "echo 1;" >> dir\ b/file\ b.php',
- 'sed -e \'s/@Symfony/@PSR2/\' .php_cs.dist > .php_cs',
- 'git add .',
- 'git commit -m "Random changes including custom config file creation" -q',
- ],
- [
- '.php_cs',
- 'dir b/file b.php',
- ],
- [
- '',
- '',
- ],
- '... 3 / 3 (100%)',
- ],
- 'changes-including-composer-lock' => [
- 'changes-including-composer-lock',
- [
- 'echo "" >> dir\ b/file\ b.php',
- 'echo "echo 1;" >> dir\ b/file\ b.php',
- 'touch composer.lock',
- 'git add .',
- 'git commit -m "Random changes including composer.lock" -q',
- ],
- [
- 'composer.lock',
- 'dir b/file b.php',
- ],
- [
- '',
- '',
- ],
- '... 3 / 3 (100%)',
- ],
- ];
- }
- private static function executeCommand($command)
- {
- return CommandExecutor::create($command, self::$fixtureDir)->getResult();
- }
- private static function executeScript(array $scriptParts)
- {
- return ScriptExecutor::create($scriptParts, self::$fixtureDir)->getResult();
- }
- }
|