Skip to content

Commit

Permalink
Extract a shared Command method for asking for a string
Browse files Browse the repository at this point in the history
  • Loading branch information
caendesilva committed Oct 29, 2023
1 parent a121e9c commit 5c65d8a
Show file tree
Hide file tree
Showing 4 changed files with 51 additions and 11 deletions.
7 changes: 1 addition & 6 deletions packages/framework/src/Console/Commands/MakePageCommand.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
use Hyde\Pages\BladePage;
use Hyde\Pages\DocumentationPage;
use Hyde\Pages\MarkdownPage;
use LaravelZero\Framework\Commands\Command;
use Hyde\Console\Concerns\Command;

use function strtolower;
use function ucfirst;
Expand Down Expand Up @@ -116,9 +116,4 @@ protected function getTypeOption(): ?string

return null;
}

protected function askForString(string $question, ?string $default = null): ?string
{
return $this->ask($question, $default);
}
}
5 changes: 0 additions & 5 deletions packages/framework/src/Console/Commands/MakePostCommand.php
Original file line number Diff line number Diff line change
Expand Up @@ -99,9 +99,4 @@ protected function createPostFile(CreatesNewMarkdownPostFile $creator): int
return (int) $exception->getCode();
}
}

protected function askForString(string $question, ?string $default = null): ?string
{
return is_string($answer = $this->output->ask($question, $default)) ? $answer : null;
}
}
9 changes: 9 additions & 0 deletions packages/framework/src/Console/Concerns/Command.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
use Hyde\Facades\Config;
use LaravelZero\Framework\Commands\Command as BaseCommand;

use function is_string;
use function array_keys;
use function array_values;
use function realpath;
Expand Down Expand Up @@ -128,4 +129,12 @@ public function indentedLine(int $spaces, string $string): void
{
$this->line(str_repeat(' ', $spaces).$string);
}

public function askForString(string $question, ?string $default = null): ?string
{
/** @var string|null $answer */
$answer = $this->output->ask($question, $default);

return is_string($answer) ? $answer : $default;
}
}
41 changes: 41 additions & 0 deletions packages/framework/tests/Feature/CommandTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -215,13 +215,54 @@ public function testCanEnableThrowOnException()
$this->assertSame(1, $code);
}

public function testAskForString()
{
$this->testOutput(function ($command) {
$this->assertSame('foo', $command->askForString('foo'));
}, function ($output) {
$output->shouldReceive('ask')->once()->withArgs(function (string $question, ?string $default): bool {
return $this->assertIsSame('foo', $question) && $this->assertIsNull($default);
})->andReturn('foo');
});
}

public function testAskForStringWithDefaultValue()
{
$this->testOutput(function ($command) {
$this->assertSame('foo', $command->askForString('foo', 'bar'));
}, function ($output) {
$output->shouldReceive('ask')->once()->withArgs(function (string $question, ?string $default): bool {
return $this->assertIsSame('foo', $question) && $this->assertIsSame('bar', $default);
})->andReturn('foo');
});
}

public function testAskForStringWithDefaultValueSupplyingNull()
{
$this->testOutput(function ($command) {
$this->assertSame('bar', $command->askForString('foo', 'bar'));
}, function ($output) {
$output->shouldReceive('ask')->once()->withArgs(function (string $question, ?string $default): bool {
return $this->assertIsSame('foo', $question) && $this->assertIsSame('bar', $default);
})->andReturn(null);
});
}

protected function assertIsSame(string $expected, string $actual): bool
{
$this->assertSame($expected, $actual);

return $actual === $expected;
}

protected function assertIsNull(mixed $expected): bool
{
$this->assertNull($expected);

return $expected === null;
}


protected function testOutput(Closure $closure, Closure $expectations = null): void
{
$command = new MockableTestCommand();
Expand Down

0 comments on commit 5c65d8a

Please sign in to comment.