![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/cartforge.co/vendor/magento/framework/Test/Unit/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ declare(strict_types=1); namespace Magento\Framework\Test\Unit; use Magento\Framework\Exception\LocalizedException; use Magento\Framework\Shell; use Magento\Framework\Shell\CommandRenderer; use Magento\Framework\Shell\CommandRendererInterface; use PHPUnit\Framework\MockObject\MockObject; use PHPUnit\Framework\TestCase; use Psr\Log\LoggerInterface; class ShellTest extends TestCase { /** * @var CommandRendererInterface|MockObject */ protected $commandRenderer; /** * @var LoggerInterface|MockObject */ protected $logger; /** * @inheritDoc */ protected function setUp(): void { $this->logger = $this->getMockBuilder(LoggerInterface::class) ->disableOriginalConstructor() ->getMockForAbstractClass(); $this->commandRenderer = new CommandRenderer(); } /** * Test that a command with input arguments returns an expected result. * * @param Shell $shell * @param string $command * @param array $commandArgs * @param string $expectedResult * * @return void */ protected function _testExecuteCommand(Shell $shell, $command, $commandArgs, $expectedResult): void { $this->expectOutputString(''); // nothing is expected to be ever printed to the standard output $actualResult = $shell->execute($command, $commandArgs); $this->assertEquals($expectedResult, $actualResult); } /** * @param string $command * @param array $commandArgs * @param string $expectedResult * * @return void * @dataProvider executeDataProvider */ public function testExecute($command, $commandArgs, $expectedResult): void { $this->_testExecuteCommand( new Shell($this->commandRenderer, $this->logger), $command, $commandArgs, $expectedResult ); } /** * @param string $command * @param array $commandArgs * @param string $expectedResult * @param array $expectedLogRecords * * @return void * @dataProvider executeDataProvider */ public function testExecuteLog($command, $commandArgs, $expectedResult, $expectedLogRecords): void { $quoteChar = substr(escapeshellarg(' '), 0, 1); $withArgs = []; // environment-dependent quote character foreach ($expectedLogRecords as $expectedLogMessage) { $expectedLogMessage = str_replace('`', $quoteChar, $expectedLogMessage); $withArgs[] = [$expectedLogMessage]; } $this->logger ->method('info') ->withConsecutive(...$withArgs); $this->_testExecuteCommand( new Shell($this->commandRenderer, $this->logger), $command, $commandArgs, $expectedResult ); } /** * @return array */ public function executeDataProvider(): array { // backtick symbol (`) has to be replaced with environment-dependent quote character return [ 'STDOUT' => ['php -r %s', ['echo 27181;'], '27181', ['php -r `echo 27181;` 2>&1', '27181']], 'STDERR' => [ 'php -r %s', ['fwrite(STDERR, 27182);'], '27182', ['php -r `fwrite(STDERR, 27182);` 2>&1', '27182'] ], 'piping STDERR -> STDOUT' => [ // intentionally no spaces around the pipe symbol 'php -r %s|php -r %s', ['fwrite(STDERR, 27183);', 'echo fgets(STDIN);'], '27183', ['php -r `fwrite(STDERR, 27183);` 2>&1|php -r `echo fgets(STDIN);` 2>&1', '27183'] ], 'piping STDERR -> STDERR' => [ 'php -r %s | php -r %s', ['fwrite(STDERR, 27184);', 'fwrite(STDERR, fgets(STDIN));'], '27184', ['php -r `fwrite(STDERR, 27184);` 2>&1 | php -r `fwrite(STDERR, fgets(STDIN));` 2>&1', '27184'] ] ]; } /** * @return void */ public function testExecuteFailure(): void { $this->expectException('Magento\Framework\Exception\LocalizedException'); $this->expectExceptionCode('0'); $this->expectExceptionMessage('Command returned non-zero exit code:'); $shell = new Shell($this->commandRenderer, $this->logger); $shell->execute('non_existing_command'); } /** * @param string $command * @param array $commandArgs * @param string $expectedError * * @return void * @dataProvider executeDataProvider */ public function testExecuteFailureDetails($command, $commandArgs, $expectedError): void { try { /* Force command to return non-zero exit code */ $commandArgs[count($commandArgs) - 1] .= ' exit(42);'; $this->testExecute($command, $commandArgs, ''); // no result is expected in a case of a command failure } catch (LocalizedException $e) { $this->assertInstanceOf('Exception', $e->getPrevious()); $this->assertEquals($expectedError, $e->getPrevious()->getMessage()); $this->assertEquals(42, $e->getPrevious()->getCode()); } } }