Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
vendor
/
laravel
/
framework
/
src
/
Illuminate
/
Auth
:
FakeProcessSequence.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php namespace Illuminate\Process; use Illuminate\Contracts\Process\ProcessResult as ProcessResultContract; use OutOfBoundsException; class FakeProcessSequence { /** * The fake process results and descriptions. * * @var array */ protected $processes = []; /** * Indicates that invoking this sequence when it is empty should throw an exception. * * @var bool */ protected $failWhenEmpty = true; /** * The response that should be returned when the sequence is empty. * * @var \Illuminate\Contracts\Process\ProcessResult|\Illuminate\Process\FakeProcessDescription */ protected $emptyProcess; /** * Create a new fake process sequence instance. * * @param array $processes * @return void */ public function __construct(array $processes = []) { $this->processes = $processes; } /** * Push a new process result or description onto the sequence. * * @param \Illuminate\Contracts\Process\ProcessResult|\Illuminate\Process\FakeProcessDescription|array|string $process * @return $this */ public function push(ProcessResultContract|FakeProcessDescription|array|string $process) { $this->processes[] = $this->toProcessResult($process); return $this; } /** * Make the sequence return a default result when it is empty. * * @param \Illuminate\Contracts\Process\ProcessResult|\Illuminate\Process\FakeProcessDescription|array|string $process * @return $this */ public function whenEmpty(ProcessResultContract|FakeProcessDescription|array|string $process) { $this->failWhenEmpty = false; $this->emptyProcess = $this->toProcessResult($process); return $this; } /** * Convert the given result into an actual process result or description. * * @param \Illuminate\Contracts\Process\ProcessResult|\Illuminate\Process\FakeProcessDescription|array|string $process * @return \Illuminate\Contracts\Process\ProcessResult|\Illuminate\Process\FakeProcessDescription */ protected function toProcessResult(ProcessResultContract|FakeProcessDescription|array|string $process) { return is_array($process) || is_string($process) ? new FakeProcessResult(output: $process) : $process; } /** * Make the sequence return a default result when it is empty. * * @return $this */ public function dontFailWhenEmpty() { return $this->whenEmpty(new FakeProcessResult); } /** * Indicate that this sequence has depleted all of its process results. * * @return bool */ public function isEmpty() { return count($this->processes) === 0; } /** * Get the next process in the sequence. * * @return \Illuminate\Contracts\Process\ProcessResult|\Illuminate\Process\FakeProcessDescription * * @throws \OutOfBoundsException */ public function __invoke() { if ($this->failWhenEmpty && count($this->processes) === 0) { throw new OutOfBoundsException('A process was invoked, but the process result sequence is empty.'); } if (! $this->failWhenEmpty && count($this->processes) === 0) { return value($this->emptyProcess ?? new FakeProcessResult); } return array_shift($this->processes); } }