Skip to content

Commit

Permalink
Refactored console command tests to use Application tester.
Browse files Browse the repository at this point in the history
  • Loading branch information
AlexSkrypnyk committed Dec 17, 2024
1 parent 2b186e2 commit 78bf86c
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 85 deletions.
23 changes: 23 additions & 0 deletions tests/phpunit/Functional/ApplicationFunctionalTestCase.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
<?php

declare(strict_types=1);

namespace YourNamespace\App\Tests\Functional;

use PHPUnit\Framework\TestCase;
use YourNamespace\App\Tests\Traits\ArrayTrait;
use YourNamespace\App\Tests\Traits\AssertTrait;
use YourNamespace\App\Tests\Traits\MockTrait;

/**
* Class ApplicationFunctionalTestCase.
*
* Base class to unit test scripts.
*/
abstract class ApplicationFunctionalTestCase extends TestCase {

use ArrayTrait;
use AssertTrait;
use MockTrait;

}
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,14 @@

declare(strict_types=1);

namespace YourNamespace\App\Tests\Unit\Command;
namespace YourNamespace\App\Tests\Functional;

use PHPUnit\Framework\Attributes\CoversMethod;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Group;
use Symfony\Component\Console\Command\Command;
use YourNamespace\App\Command\JokeCommand;
use YourNamespace\App\Tests\Traits\ConsoleTrait;
use YourNamespace\App\Tests\Traits\MockTrait;

/**
* Class JokeCommandTest.
Expand All @@ -19,32 +20,33 @@
#[CoversMethod(JokeCommand::class, 'configure')]
#[CoversMethod(JokeCommand::class, 'getJoke')]
#[Group('command')]
class JokeCommandTest extends CommandTestCase {
class JokeCommandTest extends ApplicationFunctionalTestCase {

use ConsoleTrait;
use MockTrait;

#[DataProvider('dataProviderExecute')]
public function testExecute(string $content, int $expected_code, array|string $expected_output = []): void {
public function testExecute(string $content, array $expected_output, bool $expected_fail = FALSE): void {
/** @var \YourNamespace\App\Command\JokeCommand $mock */
// @phpstan-ignore varTag.nativeType
$mock = $this->prepareMock(JokeCommand::class, [
'getContent' => $content,
]);
$mock->setName('joke');

$output = $this->runExecute($mock);

$this->assertEquals($expected_code, $this->commandTester->getStatusCode());
$expected_output = is_array($expected_output) ? $expected_output : [$expected_output];
$this->consoleInitApplicationTester($mock);
$output = $this->consoleApplicationRun([], [], $expected_fail);
foreach ($expected_output as $expected_output_string) {
$this->assertArrayContainsString($expected_output_string, $output);
$this->assertStringContainsString($expected_output_string, $output);
}
}

public static function dataProviderExecute(): array {
return [
[static::fixturePayload(['setup' => 'Test setup', 'punchline' => 'Test punchline']), Command::SUCCESS, ['Test setup', 'Test punchline']],
['', Command::FAILURE, ['Unable to retrieve a joke.']],
['non-json', Command::FAILURE, ['Unable to retrieve a joke.']],
[static::fixturePayload(['setup' => 'Test setup']), Command::FAILURE, ['Unable to retrieve a joke.']],
[static::fixturePayload(['setup' => 'Test setup', 'punchline' => 'Test punchline']), ['Test setup', 'Test punchline']],
['', ['Unable to retrieve a joke.'], TRUE],
['non-json', ['Unable to retrieve a joke.'], TRUE],
[static::fixturePayload(['setup' => 'Test setup']), ['Unable to retrieve a joke.'], TRUE],
];
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,12 @@

declare(strict_types=1);

namespace YourNamespace\App\Tests\Unit\Command;
namespace YourNamespace\App\Tests\Functional;

use PHPUnit\Framework\Attributes\CoversMethod;
use PHPUnit\Framework\Attributes\Group;
use YourNamespace\App\Command\SayHelloCommand;
use YourNamespace\App\Tests\Traits\ConsoleTrait;

/**
* Class SayHelloCommandTest.
Expand All @@ -16,11 +17,15 @@
#[CoversMethod(SayHelloCommand::class, 'execute')]
#[CoversMethod(SayHelloCommand::class, 'configure')]
#[Group('command')]
class SayHelloCommandTest extends CommandTestCase {
class SayHelloCommandTest extends ApplicationFunctionalTestCase {

use ConsoleTrait;

public function testExecute(): void {
$output = $this->runExecute(SayHelloCommand::class);
$this->assertArrayContainsString('Hello, Symfony console!', $output);
$this->consoleInitApplicationTester(SayHelloCommand::class);

$output = $this->consoleApplicationRun();
$this->assertStringContainsString('Hello, Symfony console!', $output);
}

}
8 changes: 5 additions & 3 deletions tests/phpunit/Traits/ConsoleTrait.php
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@
*/
trait ConsoleTrait {

use ReflectionTrait;

/**
* Application tester.
*/
Expand Down Expand Up @@ -54,9 +56,7 @@ protected function consoleInitApplicationTester(string|object $object_or_class,

$application->setAutoExit(FALSE);
$application->setCatchExceptions(FALSE);
if (method_exists($application, 'setCatchErrors')) {
$application->setCatchErrors(FALSE);
}
$application->setCatchErrors(FALSE);

$this->appTester = new ApplicationTester($application);
}
Expand All @@ -75,6 +75,8 @@ protected function consoleInitApplicationTester(string|object $object_or_class,
* Run output (stdout or stderr).
*/
protected function consoleApplicationRun(array $input = [], array $options = [], bool $expect_fail = FALSE): string {
$output = '';

$options += ['capture_stderr_separately' => TRUE];

try {
Expand Down
65 changes: 0 additions & 65 deletions tests/phpunit/Unit/Command/CommandTestCase.php

This file was deleted.

0 comments on commit 78bf86c

Please sign in to comment.