From f3936b82cdaa965ed043be0bc30f056749df4233 Mon Sep 17 00:00:00 2001 From: Simon Berger Date: Tue, 8 Sep 2020 11:33:41 +0200 Subject: [PATCH] Added test to cancel ProcessExecutor::asyncExecute --- tests/Composer/Test/Util/ProcessExecutorTest.php | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/tests/Composer/Test/Util/ProcessExecutorTest.php b/tests/Composer/Test/Util/ProcessExecutorTest.php index 87c2d07cc..a05f49c72 100644 --- a/tests/Composer/Test/Util/ProcessExecutorTest.php +++ b/tests/Composer/Test/Util/ProcessExecutorTest.php @@ -16,6 +16,7 @@ use Composer\IO\ConsoleIO; use Composer\Util\ProcessExecutor; use Composer\Test\TestCase; use Composer\IO\BufferIO; +use React\Promise\Promise; use Symfony\Component\Console\Helper\HelperSet; use Symfony\Component\Console\Input\ArrayInput; use Symfony\Component\Console\Output\BufferedOutput; @@ -113,4 +114,15 @@ class ProcessExecutorTest extends TestCase $process->execute('php -r "echo \'foo\'.PHP_EOL;"'); $this->assertSame('foo'.PHP_EOL, $output->fetch()); } + + public function testExecuteAsyncCancel() + { + $process = new ProcessExecutor($buffer = new BufferIO('', StreamOutput::VERBOSITY_DEBUG)); + $process->enableAsync(); + /** @var Promise $promise */ + $promise = $process->executeAsync('echo foo'); + $this->assertEquals(1, $process->countActiveJobs()); + $promise->cancel(); + $this->assertEquals(0, $process->countActiveJobs()); + } }