Extract extraArgs and workingDir

This commit is contained in:
Oliver Davies 2024-02-21 13:00:16 +00:00
parent b4e7a71fe3
commit ee709b2966
5 changed files with 36 additions and 28 deletions

View file

@ -16,17 +16,14 @@ final class BuildCommand extends AbstractCommand
{
$projectType = null;
$extraArgs = $input->getOption('extra-args');
$workingDir = $input->getOption('working-dir');
$filesystem = new Filesystem();
// Attempt to prepopulate some of the options, such as the project type
// based on its dependencies.
// TODO: move this logic to a service so it can be tested.
if ($filesystem->exists($workingDir.'/composer.json')) {
if ($filesystem->exists($this->workingDir.'/composer.json')) {
$json = json_decode(
json: strval(file_get_contents($workingDir.'/composer.json')),
json: strval(file_get_contents($this->workingDir.'/composer.json')),
associative: true,
);
@ -45,15 +42,15 @@ final class BuildCommand extends AbstractCommand
// the option value if there is one.
$projectType = $input->getOption('type') ?? $projectType;
$isDockerCompose = $filesystem->exists($workingDir . '/docker-compose.yaml');
$isDockerCompose = $filesystem->exists($this->workingDir . '/docker-compose.yaml');
switch ($projectType) {
case ProjectType::Drupal->value:
if ($isDockerCompose) {
$process = Process::create(
command: ['docker', 'compose', 'build'],
extraArgs: $extraArgs,
workingDir: $workingDir,
extraArgs: $this->extraArgs,
workingDir: $this->workingDir,
);
$process->run();
@ -67,8 +64,8 @@ final class BuildCommand extends AbstractCommand
case ProjectType::Sculpin->value:
$process = Process::create(
command: ['./vendor/bin/sculpin', 'generate'],
extraArgs: $extraArgs,
workingDir: $workingDir,
extraArgs: $this->extraArgs,
workingDir: $this->workingDir,
);
$process->run();