Skip to content

Commit

Permalink
Php Extensions Check
Browse files Browse the repository at this point in the history
  • Loading branch information
svilborg committed Jul 17, 2019
1 parent bd40d7d commit 58252e7
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 0 deletions.
34 changes: 34 additions & 0 deletions src/Checks/Php/Extensions.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
<?php
namespace Health\Checks\Php;

use Health\Checks\BaseCheck;
use Health\Checks\HealthCheckInterface;

class Extensions extends BaseCheck implements HealthCheckInterface
{

/**
*
* {@inheritdoc}
* @see \Health\Checks\HealthCheckInterface::call()
*/
public function call()
{
$builder = $this->getBuilder();

$extensions = $this->getParam('extensions', []);
$errors = [];

foreach ($extensions as $extension) {
if (! extension_loaded($extension)) {
$errors[] = $extension;
}
}

if ($errors) {
$builder->down()->withData('errors', $errors);
}

return $builder->build();
}
}
25 changes: 25 additions & 0 deletions tests/Checks/PhpExtensionsTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<?php
namespace Tests\Checks;

use Health\Checks\Php\Extensions;

class PhpExtensionsTest extends CheckTestCase
{

public function testCheckPhpConfigOptions()
{
$this->assertCheck($this->runCheck(Extensions::class, []), 'UP');

$this->assertCheck($this->runCheck(Extensions::class, [
'extensions' => [
'nosuch'
]
]), 'DOWN');

$this->assertCheck($this->runCheck(Extensions::class, [
'extensions' => [
'mbstring'
]
]), extension_loaded('mbstring') ? 'UP' : 'DOWN');
}
}

0 comments on commit 58252e7

Please sign in to comment.