ShellTest.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Framework\App\Test\Unit;
  7. use Magento\Framework\App\Shell;
  8. use Magento\Framework\Exception\LocalizedException;
  9. use Magento\Framework\Shell\Response;
  10. class ShellTest extends \PHPUnit\Framework\TestCase
  11. {
  12. /** @var \PHPUnit_Framework_MockObject_MockObject | \Psr\Log\LoggerInterface */
  13. private $loggerMock;
  14. /** @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Framework\Shell\Driver */
  15. private $driverMock;
  16. /** @var \Magento\Framework\App\Shell */
  17. private $model;
  18. public function setUp()
  19. {
  20. $this->loggerMock = $this->getMockBuilder(\Psr\Log\LoggerInterface::class)
  21. ->disableOriginalConstructor()
  22. ->getMock();
  23. $this->driverMock = $this->getMockBuilder(\Magento\Framework\Shell\Driver::class)
  24. ->disableOriginalConstructor()
  25. ->getMock();
  26. $this->model = new Shell(
  27. $this->driverMock,
  28. $this->loggerMock
  29. );
  30. }
  31. public function testExecuteSuccess()
  32. {
  33. $output = 'success';
  34. $exitCode = 0;
  35. $command = 'escaped command';
  36. $logEntry = $command . PHP_EOL . $output;
  37. $successfulResponse = new Response(
  38. [
  39. 'output' => $output,
  40. 'exit_code' => $exitCode,
  41. 'escaped_command' => $command
  42. ]
  43. );
  44. $this->driverMock->expects($this->once())->method('execute')->willReturn($successfulResponse);
  45. $this->loggerMock->expects($this->once())->method('info')->with($logEntry);
  46. $this->assertEquals($output, $this->model->execute($command, []));
  47. }
  48. public function testExecuteFailure()
  49. {
  50. $output = 'failure';
  51. $exitCode = 1;
  52. $command = 'escaped command';
  53. $logEntry = $command . PHP_EOL . $output;
  54. $response = new Response(
  55. [
  56. 'output' => $output,
  57. 'exit_code' => $exitCode,
  58. 'escaped_command' => $command
  59. ]
  60. );
  61. $this->driverMock->expects($this->once())->method('execute')->willReturn($response);
  62. $this->loggerMock->expects($this->once())->method('error')->with($logEntry);
  63. $this->expectException(LocalizedException::class);
  64. $this->expectExceptionMessage("Command returned non-zero exit code:\n`$command`");
  65. $this->model->execute($command, []);
  66. }
  67. }