mirror of
https://github.com/Karaka-Management/phpOMS.git
synced 2026-01-11 17:58:41 +00:00
187 lines
5.4 KiB
PHP
187 lines
5.4 KiB
PHP
<?php
|
|
/**
|
|
* Orange Management
|
|
*
|
|
* PHP Version 7.2
|
|
*
|
|
* @package tests
|
|
* @copyright Dennis Eichhorn
|
|
* @license OMS License 1.0
|
|
* @version 1.0.0
|
|
* @link http://website.orange-management.de
|
|
*/
|
|
|
|
namespace phpOMS\tests\Log;
|
|
|
|
use phpOMS\Log\FileLogger;
|
|
use phpOMS\Log\LogLevel;
|
|
|
|
require_once __DIR__ . '/../Autoloader.php';
|
|
|
|
class FileLoggerTest extends \PHPUnit\Framework\TestCase
|
|
{
|
|
public function testAttributes() : void
|
|
{
|
|
$log = FileLogger::getInstance(__DIR__);
|
|
self::assertObjectHasAttribute('fp', $log);
|
|
self::assertObjectHasAttribute('path', $log);
|
|
|
|
if (\file_exists(__DIR__ . '/' . \date('Y-m-d') . '.log')) {
|
|
\unlink(__DIR__ . '/' . \date('Y-m-d') . '.log');
|
|
}
|
|
}
|
|
|
|
public function testDefault() : void
|
|
{
|
|
if (\file_exists(__DIR__ . '/' . \date('Y-m-d') . '.log')) {
|
|
\unlink(__DIR__ . '/' . \date('Y-m-d') . '.log');
|
|
}
|
|
|
|
$log = FileLogger::getInstance(__DIR__);
|
|
self::assertEquals([], $log->countLogs());
|
|
self::assertEquals([], $log->getHighestPerpetrator());
|
|
self::assertEquals([], $log->get());
|
|
self::assertEquals([], $log->getByLine());
|
|
|
|
if (\file_exists(__DIR__ . '/' . \date('Y-m-d') . '.log')) {
|
|
\unlink(__DIR__ . '/' . \date('Y-m-d') . '.log');
|
|
}
|
|
}
|
|
|
|
public function testGetSet() : void
|
|
{
|
|
if (\file_exists(__DIR__ . '/test.log')) {
|
|
\unlink(__DIR__ . '/test.log');
|
|
}
|
|
|
|
$log = new FileLogger(__DIR__ . '/test.log', false);
|
|
|
|
$log->emergency(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->alert(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->critical(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->error(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->warning(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->notice(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->info(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->debug(FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
$log->log(LogLevel::DEBUG, FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
|
|
self::assertEquals(1, $log->countLogs()['emergency'] ?? 0);
|
|
self::assertEquals(1, $log->countLogs()['alert'] ?? 0);
|
|
self::assertEquals(1, $log->countLogs()['critical'] ?? 0);
|
|
self::assertEquals(1, $log->countLogs()['error'] ?? 0);
|
|
self::assertEquals(1, $log->countLogs()['warning'] ?? 0);
|
|
self::assertEquals(1, $log->countLogs()['notice'] ?? 0);
|
|
self::assertEquals(1, $log->countLogs()['info'] ?? 0);
|
|
self::assertEquals(2, $log->countLogs()['debug'] ?? 0);
|
|
|
|
self::assertEquals(['0.0.0.0' => 9], $log->getHighestPerpetrator());
|
|
self::assertEquals([6, 7, 8, 9, 10], \array_keys($log->get(5, 1)));
|
|
self::assertEquals('alert', $log->getByLine(2)['level']);
|
|
|
|
\ob_start();
|
|
$log->console(FileLogger::MSG_FULL, true, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
$ob = \ob_get_clean();
|
|
|
|
// test without output
|
|
$log->console(FileLogger::MSG_FULL, false, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
self::assertTrue(\stripos($ob, 'msg;') !== false);
|
|
self::assertEquals(2, $log->countLogs()['info'] ?? 0);
|
|
|
|
\ob_start();
|
|
$log->console('test', true);
|
|
$ob = \ob_get_clean();
|
|
self::assertEquals(\date('[Y-m-d H:i:s] ') . "test\r\n", $ob);
|
|
|
|
\unlink(__DIR__ . '/test.log');
|
|
|
|
if (\file_exists(__DIR__ . '/' . \date('Y-m-d') . '.log')) {
|
|
\unlink(__DIR__ . '/' . \date('Y-m-d') . '.log');
|
|
}
|
|
|
|
\ob_clean();
|
|
}
|
|
|
|
public function testLogException() : void
|
|
{
|
|
self::expectException(\phpOMS\Stdlib\Base\Exception\InvalidEnumValue::class);
|
|
|
|
$log = new FileLogger(__DIR__ . '/test.log');
|
|
$log->log('testException', FileLogger::MSG_FULL, [
|
|
'message' => 'msg',
|
|
'line' => 11,
|
|
'file' => self::class,
|
|
]);
|
|
}
|
|
|
|
public function testTiming() : void
|
|
{
|
|
self::assertTrue(FileLogger::startTimeLog('test'));
|
|
self::assertFalse(FileLogger::startTimeLog('test'));
|
|
self::assertGreaterThan(0.0, FileLogger::endTimeLog('test'));
|
|
}
|
|
|
|
public static function tearDownAfterClass() : void
|
|
{
|
|
if (\file_exists(__DIR__ . '/test.log')) {
|
|
\unlink(__DIR__ . '/test.log');
|
|
}
|
|
|
|
if (\file_exists(__DIR__ . '/' . \date('Y-m-d') . '.log')) {
|
|
\unlink(__DIR__ . '/' . \date('Y-m-d') . '.log');
|
|
}
|
|
}
|
|
}
|