| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 | <?php/* * This file is part of the Symfony package. * * (c) Fabien Potencier <fabien@symfony.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */namespace Symfony\Component\Console\Tester;use Symfony\Component\Console\Application;use Symfony\Component\Console\Input\ArrayInput;use Symfony\Component\Console\Input\InputInterface;use Symfony\Component\Console\Output\ConsoleOutput;use Symfony\Component\Console\Output\OutputInterface;use Symfony\Component\Console\Output\StreamOutput;/** * Eases the testing of console applications. * * When testing an application, don't forget to disable the auto exit flag: * *     $application = new Application(); *     $application->setAutoExit(false); * * @author Fabien Potencier <fabien@symfony.com> */class ApplicationTester{    private $application;    private $input;    private $statusCode;    /**     * @var OutputInterface     */    private $output;    private $captureStreamsIndependently = false;    public function __construct(Application $application)    {        $this->application = $application;    }    /**     * Executes the application.     *     * Available options:     *     *  * interactive:               Sets the input interactive flag     *  * decorated:                 Sets the output decorated flag     *  * verbosity:                 Sets the output verbosity flag     *  * capture_stderr_separately: Make output of stdOut and stdErr separately available     *     * @param array $input   An array of arguments and options     * @param array $options An array of options     *     * @return int The command exit code     */    public function run(array $input, $options = [])    {        $this->input = new ArrayInput($input);        if (isset($options['interactive'])) {            $this->input->setInteractive($options['interactive']);        }        $this->captureStreamsIndependently = \array_key_exists('capture_stderr_separately', $options) && $options['capture_stderr_separately'];        if (!$this->captureStreamsIndependently) {            $this->output = new StreamOutput(fopen('php://memory', 'w', false));            if (isset($options['decorated'])) {                $this->output->setDecorated($options['decorated']);            }            if (isset($options['verbosity'])) {                $this->output->setVerbosity($options['verbosity']);            }        } else {            $this->output = new ConsoleOutput(                isset($options['verbosity']) ? $options['verbosity'] : ConsoleOutput::VERBOSITY_NORMAL,                isset($options['decorated']) ? $options['decorated'] : null            );            $errorOutput = new StreamOutput(fopen('php://memory', 'w', false));            $errorOutput->setFormatter($this->output->getFormatter());            $errorOutput->setVerbosity($this->output->getVerbosity());            $errorOutput->setDecorated($this->output->isDecorated());            $reflectedOutput = new \ReflectionObject($this->output);            $strErrProperty = $reflectedOutput->getProperty('stderr');            $strErrProperty->setAccessible(true);            $strErrProperty->setValue($this->output, $errorOutput);            $reflectedParent = $reflectedOutput->getParentClass();            $streamProperty = $reflectedParent->getProperty('stream');            $streamProperty->setAccessible(true);            $streamProperty->setValue($this->output, fopen('php://memory', 'w', false));        }        return $this->statusCode = $this->application->run($this->input, $this->output);    }    /**     * Gets the display returned by the last execution of the application.     *     * @param bool $normalize Whether to normalize end of lines to \n or not     *     * @return string The display     */    public function getDisplay($normalize = false)    {        rewind($this->output->getStream());        $display = stream_get_contents($this->output->getStream());        if ($normalize) {            $display = str_replace(PHP_EOL, "\n", $display);        }        return $display;    }    /**     * Gets the output written to STDERR by the application.     *     * @param bool $normalize Whether to normalize end of lines to \n or not     *     * @return string     */    public function getErrorOutput($normalize = false)    {        if (!$this->captureStreamsIndependently) {            throw new \LogicException('The error output is not available when the tester is run without "capture_stderr_separately" option set.');        }        rewind($this->output->getErrorOutput()->getStream());        $display = stream_get_contents($this->output->getErrorOutput()->getStream());        if ($normalize) {            $display = str_replace(PHP_EOL, "\n", $display);        }        return $display;    }    /**     * Gets the input instance used by the last execution of the application.     *     * @return InputInterface The current input instance     */    public function getInput()    {        return $this->input;    }    /**     * Gets the output instance used by the last execution of the application.     *     * @return OutputInterface The current output instance     */    public function getOutput()    {        return $this->output;    }    /**     * Gets the status code returned by the last execution of the application.     *     * @return int The status code     */    public function getStatusCode()    {        return $this->statusCode;    }}
 |