view vendor/consolidation/site-process/tests/RemoCommandsTest.php @ 5:12f9dff5fda9 tip

Update to Drupal core 8.7.1
author Chris Cannam
date Thu, 09 May 2019 15:34:47 +0100
parents
children
line wrap: on
line source
<?php

namespace Consolidation\SiteProcess;

use PHPUnit\Framework\TestCase;
use Symfony\Component\Console\Output\BufferedOutput;

class RemoCommandsTest extends TestCase implements CommandTesterInterface
{
    use CommandTesterTrait;

    /** @var string[] */
    protected $commandClasses;

    /**
     * Prepare to test our commandfile
     */
    public function setUp()
    {
        // Store the command classes we are going to test
        $this->commandClasses = [ \Consolidation\SiteProcess\Remo\RemoCommands::class ];
        $this->setupCommandTester('TestFixtureApp', '1.0.1');
    }

    /**
     * Data provider for testRemoCommands.
     *
     * Return an array of arrays, each of which contains the data for one test.
     * The parameters in each array should be:
     *
     *   - Expected output (actual output must CONTAIN this string)
     *   - Expected function status code
     *   - argv
     *
     * All of the remaining parameters after the first two are interpreted
     * to be the argv value to pass to the command. The application name
     * is automatically unshifted into argv[0] first.
     */
    public function remoTestCommandParameters()
    {
        return [

            [
                'Run a command identified by a site alias',
                self::STATUS_OK,
                'list',
            ],

            [
                'Not enough arguments (missing: "aliasName")',
                self::STATUS_ERROR,
                'run',
            ],
        ];
    }

    /**
     * Test our remo commandfile class. Each time this function is called,
     * it will be passed the expected output and expected status code; the
     * remainder of the arguments passed will be used as $argv.
     *
     * @dataProvider remoTestCommandParameters
     */
    public function testRemoCommands($expectedOutput, $expectedStatus, $variable_args)
    {
        // Set this to the path to a fixture configuration file if you'd like to use one.
        $configurationFile = false;

        // Create our argv array and run the command
        $argv = $this->argv(func_get_args());
        list($actualOutput, $statusCode) = $this->execute($argv, $this->commandClasses, $configurationFile);

        // Confirm that our output and status code match expectations
        $this->assertContains($expectedOutput, $actualOutput);
        $this->assertEquals($expectedStatus, $statusCode);
    }
}