Skip to content

Commit

Permalink
Make phpstan happy again
Browse files Browse the repository at this point in the history
  • Loading branch information
dinamic committed Jul 16, 2024
1 parent 6c3c74c commit 340eb4d
Showing 1 changed file with 18 additions and 6 deletions.
24 changes: 18 additions & 6 deletions src/Container/Container.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,11 @@
use Testcontainer\Registry;
use Testcontainer\Wait\WaitForNothing;
use Testcontainer\Wait\WaitInterface;
use UnexpectedValueException;

/**
* @phpstan-type ContainerInspect array{0: array{NetworkSettings: array{IPAddress: string}}}
* @phpstan-type ContainerInspectSingleNetwork array<int, array{'NetworkSettings': array{'IPAddress': string}}>
* @phpstan-type ContainerInspectMultipleNetworks array<int, array{'NetworkSettings': array{'Networks': array<string, array{'IPAddress': string}>}}>
*/
class Container
{
Expand All @@ -32,7 +34,7 @@ class Container
private int $healthCheckIntervalInMS;

/**
* @var ContainerInspect
* @var ContainerInspectSingleNetwork|ContainerInspectMultipleNetworks
*/
private array $inspectedData;

Expand Down Expand Up @@ -165,7 +167,7 @@ public function run(bool $wait = true): self
$inspect = new Process(['docker', 'inspect', $this->id]);
$inspect->mustRun();

/** @var ContainerInspect $inspectedData */
/** @var ContainerInspectSingleNetwork|ContainerInspectMultipleNetworks $inspectedData */
$inspectedData = json_decode($inspect->getOutput(), true, 512, JSON_THROW_ON_ERROR);

$this->inspectedData = $inspectedData;
Expand Down Expand Up @@ -256,10 +258,20 @@ public function logs(): string

public function getAddress(): string
{
if ($this->network !== null && !empty($this->inspectedData[0]['NetworkSettings']['Networks'][$this->network]['IPAddress'])) {
return $this->inspectedData[0]['NetworkSettings']['Networks'][$this->network]['IPAddress'];
if (is_string($this->network)) {
$containerAddress = $this->inspectedData[0]['NetworkSettings']['Networks'][$this->network]['IPAddress'] ?? null;

if (is_string($containerAddress)) {
return $containerAddress;
}
}

$containerAddress = $this->inspectedData[0]['NetworkSettings']['IPAddress'] ?? null;

if (is_string($containerAddress)) {
return $containerAddress;
}

return $this->inspectedData[0]['NetworkSettings']['IPAddress'];
throw new UnexpectedValueException('Unable to find container IP address');
}
}

0 comments on commit 340eb4d

Please sign in to comment.