2021-02-12 23:23:34 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace ShlinkioTest\Shlink\CLI\Util;
|
|
|
|
|
2023-02-09 20:42:18 +01:00
|
|
|
use PHPUnit\Framework\Attributes\Test;
|
2022-10-22 14:37:13 +02:00
|
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
2021-02-12 23:23:34 +01:00
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
use Shlinkio\Shlink\CLI\Util\ProcessRunner;
|
|
|
|
use Symfony\Component\Console\Helper\DebugFormatterHelper;
|
|
|
|
use Symfony\Component\Console\Helper\HelperSet;
|
|
|
|
use Symfony\Component\Console\Helper\ProcessHelper;
|
|
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
|
|
use Symfony\Component\Process\Process;
|
|
|
|
|
|
|
|
class ProcessRunnerTest extends TestCase
|
|
|
|
{
|
|
|
|
private ProcessRunner $runner;
|
2022-10-24 19:53:13 +02:00
|
|
|
private MockObject & ProcessHelper $helper;
|
|
|
|
private MockObject & DebugFormatterHelper $formatter;
|
|
|
|
private MockObject & Process $process;
|
|
|
|
private MockObject & OutputInterface $output;
|
2021-02-12 23:23:34 +01:00
|
|
|
|
|
|
|
protected function setUp(): void
|
|
|
|
{
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->helper = $this->createMock(ProcessHelper::class);
|
|
|
|
$this->formatter = $this->createMock(DebugFormatterHelper::class);
|
|
|
|
$helperSet = $this->createMock(HelperSet::class);
|
2022-10-23 18:15:57 +02:00
|
|
|
$helperSet->method('get')->with('debug_formatter')->willReturn($this->formatter);
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->helper->method('getHelperSet')->with()->willReturn($helperSet);
|
|
|
|
$this->process = $this->createMock(Process::class);
|
|
|
|
$this->output = $this->createMock(OutputInterface::class);
|
|
|
|
|
|
|
|
$this->runner = new ProcessRunner($this->helper, fn () => $this->process);
|
2021-02-12 23:23:34 +01:00
|
|
|
}
|
|
|
|
|
2023-02-09 20:42:18 +01:00
|
|
|
#[Test]
|
2021-02-12 23:23:34 +01:00
|
|
|
public function noMessagesAreWrittenWhenOutputIsNotVerbose(): void
|
|
|
|
{
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->output->expects($this->exactly(2))->method('isVeryVerbose')->with()->willReturn(false);
|
|
|
|
$this->output->expects($this->once())->method('isDebug')->with()->willReturn(false);
|
|
|
|
$this->output->expects($this->never())->method('write');
|
2022-10-22 14:40:35 +02:00
|
|
|
$this->process->expects($this->once())->method('mustRun')->withAnyParameters()->willReturnSelf();
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->process->expects($this->never())->method('isSuccessful');
|
|
|
|
$this->process->expects($this->never())->method('getCommandLine');
|
|
|
|
$this->helper->expects($this->never())->method('wrapCallback');
|
|
|
|
$this->formatter->expects($this->never())->method('start');
|
|
|
|
$this->formatter->expects($this->never())->method('stop');
|
|
|
|
|
|
|
|
$this->runner->run($this->output, []);
|
2021-02-12 23:23:34 +01:00
|
|
|
}
|
|
|
|
|
2023-02-09 20:42:18 +01:00
|
|
|
#[Test]
|
2021-02-12 23:23:34 +01:00
|
|
|
public function someMessagesAreWrittenWhenOutputIsVerbose(): void
|
|
|
|
{
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->output->expects($this->exactly(2))->method('isVeryVerbose')->with()->willReturn(true);
|
|
|
|
$this->output->expects($this->once())->method('isDebug')->with()->willReturn(false);
|
|
|
|
$this->output->expects($this->exactly(2))->method('write')->withAnyParameters();
|
2022-10-22 14:40:35 +02:00
|
|
|
$this->process->expects($this->once())->method('mustRun')->withAnyParameters()->willReturnSelf();
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->process->expects($this->exactly(2))->method('isSuccessful')->with()->willReturn(true);
|
|
|
|
$this->process->expects($this->once())->method('getCommandLine')->with()->willReturn('true');
|
|
|
|
$this->formatter->expects($this->once())->method('start')->withAnyParameters()->willReturn('');
|
|
|
|
$this->formatter->expects($this->once())->method('stop')->withAnyParameters()->willReturn('');
|
|
|
|
$this->helper->expects($this->never())->method('wrapCallback');
|
|
|
|
|
|
|
|
$this->runner->run($this->output, []);
|
2021-02-12 23:23:34 +01:00
|
|
|
}
|
|
|
|
|
2023-02-09 20:42:18 +01:00
|
|
|
#[Test]
|
2021-02-12 23:23:34 +01:00
|
|
|
public function wrapsCallbackWhenOutputIsDebug(): void
|
|
|
|
{
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->output->expects($this->exactly(2))->method('isVeryVerbose')->with()->willReturn(false);
|
|
|
|
$this->output->expects($this->once())->method('isDebug')->with()->willReturn(true);
|
|
|
|
$this->output->expects($this->never())->method('write');
|
2022-10-22 14:40:35 +02:00
|
|
|
$this->process->expects($this->once())->method('mustRun')->withAnyParameters()->willReturnSelf();
|
2022-10-22 14:37:13 +02:00
|
|
|
$this->process->expects($this->never())->method('isSuccessful');
|
|
|
|
$this->process->expects($this->never())->method('getCommandLine');
|
|
|
|
$this->helper->expects($this->once())->method('wrapCallback')->withAnyParameters()->willReturn(
|
|
|
|
function (): void {
|
|
|
|
},
|
|
|
|
);
|
|
|
|
$this->formatter->expects($this->never())->method('start');
|
|
|
|
$this->formatter->expects($this->never())->method('stop');
|
|
|
|
|
|
|
|
$this->runner->run($this->output, []);
|
2021-02-12 23:23:34 +01:00
|
|
|
}
|
|
|
|
}
|