2015-11-20 12:01:21 +13:00
|
|
|
<?php
|
2017-01-05 11:16:12 +13:00
|
|
|
|
|
|
|
namespace SilverStripe\EnvironmentCheck\Tests;
|
|
|
|
|
2017-08-25 15:19:45 +12:00
|
|
|
use Monolog\Logger;
|
2017-03-21 23:57:07 +13:00
|
|
|
use Psr\Log\LoggerInterface;
|
2017-08-25 15:19:45 +12:00
|
|
|
use Psr\Log\LogLevel;
|
2017-01-05 11:16:12 +13:00
|
|
|
use SilverStripe\Core\Config\Config;
|
|
|
|
use SilverStripe\Core\Injector\Injector;
|
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2017-03-21 23:57:07 +13:00
|
|
|
use SilverStripe\EnvironmentCheck\EnvironmentChecker;
|
2017-01-05 11:16:12 +13:00
|
|
|
use SilverStripe\EnvironmentCheck\EnvironmentCheckSuite;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class EnvironmentCheckerTest
|
|
|
|
*
|
|
|
|
* @package environmentcheck
|
|
|
|
*/
|
2015-11-21 19:18:35 +13:00
|
|
|
class EnvironmentCheckerTest extends SapphireTest
|
|
|
|
{
|
2016-07-12 14:08:29 +12:00
|
|
|
protected $usesDatabase = true;
|
|
|
|
|
2021-10-27 18:06:29 +13:00
|
|
|
protected function tearDown(): void
|
2015-11-21 19:18:35 +13:00
|
|
|
{
|
2017-08-25 15:19:45 +12:00
|
|
|
EnvironmentCheckSuite::reset();
|
2015-11-21 19:18:35 +13:00
|
|
|
parent::tearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testOnlyLogsWithErrors()
|
|
|
|
{
|
2017-03-21 23:57:07 +13:00
|
|
|
Config::modify()->set(EnvironmentChecker::class, 'log_results_warning', true);
|
|
|
|
Config::modify()->set(EnvironmentChecker::class, 'log_results_error', true);
|
2017-08-25 15:19:45 +12:00
|
|
|
|
|
|
|
EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckNoErrors());
|
|
|
|
|
|
|
|
$logger = $this->getMockBuilder(Logger::class)
|
|
|
|
->disableOriginalConstructor()
|
2024-09-10 18:03:57 +12:00
|
|
|
->onlyMethods(['log'])
|
2017-08-25 15:19:45 +12:00
|
|
|
->getMock();
|
|
|
|
|
|
|
|
$logger->expects($this->never())->method('log');
|
|
|
|
|
|
|
|
Injector::inst()->registerService($logger, LoggerInterface::class);
|
|
|
|
|
|
|
|
(new EnvironmentChecker('test suite', 'test'))->index();
|
2015-11-21 19:18:35 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testLogsWithWarnings()
|
|
|
|
{
|
2017-03-21 23:57:07 +13:00
|
|
|
Config::modify()->set(EnvironmentChecker::class, 'log_results_warning', true);
|
|
|
|
Config::modify()->set(EnvironmentChecker::class, 'log_results_error', false);
|
2017-08-25 15:19:45 +12:00
|
|
|
|
|
|
|
EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckWarnings());
|
|
|
|
EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckErrors());
|
|
|
|
|
|
|
|
$logger = $this->getMockBuilder(Logger::class)
|
|
|
|
->disableOriginalConstructor()
|
2024-09-10 18:03:57 +12:00
|
|
|
->onlyMethods(['log'])
|
2017-08-25 15:19:45 +12:00
|
|
|
->getMock();
|
|
|
|
|
2024-09-10 18:03:57 +12:00
|
|
|
$matcher = $this->once();
|
|
|
|
$logger->expects($matcher)
|
2017-08-25 15:19:45 +12:00
|
|
|
->method('log')
|
2024-09-10 18:03:57 +12:00
|
|
|
->willReturnCallback(function (mixed $level) use ($matcher) {
|
|
|
|
match ($matcher->numberOfInvocations()) {
|
|
|
|
1 => $this->assertSame(LogLevel::WARNING, $level),
|
|
|
|
};
|
|
|
|
});
|
2017-08-25 15:19:45 +12:00
|
|
|
|
|
|
|
Injector::inst()->registerService($logger, LoggerInterface::class);
|
|
|
|
|
|
|
|
(new EnvironmentChecker('test suite', 'test'))->index();
|
2015-11-21 19:18:35 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testLogsWithErrors()
|
|
|
|
{
|
2017-03-21 23:57:07 +13:00
|
|
|
Config::modify()->set(EnvironmentChecker::class, 'log_results_error', false);
|
|
|
|
Config::modify()->set(EnvironmentChecker::class, 'log_results_error', true);
|
2015-11-20 12:01:21 +13:00
|
|
|
|
2017-08-25 15:19:45 +12:00
|
|
|
EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckWarnings());
|
|
|
|
EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckErrors());
|
2015-11-20 12:01:21 +13:00
|
|
|
|
2017-08-25 15:19:45 +12:00
|
|
|
$logger = $this->getMockBuilder(Logger::class)
|
|
|
|
->disableOriginalConstructor()
|
2024-09-10 18:03:57 +12:00
|
|
|
->onlyMethods(['log'])
|
2017-08-25 15:19:45 +12:00
|
|
|
->getMock();
|
2015-11-20 12:01:21 +13:00
|
|
|
|
2024-09-10 18:03:57 +12:00
|
|
|
$matcher = $this->once();
|
|
|
|
$logger->expects($matcher)
|
2017-08-25 15:19:45 +12:00
|
|
|
->method('log')
|
2024-09-10 18:03:57 +12:00
|
|
|
->willReturnCallback(function (mixed $level) use ($matcher) {
|
|
|
|
match ($matcher->numberOfInvocations()) {
|
|
|
|
1 => $this->assertSame(LogLevel::ALERT, $level),
|
|
|
|
};
|
|
|
|
});
|
2017-08-25 15:19:45 +12:00
|
|
|
|
|
|
|
Injector::inst()->registerService($logger, LoggerInterface::class);
|
|
|
|
|
|
|
|
(new EnvironmentChecker('test suite', 'test'))->index();
|
2015-11-21 19:18:35 +13:00
|
|
|
}
|
|
|
|
}
|