Parallelization::fetchItems()
now requiresOutputInterface
as a second parameter- A lot more type-safety and validation has been added with a comprehensive message upon failure.
- When no number of process is given (via
-p|--processes
), the command is no longer executed in the main process. Instead, the number of processes is guessed based on the maximum number of cores detected. Note that the execution within the main process instead of spawning child processes can be guaranteed by passing--main-process
. - Child processes will always be spawned regardless of the number of items
(known or not), the number of processes defined (or not defined). Instead
the processing will occur only if the
--main-process
option is passed. ParallelizationInput
should be created from the new factory::fromInput()
ContainerAwareCommand
has been removed.Parallelization
instead provides a::getContainer()
method which by defaults returns the Symfony Application Kernel's container when available.- The
Parallelization#logError
property has been deprecated. Override the new::createErrorHandler()
method instead. - Rename
ParallelizationInput::configureParallelization()
to::configureCommand()
- The
Parallelization::configureParallelization()
method has been deprecated. UseParallelizationInput::configureCommand()
directly instead. - Most of the execution of the
Parallelization
trait has been moved to theParallelExecutor
. Certain pieces are no longer overridable, but each key element should remain configurable. Since creating theParallelExecutor
is quite complex, aParallelExecutorFactory
has been introduced allowing to create an executor whilst overriding only the necessary bits. All the following methods have been deprecated in favour of overriding::getParallelExecutableFactory()
to configure the factory instead:::getProgressSymbol()
::detectPhpExecutable()
::getWorkingDirectory()
::getEnvironmentVariables()
::getSegmentSize()
::getBatchSize()
::getConsolePath()
- As part of the previous point, the following methods will no longer be declared
in the
Parallelization
trait in 3.0. It is perfectly fine to still have a method with those names, but you need to register them to the factory (it will no longer be done automatically in 3.0) and you should not extend the current ones. The following methods are affected:::runBeforeFirstCommand()
::runAfterLastCommand()
::runBeforeBatch()
::runAfterBatch()
- The following methods have been removed from
Parallelization
and have no replacement (the existing and new extension points should be enough to cover those):::executeMasterProcess()
::executeChildProcess()
::processChildOutput()
::runTolerantSingleCommand()
::serializeInputOptions()
::quoteOptionValue()
::isValueRequiresQuoting()
::fetchItems()
can now return aniterable
instead ofarray
::getItemName()
can now takenull
for an unknown number of items- Ensures that if an item is given, then the processing is done in the main process. An item also cannot be passed to a child process (via the argument).
- A
ErrorHandler
interface has been introduced which offers an extension point on how to handle an error that occurred when processing an item. TheParallelization
trait offers a::createErrorHandler()
method which by default logs the error and resets the Container (when resettable) in order to avoid issues such as a broken Doctrine UnitOfWork. - The logging has been consolidated into a
Logger
interface which can be overridden by::createLogger()
provided in theParallelization
trait - The logging has been consolidated into a
Logger
interface which can be overridden by::createLogger()
provided in theParallelization
trait - The process launching strategy and details has been moved to the
ProcessLauncher
andProcessLauncherFactory
interfaces. To change the process launching implementation used, you can configure it viaParallelExecutorFactory::withProcessLauncherFactory()
.
Notable "internal" BC breaks:
ItemBatchIterable
has been renamed toChunkedItemsIterator
ParallelizationInput
is now only validated when creating it via the new factory::fromInput()
- Most of the execution of the
Parallelization
trait has been moved to theParallelExecutor
. Certain pieces are no longer overridable, but each key element should remain configurable. ProcessLauncher
has been renamed toSymfonyProcessLauncher
and moved under theProcess
namespace.- A few parameters have been added to
SymfonyProcessLauncher