blob: e060a5a7da11388b0f899044334527194931ea6a [file] [log] [blame]
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Code Coverage for D:\work\log4php-trunk\src\main\php/Logger.php</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link href="css/bootstrap.min.css" rel="stylesheet">
<link href="css/bootstrap-responsive.min.css" rel="stylesheet">
<link href="css/style.css" rel="stylesheet">
<!--[if lt IE 9]>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
</head>
<body>
<header>
<div class="container">
<div class="row">
<div class="span12">
<ul class="breadcrumb">
<li><a href="index.html">D:\work\log4php-trunk\src\main\php</a> <span class="divider">/</span></li>
<li class="active">Logger.php</li>
</ul>
</div>
</div>
</div>
</header>
<div class="container">
<table class="table table-bordered">
<thead>
<tr>
<td>&nbsp;</td>
<td colspan="10"><div align="center"><strong>Code Coverage</strong></div></td>
</tr>
<tr>
<td>&nbsp;</td>
<td colspan="3"><div align="center"><strong>Classes and Traits</strong></div></td>
<td colspan="4"><div align="center"><strong>Functions and Methods</strong></div></td>
<td colspan="3"><div align="center"><strong>Lines</strong></div></td>
</tr>
</thead>
<tbody>
<tr>
<td class="danger">Total</td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 84.09%;"></div>
</div>
</td>
<td class="success small"><div align="right">84.09%</div></td>
<td class="success small"><div align="right">37 / 44</div></td>
<td class="success small"><acronym title="Change Risk Anti-Patterns (CRAP) Index">CRAP</acronym></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 76.15%;"></div>
</div>
</td>
<td class="success small"><div align="right">76.15%</div></td>
<td class="success small"><div align="right">99 / 130</div></td>
</tr>
<tr>
<td class="danger">Logger</td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 84.09%;"></div>
</div>
</td>
<td class="success small"><div align="right">84.09%</div></td>
<td class="success small"><div align="right">37 / 44</div></td>
<td class="success small">136.44</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 76.15%;"></div>
</div>
</td>
<td class="success small"><div align="right">76.15%</div></td>
<td class="success small"><div align="right">99 / 130</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#73">__construct($name)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#81">getName()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#89">getParent()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#104">trace($message, $throwable = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#115">debug($message, $throwable = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#126">info($message, $throwable = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#137">warn($message, $throwable = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#148">error($message, $throwable = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#159">fatal($message, $throwable = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#171">log(LoggerLevel $level, $message, $throwable = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">5</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">11 / 11</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#193">logEvent(LoggerLoggingEvent $event)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">4</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">7 / 7</div></td>
</tr>
<tr>
<td class="danger" colspan="4">&nbsp;<a href="#211">assertLog($assertion = true, $msg = '')</a></td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="danger small">6</td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 4</div></td>
</tr>
<tr>
<td class="danger" colspan="4">&nbsp;<a href="#231">forcedLog($fqcn, $throwable, LoggerLevel $level, $message)</a></td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="danger small">12</td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 6</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#245">callAppenders($event)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">2</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">4 / 4</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#261">isEnabledFor(LoggerLevel $level)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#269">isTraceEnabled()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#277">isDebugEnabled()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#285">isInfoEnabled()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#293">isWarnEnabled()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#301">isErrorEnabled()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#309">isFatalEnabled()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#321">addAppender($appender)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">3 / 3</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#327">removeAllAppenders()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">2</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">4 / 4</div></td>
</tr>
<tr>
<td class="danger" colspan="4">&nbsp;<a href="#337">removeAppender($appender)</a></td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="danger small">4.25</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 75.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">75.00%</div></td>
<td class="success small"><div align="right">6 / 8</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#351">getAllAppenders()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#359">getAppender($name)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#367">setAdditivity($additive)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#375">getAdditivity()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="danger" colspan="4">&nbsp;<a href="#384">getEffectiveLevel()</a></td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="danger small">3.07</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 80.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">80.00%</div></td>
<td class="success small"><div align="right">4 / 5</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#396">getLevel()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#408">setLevel(LoggerLevel $level = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="danger" colspan="4">&nbsp;<a href="#418">isAttached(LoggerAppender $appender)</a></td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="danger small">2</td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#426">setParent(Logger $logger)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">2 / 2</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#449">getHierarchy()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">2</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">4 / 4</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#462">getLogger($name)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">2</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">4 / 4</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#473">getRootLogger()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">2</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">4 / 4</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#484">clear()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#491">resetConfiguration()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">4 / 4</div></td>
</tr>
<tr>
<td class="danger" colspan="4">&nbsp;<a href="#502">shutdown()</a></td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="danger small">2</td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#512">exists($name)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#521">getCurrentLoggers()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#540">configure($configuration = null, $configurator = null)</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">5 / 5</div></td>
</tr>
<tr>
<td class="danger" colspan="4">&nbsp;<a href="#555">getConfigurator($configurator = null)</a></td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 0.00%;"></div>
</div>
</td>
<td class="danger small"><div align="right">0.00%</div></td>
<td class="danger small"><div align="right">0 / 1</div></td>
<td class="danger small">41.41</td>
<td class="danger big"> <div class="progress progress-danger" style="width: 100px;">
<div class="bar" style="width: 11.11%;"></div>
</div>
</td>
<td class="danger small"><div align="right">11.11%</div></td>
<td class="danger small"><div align="right">2 / 18</div></td>
</tr>
<tr>
<td class="success" colspan="4">&nbsp;<a href="#593">isInitialized()</a></td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
<td class="success small">1</td>
<td class="success big"> <div class="progress progress-success" style="width: 100px;">
<div class="bar" style="width: 100.00%;"></div>
</div>
</td>
<td class="success small"><div align="right">100.00%</div></td>
<td class="success small"><div align="right">1 / 1</div></td>
</tr>
</tbody>
</table>
<table class="table table-borderless table-condensed">
<tbody>
<tr><td><div align="right"><a name="1"></a><a href="#1">1</a></div></td><td class="codeLine">&lt;?php</td></tr>
<tr><td><div align="right"><a name="2"></a><a href="#2">2</a></div></td><td class="codeLine">/**</td></tr>
<tr><td><div align="right"><a name="3"></a><a href="#3">3</a></div></td><td class="codeLine"> * Licensed to the Apache Software Foundation (ASF) under one or more</td></tr>
<tr><td><div align="right"><a name="4"></a><a href="#4">4</a></div></td><td class="codeLine"> * contributor license agreements. See the NOTICE file distributed with</td></tr>
<tr><td><div align="right"><a name="5"></a><a href="#5">5</a></div></td><td class="codeLine"> * this work for additional information regarding copyright ownership.</td></tr>
<tr><td><div align="right"><a name="6"></a><a href="#6">6</a></div></td><td class="codeLine"> * The ASF licenses this file to You under the Apache License, Version 2.0</td></tr>
<tr><td><div align="right"><a name="7"></a><a href="#7">7</a></div></td><td class="codeLine"> * (the &quot;License&quot;); you may not use this file except in compliance with</td></tr>
<tr><td><div align="right"><a name="8"></a><a href="#8">8</a></div></td><td class="codeLine"> * the License. You may obtain a copy of the License at</td></tr>
<tr><td><div align="right"><a name="9"></a><a href="#9">9</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="10"></a><a href="#10">10</a></div></td><td class="codeLine"> * http://www.apache.org/licenses/LICENSE-2.0</td></tr>
<tr><td><div align="right"><a name="11"></a><a href="#11">11</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="12"></a><a href="#12">12</a></div></td><td class="codeLine"> * Unless required by applicable law or agreed to in writing, software</td></tr>
<tr><td><div align="right"><a name="13"></a><a href="#13">13</a></div></td><td class="codeLine"> * distributed under the License is distributed on an &quot;AS IS&quot; BASIS,</td></tr>
<tr><td><div align="right"><a name="14"></a><a href="#14">14</a></div></td><td class="codeLine"> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</td></tr>
<tr><td><div align="right"><a name="15"></a><a href="#15">15</a></div></td><td class="codeLine"> * See the License for the specific language governing permissions and</td></tr>
<tr><td><div align="right"><a name="16"></a><a href="#16">16</a></div></td><td class="codeLine"> * limitations under the License.</td></tr>
<tr><td><div align="right"><a name="17"></a><a href="#17">17</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="18"></a><a href="#18">18</a></div></td><td class="codeLine"> * @package log4php</td></tr>
<tr><td><div align="right"><a name="19"></a><a href="#19">19</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="20"></a><a href="#20">20</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="21"></a><a href="#21">21</a></div></td><td class="codeLine">require dirname(__FILE__) . '/LoggerAutoloader.php';</td></tr>
<tr><td><div align="right"><a name="22"></a><a href="#22">22</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="23"></a><a href="#23">23</a></div></td><td class="codeLine">/**</td></tr>
<tr><td><div align="right"><a name="24"></a><a href="#24">24</a></div></td><td class="codeLine"> * This is the central class in the log4php package. All logging operations</td></tr>
<tr><td><div align="right"><a name="25"></a><a href="#25">25</a></div></td><td class="codeLine"> * are done through this class.</td></tr>
<tr><td><div align="right"><a name="26"></a><a href="#26">26</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="27"></a><a href="#27">27</a></div></td><td class="codeLine"> * The main logging methods are:</td></tr>
<tr><td><div align="right"><a name="28"></a><a href="#28">28</a></div></td><td class="codeLine"> * &lt;ul&gt;</td></tr>
<tr><td><div align="right"><a name="29"></a><a href="#29">29</a></div></td><td class="codeLine"> * &lt;li&gt;{@link trace()}&lt;/li&gt;</td></tr>
<tr><td><div align="right"><a name="30"></a><a href="#30">30</a></div></td><td class="codeLine"> * &lt;li&gt;{@link debug()}&lt;/li&gt;</td></tr>
<tr><td><div align="right"><a name="31"></a><a href="#31">31</a></div></td><td class="codeLine"> * &lt;li&gt;{@link info()}&lt;/li&gt;</td></tr>
<tr><td><div align="right"><a name="32"></a><a href="#32">32</a></div></td><td class="codeLine"> * &lt;li&gt;{@link warn()}&lt;/li&gt;</td></tr>
<tr><td><div align="right"><a name="33"></a><a href="#33">33</a></div></td><td class="codeLine"> * &lt;li&gt;{@link error()}&lt;/li&gt;</td></tr>
<tr><td><div align="right"><a name="34"></a><a href="#34">34</a></div></td><td class="codeLine"> * &lt;li&gt;{@link fatal()}&lt;/li&gt;</td></tr>
<tr><td><div align="right"><a name="35"></a><a href="#35">35</a></div></td><td class="codeLine"> * &lt;/ul&gt;</td></tr>
<tr><td><div align="right"><a name="36"></a><a href="#36">36</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="37"></a><a href="#37">37</a></div></td><td class="codeLine"> * @package log4php</td></tr>
<tr><td><div align="right"><a name="38"></a><a href="#38">38</a></div></td><td class="codeLine"> * @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0</td></tr>
<tr><td><div align="right"><a name="39"></a><a href="#39">39</a></div></td><td class="codeLine"> * @version SVN: $Id: Logger.php 1395241 2012-10-07 08:28:53Z ihabunek $</td></tr>
<tr><td><div align="right"><a name="40"></a><a href="#40">40</a></div></td><td class="codeLine"> * @link http://logging.apache.org/log4php</td></tr>
<tr><td><div align="right"><a name="41"></a><a href="#41">41</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="42"></a><a href="#42">42</a></div></td><td class="codeLine">class Logger {</td></tr>
<tr><td><div align="right"><a name="43"></a><a href="#43">43</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="44"></a><a href="#44">44</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="45"></a><a href="#45">45</a></div></td><td class="codeLine"> * Logger additivity. If set to true then child loggers will inherit</td></tr>
<tr><td><div align="right"><a name="46"></a><a href="#46">46</a></div></td><td class="codeLine"> * the appenders of their ancestors by default.</td></tr>
<tr><td><div align="right"><a name="47"></a><a href="#47">47</a></div></td><td class="codeLine"> * @var boolean</td></tr>
<tr><td><div align="right"><a name="48"></a><a href="#48">48</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="49"></a><a href="#49">49</a></div></td><td class="codeLine"> private $additive = true;</td></tr>
<tr><td><div align="right"><a name="50"></a><a href="#50">50</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="51"></a><a href="#51">51</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="52"></a><a href="#52">52</a></div></td><td class="codeLine"> * The Logger's fully qualified class name.</td></tr>
<tr><td><div align="right"><a name="53"></a><a href="#53">53</a></div></td><td class="codeLine"> * TODO: Determine if this is useful.</td></tr>
<tr><td><div align="right"><a name="54"></a><a href="#54">54</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="55"></a><a href="#55">55</a></div></td><td class="codeLine"> private $fqcn = 'Logger';</td></tr>
<tr><td><div align="right"><a name="56"></a><a href="#56">56</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="57"></a><a href="#57">57</a></div></td><td class="codeLine"> /** The assigned Logger level. */</td></tr>
<tr><td><div align="right"><a name="58"></a><a href="#58">58</a></div></td><td class="codeLine"> private $level;</td></tr>
<tr><td><div align="right"><a name="59"></a><a href="#59">59</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="60"></a><a href="#60">60</a></div></td><td class="codeLine"> /** The name of this Logger instance. */</td></tr>
<tr><td><div align="right"><a name="61"></a><a href="#61">61</a></div></td><td class="codeLine"> private $name;</td></tr>
<tr><td><div align="right"><a name="62"></a><a href="#62">62</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="63"></a><a href="#63">63</a></div></td><td class="codeLine"> /** The parent logger. Set to null if this is the root logger. */</td></tr>
<tr><td><div align="right"><a name="64"></a><a href="#64">64</a></div></td><td class="codeLine"> private $parent;</td></tr>
<tr><td><div align="right"><a name="65"></a><a href="#65">65</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="66"></a><a href="#66">66</a></div></td><td class="codeLine"> /** A collection of appenders linked to this logger. */</td></tr>
<tr><td><div align="right"><a name="67"></a><a href="#67">67</a></div></td><td class="codeLine"> private $appenders = array();</td></tr>
<tr><td><div align="right"><a name="68"></a><a href="#68">68</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="69"></a><a href="#69">69</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="70"></a><a href="#70">70</a></div></td><td class="codeLine"> * Constructor.</td></tr>
<tr><td><div align="right"><a name="71"></a><a href="#71">71</a></div></td><td class="codeLine"> * @param string $name Name of the logger.</td></tr>
<tr><td><div align="right"><a name="72"></a><a href="#72">72</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="73"></a><a href="#73">73</a></div></td><td class="codeLine"> public function __construct($name) {</td></tr>
<tr class="success popin" data-title="92 tests cover line 74" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testExists&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testClear&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerMDCTest::testPatterns&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testInitialSetup&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentResult&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testNullLevelWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testLazyFileOpen&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testChangedDateFormat&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testEcho&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testEchoHtml&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleDebug&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleWarn&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleError&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleFatal&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMailEventTest::testMail&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMailTest::testMail&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testHost&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testPort&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testDatabaseName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testCollectionName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testUserName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testPassword&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testTimeout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testActivateOptions&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testActivateOptionsNoCredentials&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormat&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormatThrowableInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormatThrowableInfoWithInnerException&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testClose&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderNullTest::testActivateOptions&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testSimpleWithDefaults&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testCustomizedSql&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testClose&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSyslogTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideAccept&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideDeny&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideNull&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelRangeTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelRangeTest::testDecideAcceptFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideAccept&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideDeny&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideNullMessage&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideNullMatch&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutHtmlTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutHtmlTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSimpleTest::testSimpleLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutTTCCTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutTTCCTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testLog4JNamespaceErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testNDC&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testMDC&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLoggerWithoutOption&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLoggerWithOption0&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testMessage&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingTrimRight&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingTrimLeft&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadEmpty&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadLeft&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadRight&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="74"></a><a href="#74">74</a></div></td><td class="codeLine"> $this-&gt;name = $name;</td></tr>
<tr class="success popin" data-title="92 tests cover line 75" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testExists&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testClear&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerMDCTest::testPatterns&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testInitialSetup&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentResult&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testNullLevelWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testLazyFileOpen&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testChangedDateFormat&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testEcho&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testEchoHtml&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleDebug&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleWarn&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleError&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleFatal&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMailEventTest::testMail&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMailTest::testMail&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testHost&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testPort&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testDatabaseName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testCollectionName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testUserName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testPassword&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testTimeout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testActivateOptions&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testActivateOptionsNoCredentials&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormat&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormatThrowableInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormatThrowableInfoWithInnerException&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testClose&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderNullTest::testActivateOptions&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testSimpleWithDefaults&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testCustomizedSql&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testClose&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSyslogTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideAccept&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideDeny&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideNull&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelRangeTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelRangeTest::testDecideAcceptFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideAccept&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideDeny&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideNullMessage&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideNullMatch&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutHtmlTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutHtmlTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSimpleTest::testSimpleLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutTTCCTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutTTCCTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testLog4JNamespaceErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testNDC&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testMDC&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLoggerWithoutOption&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLoggerWithOption0&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testMessage&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingTrimRight&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingTrimLeft&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadEmpty&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadLeft&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadRight&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="75"></a><a href="#75">75</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="76"></a><a href="#76">76</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="77"></a><a href="#77">77</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="78"></a><a href="#78">78</a></div></td><td class="codeLine"> * Returns the logger name.</td></tr>
<tr><td><div align="right"><a name="79"></a><a href="#79">79</a></div></td><td class="codeLine"> * @return string</td></tr>
<tr><td><div align="right"><a name="80"></a><a href="#80">80</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="81"></a><a href="#81">81</a></div></td><td class="codeLine"> public function getName() {</td></tr>
<tr class="success popin" data-title="111 tests cover line 82" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerMDCTest::testPatterns&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testInitialSetup&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testLazyFileOpen&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderDailyFileTest::testChangedDateFormat&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testEcho&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testEchoHtml&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleDebug&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleWarn&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleError&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleFatal&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFirePHPTest::testAppend_HandleDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMailEventTest::testMail&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMailTest::testMail&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testHost&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testPort&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testDatabaseName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testCollectionName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testUserName&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testPassword&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testTimeout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testActivateOptions&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testActivateOptionsNoCredentials&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormat&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormatThrowableInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testFormatThrowableInfoWithInnerException&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderMongoDBTest::testClose&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderNullTest::testActivateOptions&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testSimpleWithDefaults&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testCustomizedSql&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPDOTest::testClose&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSyslogTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideAccept&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideDeny&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDecideNull&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelRangeTest::testDecide&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelRangeTest::testDecideAcceptFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideAccept&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideDeny&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideNullMessage&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterStringMatchTest::testDecideNullMatch&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutHtmlTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutHtmlTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSimpleTest::testSimpleLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutTTCCTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutTTCCTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testWarnLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testLog4JNamespaceErrorLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testNDC&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutXmlTest::testMDC&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLoggerWithoutOption&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLoggerWithOption0&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testMessage&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingTrimRight&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingTrimLeft&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadEmpty&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadLeft&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testFormattingPadRight&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="82"></a><a href="#82">82</a></div></td><td class="codeLine"> return $this-&gt;name;</td></tr>
<tr><td><div align="right"><a name="83"></a><a href="#83">83</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="84"></a><a href="#84">84</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="85"></a><a href="#85">85</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="86"></a><a href="#86">86</a></div></td><td class="codeLine"> * Returns the parent Logger. Can be null if this is the root logger.</td></tr>
<tr><td><div align="right"><a name="87"></a><a href="#87">87</a></div></td><td class="codeLine"> * @return Logger</td></tr>
<tr><td><div align="right"><a name="88"></a><a href="#88">88</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="89"></a><a href="#89">89</a></div></td><td class="codeLine"> public function getParent() {</td></tr>
<tr class="success popin" data-title="16 tests cover line 90" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testInitialSetup&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentResult&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="90"></a><a href="#90">90</a></div></td><td class="codeLine"> return $this-&gt;parent;</td></tr>
<tr><td><div align="right"><a name="91"></a><a href="#91">91</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="92"></a><a href="#92">92</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="93"></a><a href="#93">93</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="94"></a><a href="#94">94</a></div></td><td class="codeLine"> // *** Logging methods ***</td></tr>
<tr><td><div align="right"><a name="95"></a><a href="#95">95</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="96"></a><a href="#96">96</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="97"></a><a href="#97">97</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="98"></a><a href="#98">98</a></div></td><td class="codeLine"> * Log a message object with the TRACE level.</td></tr>
<tr><td><div align="right"><a name="99"></a><a href="#99">99</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="100"></a><a href="#100">100</a></div></td><td class="codeLine"> * @param mixed $message message</td></tr>
<tr><td><div align="right"><a name="101"></a><a href="#101">101</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="102"></a><a href="#102">102</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="103"></a><a href="#103">103</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="104"></a><a href="#104">104</a></div></td><td class="codeLine"> public function trace($message, $throwable = null) {</td></tr>
<tr class="success popin" data-title="5 tests cover line 105" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="105"></a><a href="#105">105</a></div></td><td class="codeLine"> $this-&gt;log(LoggerLevel::getLevelTrace(), $message, $throwable);</td></tr>
<tr class="success popin" data-title="5 tests cover line 106" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="106"></a><a href="#106">106</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="107"></a><a href="#107">107</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="108"></a><a href="#108">108</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="109"></a><a href="#109">109</a></div></td><td class="codeLine"> * Log a message object with the DEBUG level.</td></tr>
<tr><td><div align="right"><a name="110"></a><a href="#110">110</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="111"></a><a href="#111">111</a></div></td><td class="codeLine"> * @param mixed $message message</td></tr>
<tr><td><div align="right"><a name="112"></a><a href="#112">112</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="113"></a><a href="#113">113</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="114"></a><a href="#114">114</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="115"></a><a href="#115">115</a></div></td><td class="codeLine"> public function debug($message, $throwable = null) {</td></tr>
<tr class="success popin" data-title="11 tests cover line 116" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="116"></a><a href="#116">116</a></div></td><td class="codeLine"> $this-&gt;log(LoggerLevel::getLevelDebug(), $message, $throwable);</td></tr>
<tr class="success popin" data-title="11 tests cover line 117" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="117"></a><a href="#117">117</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="118"></a><a href="#118">118</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="119"></a><a href="#119">119</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="120"></a><a href="#120">120</a></div></td><td class="codeLine"> * Log a message object with the INFO Level.</td></tr>
<tr><td><div align="right"><a name="121"></a><a href="#121">121</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="122"></a><a href="#122">122</a></div></td><td class="codeLine"> * @param mixed $message message</td></tr>
<tr><td><div align="right"><a name="123"></a><a href="#123">123</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="124"></a><a href="#124">124</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="125"></a><a href="#125">125</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="126"></a><a href="#126">126</a></div></td><td class="codeLine"> public function info($message, $throwable = null) {</td></tr>
<tr class="success popin" data-title="21 tests cover line 127" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="127"></a><a href="#127">127</a></div></td><td class="codeLine"> $this-&gt;log(LoggerLevel::getLevelInfo(), $message, $throwable);</td></tr>
<tr class="success popin" data-title="21 tests cover line 128" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="128"></a><a href="#128">128</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="129"></a><a href="#129">129</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="130"></a><a href="#130">130</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="131"></a><a href="#131">131</a></div></td><td class="codeLine"> * Log a message with the WARN level.</td></tr>
<tr><td><div align="right"><a name="132"></a><a href="#132">132</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="133"></a><a href="#133">133</a></div></td><td class="codeLine"> * @param mixed $message message</td></tr>
<tr><td><div align="right"><a name="134"></a><a href="#134">134</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="135"></a><a href="#135">135</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="136"></a><a href="#136">136</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="137"></a><a href="#137">137</a></div></td><td class="codeLine"> public function warn($message, $throwable = null) {</td></tr>
<tr class="success popin" data-title="8 tests cover line 138" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="138"></a><a href="#138">138</a></div></td><td class="codeLine"> $this-&gt;log(LoggerLevel::getLevelWarn(), $message, $throwable);</td></tr>
<tr class="success popin" data-title="8 tests cover line 139" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="139"></a><a href="#139">139</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="140"></a><a href="#140">140</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="141"></a><a href="#141">141</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="142"></a><a href="#142">142</a></div></td><td class="codeLine"> * Log a message object with the ERROR level.</td></tr>
<tr><td><div align="right"><a name="143"></a><a href="#143">143</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="144"></a><a href="#144">144</a></div></td><td class="codeLine"> * @param mixed $message message</td></tr>
<tr><td><div align="right"><a name="145"></a><a href="#145">145</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="146"></a><a href="#146">146</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="147"></a><a href="#147">147</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="148"></a><a href="#148">148</a></div></td><td class="codeLine"> public function error($message, $throwable = null) {</td></tr>
<tr class="success popin" data-title="7 tests cover line 149" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="149"></a><a href="#149">149</a></div></td><td class="codeLine"> $this-&gt;log(LoggerLevel::getLevelError(), $message, $throwable);</td></tr>
<tr class="success popin" data-title="7 tests cover line 150" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="150"></a><a href="#150">150</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="151"></a><a href="#151">151</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="152"></a><a href="#152">152</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="153"></a><a href="#153">153</a></div></td><td class="codeLine"> * Log a message object with the FATAL level.</td></tr>
<tr><td><div align="right"><a name="154"></a><a href="#154">154</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="155"></a><a href="#155">155</a></div></td><td class="codeLine"> * @param mixed $message message</td></tr>
<tr><td><div align="right"><a name="156"></a><a href="#156">156</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="157"></a><a href="#157">157</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="158"></a><a href="#158">158</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="159"></a><a href="#159">159</a></div></td><td class="codeLine"> public function fatal($message, $throwable = null) {</td></tr>
<tr class="success popin" data-title="6 tests cover line 160" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="160"></a><a href="#160">160</a></div></td><td class="codeLine"> $this-&gt;log(LoggerLevel::getLevelFatal(), $message, $throwable);</td></tr>
<tr class="success popin" data-title="6 tests cover line 161" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="161"></a><a href="#161">161</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="162"></a><a href="#162">162</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="163"></a><a href="#163">163</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="164"></a><a href="#164">164</a></div></td><td class="codeLine"> * Log a message using the provided logging level.</td></tr>
<tr><td><div align="right"><a name="165"></a><a href="#165">165</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="166"></a><a href="#166">166</a></div></td><td class="codeLine"> * @param LoggerLevel $level The logging level.</td></tr>
<tr><td><div align="right"><a name="167"></a><a href="#167">167</a></div></td><td class="codeLine"> * @param mixed $message Message to log.</td></tr>
<tr><td><div align="right"><a name="168"></a><a href="#168">168</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="169"></a><a href="#169">169</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="170"></a><a href="#170">170</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="171"></a><a href="#171">171</a></div></td><td class="codeLine"> public function log(LoggerLevel $level, $message, $throwable = null) {</td></tr>
<tr class="success popin" data-title="27 tests cover line 172" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="172"></a><a href="#172">172</a></div></td><td class="codeLine"> if($this-&gt;isEnabledFor($level)) {</td></tr>
<tr class="success popin" data-title="27 tests cover line 173" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="173"></a><a href="#173">173</a></div></td><td class="codeLine"> $event = new LoggerLoggingEvent($this-&gt;fqcn, $this, $level, $message, null, $throwable);</td></tr>
<tr class="success popin" data-title="27 tests cover line 174" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="174"></a><a href="#174">174</a></div></td><td class="codeLine"> $this-&gt;callAppenders($event);</td></tr>
<tr class="success popin" data-title="27 tests cover line 175" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="175"></a><a href="#175">175</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="176"></a><a href="#176">176</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="177"></a><a href="#177">177</a></div></td><td class="codeLine"> // Forward the event upstream if additivity is turned on</td></tr>
<tr class="success popin" data-title="27 tests cover line 178" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="178"></a><a href="#178">178</a></div></td><td class="codeLine"> if(isset($this-&gt;parent) &amp;&amp; $this-&gt;getAdditivity()) {</td></tr>
<tr><td><div align="right"><a name="179"></a><a href="#179">179</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="180"></a><a href="#180">180</a></div></td><td class="codeLine"> // Use the event if already created</td></tr>
<tr class="success popin" data-title="11 tests cover line 181" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="181"></a><a href="#181">181</a></div></td><td class="codeLine"> if (isset($event)) {</td></tr>
<tr class="success popin" data-title="11 tests cover line 182" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="182"></a><a href="#182">182</a></div></td><td class="codeLine"> $this-&gt;parent-&gt;logEvent($event);</td></tr>
<tr class="success popin" data-title="11 tests cover line 183" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="183"></a><a href="#183">183</a></div></td><td class="codeLine"> } else {</td></tr>
<tr class="success popin" data-title="2 tests cover line 184" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="184"></a><a href="#184">184</a></div></td><td class="codeLine"> $this-&gt;parent-&gt;log($level, $message, $throwable);</td></tr>
<tr><td><div align="right"><a name="185"></a><a href="#185">185</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="11 tests cover line 186" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="186"></a><a href="#186">186</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="27 tests cover line 187" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="187"></a><a href="#187">187</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="188"></a><a href="#188">188</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="189"></a><a href="#189">189</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="190"></a><a href="#190">190</a></div></td><td class="codeLine"> * Logs an already prepared logging event object.</td></tr>
<tr><td><div align="right"><a name="191"></a><a href="#191">191</a></div></td><td class="codeLine"> * @param LoggerLoggingEvent $event</td></tr>
<tr><td><div align="right"><a name="192"></a><a href="#192">192</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="193"></a><a href="#193">193</a></div></td><td class="codeLine"> public function logEvent(LoggerLoggingEvent $event) {</td></tr>
<tr class="success popin" data-title="11 tests cover line 194" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="194"></a><a href="#194">194</a></div></td><td class="codeLine"> if($this-&gt;isEnabledFor($event-&gt;getLevel())) {</td></tr>
<tr class="success popin" data-title="11 tests cover line 195" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="195"></a><a href="#195">195</a></div></td><td class="codeLine"> $this-&gt;callAppenders($event);</td></tr>
<tr class="success popin" data-title="11 tests cover line 196" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="196"></a><a href="#196">196</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="197"></a><a href="#197">197</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="198"></a><a href="#198">198</a></div></td><td class="codeLine"> // Forward the event upstream if additivity is turned on</td></tr>
<tr class="success popin" data-title="11 tests cover line 199" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="199"></a><a href="#199">199</a></div></td><td class="codeLine"> if(isset($this-&gt;parent) &amp;&amp; $this-&gt;getAdditivity()) {</td></tr>
<tr class="success popin" data-title="2 tests cover line 200" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="200"></a><a href="#200">200</a></div></td><td class="codeLine"> $this-&gt;parent-&gt;logEvent($event);</td></tr>
<tr class="success popin" data-title="2 tests cover line 201" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="201"></a><a href="#201">201</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="11 tests cover line 202" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="202"></a><a href="#202">202</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="203"></a><a href="#203">203</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="204"></a><a href="#204">204</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="205"></a><a href="#205">205</a></div></td><td class="codeLine"> * If assertion parameter evaluates as false, then logs the message</td></tr>
<tr><td><div align="right"><a name="206"></a><a href="#206">206</a></div></td><td class="codeLine"> * using the ERROR level.</td></tr>
<tr><td><div align="right"><a name="207"></a><a href="#207">207</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="208"></a><a href="#208">208</a></div></td><td class="codeLine"> * @param bool $assertion</td></tr>
<tr><td><div align="right"><a name="209"></a><a href="#209">209</a></div></td><td class="codeLine"> * @param string $msg message to log</td></tr>
<tr><td><div align="right"><a name="210"></a><a href="#210">210</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="211"></a><a href="#211">211</a></div></td><td class="codeLine"> public function assertLog($assertion = true, $msg = '') {</td></tr>
<tr class="danger"><td><div align="right"><a name="212"></a><a href="#212">212</a></div></td><td class="codeLine"> if($assertion == false) {</td></tr>
<tr class="danger"><td><div align="right"><a name="213"></a><a href="#213">213</a></div></td><td class="codeLine"> $this-&gt;error($msg);</td></tr>
<tr class="danger"><td><div align="right"><a name="214"></a><a href="#214">214</a></div></td><td class="codeLine"> }</td></tr>
<tr class="danger"><td><div align="right"><a name="215"></a><a href="#215">215</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="216"></a><a href="#216">216</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="217"></a><a href="#217">217</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="218"></a><a href="#218">218</a></div></td><td class="codeLine"> * This method creates a new logging event and logs the event without</td></tr>
<tr><td><div align="right"><a name="219"></a><a href="#219">219</a></div></td><td class="codeLine"> * further checks.</td></tr>
<tr><td><div align="right"><a name="220"></a><a href="#220">220</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="221"></a><a href="#221">221</a></div></td><td class="codeLine"> * It should not be called directly. Use {@link trace()}, {@link debug()},</td></tr>
<tr><td><div align="right"><a name="222"></a><a href="#222">222</a></div></td><td class="codeLine"> * {@link info()}, {@link warn()}, {@link error()} and {@link fatal()}</td></tr>
<tr><td><div align="right"><a name="223"></a><a href="#223">223</a></div></td><td class="codeLine"> * wrappers.</td></tr>
<tr><td><div align="right"><a name="224"></a><a href="#224">224</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="225"></a><a href="#225">225</a></div></td><td class="codeLine"> * @param string $fqcn Fully qualified class name of the Logger</td></tr>
<tr><td><div align="right"><a name="226"></a><a href="#226">226</a></div></td><td class="codeLine"> * @param Exception $throwable Optional throwable information to include</td></tr>
<tr><td><div align="right"><a name="227"></a><a href="#227">227</a></div></td><td class="codeLine"> * in the logging event.</td></tr>
<tr><td><div align="right"><a name="228"></a><a href="#228">228</a></div></td><td class="codeLine"> * @param LoggerLevel $level log level</td></tr>
<tr><td><div align="right"><a name="229"></a><a href="#229">229</a></div></td><td class="codeLine"> * @param mixed $message message to log</td></tr>
<tr><td><div align="right"><a name="230"></a><a href="#230">230</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="231"></a><a href="#231">231</a></div></td><td class="codeLine"> public function forcedLog($fqcn, $throwable, LoggerLevel $level, $message) {</td></tr>
<tr class="danger"><td><div align="right"><a name="232"></a><a href="#232">232</a></div></td><td class="codeLine"> $event = new LoggerLoggingEvent($fqcn, $this, $level, $message, null, $throwable);</td></tr>
<tr class="danger"><td><div align="right"><a name="233"></a><a href="#233">233</a></div></td><td class="codeLine"> $this-&gt;callAppenders($event);</td></tr>
<tr><td><div align="right"><a name="234"></a><a href="#234">234</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="235"></a><a href="#235">235</a></div></td><td class="codeLine"> // Forward the event upstream if additivity is turned on</td></tr>
<tr class="danger"><td><div align="right"><a name="236"></a><a href="#236">236</a></div></td><td class="codeLine"> if(isset($this-&gt;parent) &amp;&amp; $this-&gt;getAdditivity()) {</td></tr>
<tr class="danger"><td><div align="right"><a name="237"></a><a href="#237">237</a></div></td><td class="codeLine"> $this-&gt;parent-&gt;logEvent($event);</td></tr>
<tr class="danger"><td><div align="right"><a name="238"></a><a href="#238">238</a></div></td><td class="codeLine"> }</td></tr>
<tr class="danger"><td><div align="right"><a name="239"></a><a href="#239">239</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="240"></a><a href="#240">240</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="241"></a><a href="#241">241</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="242"></a><a href="#242">242</a></div></td><td class="codeLine"> * Forwards the given logging event to all linked appenders.</td></tr>
<tr><td><div align="right"><a name="243"></a><a href="#243">243</a></div></td><td class="codeLine"> * @param LoggerLoggingEvent $event</td></tr>
<tr><td><div align="right"><a name="244"></a><a href="#244">244</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="245"></a><a href="#245">245</a></div></td><td class="codeLine"> public function callAppenders($event) {</td></tr>
<tr class="success popin" data-title="27 tests cover line 246" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="246"></a><a href="#246">246</a></div></td><td class="codeLine"> foreach($this-&gt;appenders as $appender) {</td></tr>
<tr class="success popin" data-title="27 tests cover line 247" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="247"></a><a href="#247">247</a></div></td><td class="codeLine"> $appender-&gt;doAppend($event);</td></tr>
<tr class="success popin" data-title="27 tests cover line 248" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="248"></a><a href="#248">248</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="27 tests cover line 249" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="249"></a><a href="#249">249</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="250"></a><a href="#250">250</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="251"></a><a href="#251">251</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="252"></a><a href="#252">252</a></div></td><td class="codeLine"> // *** Checker methods ***</td></tr>
<tr><td><div align="right"><a name="253"></a><a href="#253">253</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="254"></a><a href="#254">254</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="255"></a><a href="#255">255</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="256"></a><a href="#256">256</a></div></td><td class="codeLine"> * Check whether this Logger is enabled for a given Level passed as parameter.</td></tr>
<tr><td><div align="right"><a name="257"></a><a href="#257">257</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="258"></a><a href="#258">258</a></div></td><td class="codeLine"> * @param LoggerLevel level</td></tr>
<tr><td><div align="right"><a name="259"></a><a href="#259">259</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="260"></a><a href="#260">260</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="261"></a><a href="#261">261</a></div></td><td class="codeLine"> public function isEnabledFor(LoggerLevel $level) {</td></tr>
<tr class="success popin" data-title="28 tests cover line 262" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="262"></a><a href="#262">262</a></div></td><td class="codeLine"> return $level-&gt;isGreaterOrEqual($this-&gt;getEffectiveLevel());</td></tr>
<tr><td><div align="right"><a name="263"></a><a href="#263">263</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="264"></a><a href="#264">264</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="265"></a><a href="#265">265</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="266"></a><a href="#266">266</a></div></td><td class="codeLine"> * Check whether this Logger is enabled for the TRACE Level.</td></tr>
<tr><td><div align="right"><a name="267"></a><a href="#267">267</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="268"></a><a href="#268">268</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="269"></a><a href="#269">269</a></div></td><td class="codeLine"> public function isTraceEnabled() {</td></tr>
<tr class="success popin" data-title="1 test covers line 270" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="270"></a><a href="#270">270</a></div></td><td class="codeLine"> return $this-&gt;isEnabledFor(LoggerLevel::getLevelTrace());</td></tr>
<tr><td><div align="right"><a name="271"></a><a href="#271">271</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="272"></a><a href="#272">272</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="273"></a><a href="#273">273</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="274"></a><a href="#274">274</a></div></td><td class="codeLine"> * Check whether this Logger is enabled for the DEBUG Level.</td></tr>
<tr><td><div align="right"><a name="275"></a><a href="#275">275</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="276"></a><a href="#276">276</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="277"></a><a href="#277">277</a></div></td><td class="codeLine"> public function isDebugEnabled() {</td></tr>
<tr class="success popin" data-title="1 test covers line 278" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="278"></a><a href="#278">278</a></div></td><td class="codeLine"> return $this-&gt;isEnabledFor(LoggerLevel::getLevelDebug());</td></tr>
<tr><td><div align="right"><a name="279"></a><a href="#279">279</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="280"></a><a href="#280">280</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="281"></a><a href="#281">281</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="282"></a><a href="#282">282</a></div></td><td class="codeLine"> * Check whether this Logger is enabled for the INFO Level.</td></tr>
<tr><td><div align="right"><a name="283"></a><a href="#283">283</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="284"></a><a href="#284">284</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="285"></a><a href="#285">285</a></div></td><td class="codeLine"> public function isInfoEnabled() {</td></tr>
<tr class="success popin" data-title="1 test covers line 286" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="286"></a><a href="#286">286</a></div></td><td class="codeLine"> return $this-&gt;isEnabledFor(LoggerLevel::getLevelInfo());</td></tr>
<tr><td><div align="right"><a name="287"></a><a href="#287">287</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="288"></a><a href="#288">288</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="289"></a><a href="#289">289</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="290"></a><a href="#290">290</a></div></td><td class="codeLine"> * Check whether this Logger is enabled for the WARN Level.</td></tr>
<tr><td><div align="right"><a name="291"></a><a href="#291">291</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="292"></a><a href="#292">292</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="293"></a><a href="#293">293</a></div></td><td class="codeLine"> public function isWarnEnabled() {</td></tr>
<tr class="success popin" data-title="1 test covers line 294" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="294"></a><a href="#294">294</a></div></td><td class="codeLine"> return $this-&gt;isEnabledFor(LoggerLevel::getLevelWarn());</td></tr>
<tr><td><div align="right"><a name="295"></a><a href="#295">295</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="296"></a><a href="#296">296</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="297"></a><a href="#297">297</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="298"></a><a href="#298">298</a></div></td><td class="codeLine"> * Check whether this Logger is enabled for the ERROR Level.</td></tr>
<tr><td><div align="right"><a name="299"></a><a href="#299">299</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="300"></a><a href="#300">300</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="301"></a><a href="#301">301</a></div></td><td class="codeLine"> public function isErrorEnabled() {</td></tr>
<tr class="success popin" data-title="1 test covers line 302" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="302"></a><a href="#302">302</a></div></td><td class="codeLine"> return $this-&gt;isEnabledFor(LoggerLevel::getLevelError());</td></tr>
<tr><td><div align="right"><a name="303"></a><a href="#303">303</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="304"></a><a href="#304">304</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="305"></a><a href="#305">305</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="306"></a><a href="#306">306</a></div></td><td class="codeLine"> * Check whether this Logger is enabled for the FATAL Level.</td></tr>
<tr><td><div align="right"><a name="307"></a><a href="#307">307</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="308"></a><a href="#308">308</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="309"></a><a href="#309">309</a></div></td><td class="codeLine"> public function isFatalEnabled() {</td></tr>
<tr class="success popin" data-title="1 test covers line 310" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="310"></a><a href="#310">310</a></div></td><td class="codeLine"> return $this-&gt;isEnabledFor(LoggerLevel::getLevelFatal());</td></tr>
<tr><td><div align="right"><a name="311"></a><a href="#311">311</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="312"></a><a href="#312">312</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="313"></a><a href="#313">313</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="314"></a><a href="#314">314</a></div></td><td class="codeLine"> // *** Configuration methods ***</td></tr>
<tr><td><div align="right"><a name="315"></a><a href="#315">315</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="316"></a><a href="#316">316</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="317"></a><a href="#317">317</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="318"></a><a href="#318">318</a></div></td><td class="codeLine"> * Adds a new appender to the Logger.</td></tr>
<tr><td><div align="right"><a name="319"></a><a href="#319">319</a></div></td><td class="codeLine"> * @param LoggerAppender $appender The appender to add.</td></tr>
<tr><td><div align="right"><a name="320"></a><a href="#320">320</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="321"></a><a href="#321">321</a></div></td><td class="codeLine"> public function addAppender($appender) {</td></tr>
<tr class="success popin" data-title="44 tests cover line 322" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="322"></a><a href="#322">322</a></div></td><td class="codeLine"> $appenderName = $appender-&gt;getName();</td></tr>
<tr class="success popin" data-title="44 tests cover line 323" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="323"></a><a href="#323">323</a></div></td><td class="codeLine"> $this-&gt;appenders[$appenderName] = $appender;</td></tr>
<tr class="success popin" data-title="44 tests cover line 324" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="324"></a><a href="#324">324</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="325"></a><a href="#325">325</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="326"></a><a href="#326">326</a></div></td><td class="codeLine"> /** Removes all appenders from the Logger. */</td></tr>
<tr><td><div align="right"><a name="327"></a><a href="#327">327</a></div></td><td class="codeLine"> public function removeAllAppenders() {</td></tr>
<tr class="success popin" data-title="68 tests cover line 328" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="328"></a><a href="#328">328</a></div></td><td class="codeLine"> foreach($this-&gt;appenders as $name =&gt; $appender) {</td></tr>
<tr class="success popin" data-title="40 tests cover line 329" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="329"></a><a href="#329">329</a></div></td><td class="codeLine"> $this-&gt;removeAppender($name);</td></tr>
<tr class="success popin" data-title="68 tests cover line 330" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="330"></a><a href="#330">330</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="68 tests cover line 331" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="331"></a><a href="#331">331</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="332"></a><a href="#332">332</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="333"></a><a href="#333">333</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="334"></a><a href="#334">334</a></div></td><td class="codeLine"> * Remove the appender passed as parameter form the Logger.</td></tr>
<tr><td><div align="right"><a name="335"></a><a href="#335">335</a></div></td><td class="codeLine"> * @param mixed $appender an appender name or a {@link LoggerAppender} instance.</td></tr>
<tr><td><div align="right"><a name="336"></a><a href="#336">336</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="337"></a><a href="#337">337</a></div></td><td class="codeLine"> public function removeAppender($appender) {</td></tr>
<tr class="success popin" data-title="40 tests cover line 338" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="338"></a><a href="#338">338</a></div></td><td class="codeLine"> if($appender instanceof LoggerAppender) {</td></tr>
<tr class="danger"><td><div align="right"><a name="339"></a><a href="#339">339</a></div></td><td class="codeLine"> $appender-&gt;close();</td></tr>
<tr class="danger"><td><div align="right"><a name="340"></a><a href="#340">340</a></div></td><td class="codeLine"> unset($this-&gt;appenders[$appender-&gt;getName()]);</td></tr>
<tr class="success popin" data-title="40 tests cover line 341" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="341"></a><a href="#341">341</a></div></td><td class="codeLine"> } else if (is_string($appender) and isset($this-&gt;appenders[$appender])) {</td></tr>
<tr class="success popin" data-title="40 tests cover line 342" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="342"></a><a href="#342">342</a></div></td><td class="codeLine"> $this-&gt;appenders[$appender]-&gt;close();</td></tr>
<tr class="success popin" data-title="40 tests cover line 343" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="343"></a><a href="#343">343</a></div></td><td class="codeLine"> unset($this-&gt;appenders[$appender]);</td></tr>
<tr class="success popin" data-title="40 tests cover line 344" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="344"></a><a href="#344">344</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="40 tests cover line 345" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="345"></a><a href="#345">345</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="346"></a><a href="#346">346</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="347"></a><a href="#347">347</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="348"></a><a href="#348">348</a></div></td><td class="codeLine"> * Returns the appenders linked to this logger as an array.</td></tr>
<tr><td><div align="right"><a name="349"></a><a href="#349">349</a></div></td><td class="codeLine"> * @return array collection of appender names</td></tr>
<tr><td><div align="right"><a name="350"></a><a href="#350">350</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="351"></a><a href="#351">351</a></div></td><td class="codeLine"> public function getAllAppenders() {</td></tr>
<tr class="success popin" data-title="3 tests cover line 352" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="352"></a><a href="#352">352</a></div></td><td class="codeLine"> return $this-&gt;appenders;</td></tr>
<tr><td><div align="right"><a name="353"></a><a href="#353">353</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="354"></a><a href="#354">354</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="355"></a><a href="#355">355</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="356"></a><a href="#356">356</a></div></td><td class="codeLine"> * Returns a linked appender by name.</td></tr>
<tr><td><div align="right"><a name="357"></a><a href="#357">357</a></div></td><td class="codeLine"> * @return LoggerAppender</td></tr>
<tr><td><div align="right"><a name="358"></a><a href="#358">358</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="359"></a><a href="#359">359</a></div></td><td class="codeLine"> public function getAppender($name) {</td></tr>
<tr class="success popin" data-title="6 tests cover line 360" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="360"></a><a href="#360">360</a></div></td><td class="codeLine"> return $this-&gt;appenders[$name];</td></tr>
<tr><td><div align="right"><a name="361"></a><a href="#361">361</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="362"></a><a href="#362">362</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="363"></a><a href="#363">363</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="364"></a><a href="#364">364</a></div></td><td class="codeLine"> * Sets the additivity flag.</td></tr>
<tr><td><div align="right"><a name="365"></a><a href="#365">365</a></div></td><td class="codeLine"> * @param boolean $additive</td></tr>
<tr><td><div align="right"><a name="366"></a><a href="#366">366</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="367"></a><a href="#367">367</a></div></td><td class="codeLine"> public function setAdditivity($additive) {</td></tr>
<tr class="success popin" data-title="15 tests cover line 368" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="368"></a><a href="#368">368</a></div></td><td class="codeLine"> $this-&gt;additive = (bool)$additive;</td></tr>
<tr class="success popin" data-title="15 tests cover line 369" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="369"></a><a href="#369">369</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="370"></a><a href="#370">370</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="371"></a><a href="#371">371</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="372"></a><a href="#372">372</a></div></td><td class="codeLine"> * Returns the additivity flag.</td></tr>
<tr><td><div align="right"><a name="373"></a><a href="#373">373</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="374"></a><a href="#374">374</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="375"></a><a href="#375">375</a></div></td><td class="codeLine"> public function getAdditivity() {</td></tr>
<tr class="success popin" data-title="15 tests cover line 376" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="376"></a><a href="#376">376</a></div></td><td class="codeLine"> return $this-&gt;additive;</td></tr>
<tr><td><div align="right"><a name="377"></a><a href="#377">377</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="378"></a><a href="#378">378</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="379"></a><a href="#379">379</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="380"></a><a href="#380">380</a></div></td><td class="codeLine"> * Starting from this Logger, search the Logger hierarchy for a non-null level and return it.</td></tr>
<tr><td><div align="right"><a name="381"></a><a href="#381">381</a></div></td><td class="codeLine"> * @see LoggerLevel</td></tr>
<tr><td><div align="right"><a name="382"></a><a href="#382">382</a></div></td><td class="codeLine"> * @return LoggerLevel or null</td></tr>
<tr><td><div align="right"><a name="383"></a><a href="#383">383</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="384"></a><a href="#384">384</a></div></td><td class="codeLine"> public function getEffectiveLevel() {</td></tr>
<tr class="success popin" data-title="15 tests cover line 385" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="385"></a><a href="#385">385</a></div></td><td class="codeLine"> for($logger = $this; $logger !== null; $logger = $logger-&gt;getParent()) {</td></tr>
<tr class="success popin" data-title="15 tests cover line 386" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="386"></a><a href="#386">386</a></div></td><td class="codeLine"> if($logger-&gt;getLevel() !== null) {</td></tr>
<tr class="success popin" data-title="15 tests cover line 387" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="387"></a><a href="#387">387</a></div></td><td class="codeLine"> return $logger-&gt;getLevel();</td></tr>
<tr><td><div align="right"><a name="388"></a><a href="#388">388</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="13 tests cover line 389" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="389"></a><a href="#389">389</a></div></td><td class="codeLine"> }</td></tr>
<tr class="danger"><td><div align="right"><a name="390"></a><a href="#390">390</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="391"></a><a href="#391">391</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="392"></a><a href="#392">392</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="393"></a><a href="#393">393</a></div></td><td class="codeLine"> * Get the assigned Logger level.</td></tr>
<tr><td><div align="right"><a name="394"></a><a href="#394">394</a></div></td><td class="codeLine"> * @return LoggerLevel The assigned level or null if none is assigned.</td></tr>
<tr><td><div align="right"><a name="395"></a><a href="#395">395</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="396"></a><a href="#396">396</a></div></td><td class="codeLine"> public function getLevel() {</td></tr>
<tr class="success popin" data-title="33 tests cover line 397" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testInitialSetup&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="397"></a><a href="#397">397</a></div></td><td class="codeLine"> return $this-&gt;level;</td></tr>
<tr><td><div align="right"><a name="398"></a><a href="#398">398</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="399"></a><a href="#399">399</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="400"></a><a href="#400">400</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="401"></a><a href="#401">401</a></div></td><td class="codeLine"> * Set the Logger level.</td></tr>
<tr><td><div align="right"><a name="402"></a><a href="#402">402</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="403"></a><a href="#403">403</a></div></td><td class="codeLine"> * Use LoggerLevel::getLevelXXX() methods to get a LoggerLevel object, e.g.</td></tr>
<tr><td><div align="right"><a name="404"></a><a href="#404">404</a></div></td><td class="codeLine"> * &lt;code&gt;$logger-&gt;setLevel(LoggerLevel::getLevelInfo());&lt;/code&gt;</td></tr>
<tr><td><div align="right"><a name="405"></a><a href="#405">405</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="406"></a><a href="#406">406</a></div></td><td class="codeLine"> * @param LoggerLevel $level The level to set, or NULL to clear the logger level.</td></tr>
<tr><td><div align="right"><a name="407"></a><a href="#407">407</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="408"></a><a href="#408">408</a></div></td><td class="codeLine"> public function setLevel(LoggerLevel $level = null) {</td></tr>
<tr class="success popin" data-title="72 tests cover line 409" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testExists&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testClear&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testInitialSetup&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentResult&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testNullLevelWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="409"></a><a href="#409">409</a></div></td><td class="codeLine"> $this-&gt;level = $level;</td></tr>
<tr class="success popin" data-title="72 tests cover line 410" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testExists&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testClear&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testInitialSetup&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testSetParentResult&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRootTest::testNullLevelWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="410"></a><a href="#410">410</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="411"></a><a href="#411">411</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="412"></a><a href="#412">412</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="413"></a><a href="#413">413</a></div></td><td class="codeLine"> * Checks whether an appender is attached to this logger instance.</td></tr>
<tr><td><div align="right"><a name="414"></a><a href="#414">414</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="415"></a><a href="#415">415</a></div></td><td class="codeLine"> * @param LoggerAppender $appender</td></tr>
<tr><td><div align="right"><a name="416"></a><a href="#416">416</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="417"></a><a href="#417">417</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="418"></a><a href="#418">418</a></div></td><td class="codeLine"> public function isAttached(LoggerAppender $appender) {</td></tr>
<tr class="danger"><td><div align="right"><a name="419"></a><a href="#419">419</a></div></td><td class="codeLine"> return isset($this-&gt;appenders[$appender-&gt;getName()]);</td></tr>
<tr><td><div align="right"><a name="420"></a><a href="#420">420</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="421"></a><a href="#421">421</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="422"></a><a href="#422">422</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="423"></a><a href="#423">423</a></div></td><td class="codeLine"> * Sets the parent logger.</td></tr>
<tr><td><div align="right"><a name="424"></a><a href="#424">424</a></div></td><td class="codeLine"> * @param Logger $logger</td></tr>
<tr><td><div align="right"><a name="425"></a><a href="#425">425</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="426"></a><a href="#426">426</a></div></td><td class="codeLine"> public function setParent(Logger $logger) {</td></tr>
<tr class="success popin" data-title="24 tests cover line 427" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testExists&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testClear&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="427"></a><a href="#427">427</a></div></td><td class="codeLine"> $this-&gt;parent = $logger;</td></tr>
<tr class="success popin" data-title="24 tests cover line 428" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testResetConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testSettingParents&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testExists&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerHierarchyTest::testClear&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="428"></a><a href="#428">428</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="429"></a><a href="#429">429</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="430"></a><a href="#430">430</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="431"></a><a href="#431">431</a></div></td><td class="codeLine"> // *** Static methods and properties ***</td></tr>
<tr><td><div align="right"><a name="432"></a><a href="#432">432</a></div></td><td class="codeLine"> // ******************************************</td></tr>
<tr><td><div align="right"><a name="433"></a><a href="#433">433</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="434"></a><a href="#434">434</a></div></td><td class="codeLine"> /** The logger hierarchy used by log4php. */</td></tr>
<tr><td><div align="right"><a name="435"></a><a href="#435">435</a></div></td><td class="codeLine"> private static $hierarchy;</td></tr>
<tr><td><div align="right"><a name="436"></a><a href="#436">436</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="437"></a><a href="#437">437</a></div></td><td class="codeLine"> /** Inidicates if log4php has been initialized */</td></tr>
<tr><td><div align="right"><a name="438"></a><a href="#438">438</a></div></td><td class="codeLine"> private static $initialized = false;</td></tr>
<tr><td><div align="right"><a name="439"></a><a href="#439">439</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="440"></a><a href="#440">440</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="441"></a><a href="#441">441</a></div></td><td class="codeLine"> * Returns the hierarchy used by this Logger.</td></tr>
<tr><td><div align="right"><a name="442"></a><a href="#442">442</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="443"></a><a href="#443">443</a></div></td><td class="codeLine"> * Caution: do not use this hierarchy unless you have called initialize().</td></tr>
<tr><td><div align="right"><a name="444"></a><a href="#444">444</a></div></td><td class="codeLine"> * To get Loggers, use the Logger::getLogger and Logger::getRootLogger</td></tr>
<tr><td><div align="right"><a name="445"></a><a href="#445">445</a></div></td><td class="codeLine"> * methods instead of operating on on the hierarchy directly.</td></tr>
<tr><td><div align="right"><a name="446"></a><a href="#446">446</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="447"></a><a href="#447">447</a></div></td><td class="codeLine"> * @return LoggerHierarchy</td></tr>
<tr><td><div align="right"><a name="448"></a><a href="#448">448</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="449"></a><a href="#449">449</a></div></td><td class="codeLine"> public static function getHierarchy() {</td></tr>
<tr class="success popin" data-title="70 tests cover line 450" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="450"></a><a href="#450">450</a></div></td><td class="codeLine"> if(!isset(self::$hierarchy)) {</td></tr>
<tr class="success popin" data-title="1 test covers line 451" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="451"></a><a href="#451">451</a></div></td><td class="codeLine"> self::$hierarchy = new LoggerHierarchy(new LoggerRoot());</td></tr>
<tr class="success popin" data-title="1 test covers line 452" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="452"></a><a href="#452">452</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="70 tests cover line 453" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetLocationInformation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation1&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLoggingEventTest::testGetThrowableInformation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="453"></a><a href="#453">453</a></div></td><td class="codeLine"> return self::$hierarchy;</td></tr>
<tr><td><div align="right"><a name="454"></a><a href="#454">454</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="455"></a><a href="#455">455</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="456"></a><a href="#456">456</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="457"></a><a href="#457">457</a></div></td><td class="codeLine"> * Returns a Logger by name. If it does not exist, it will be created.</td></tr>
<tr><td><div align="right"><a name="458"></a><a href="#458">458</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="459"></a><a href="#459">459</a></div></td><td class="codeLine"> * @param string $name The logger name</td></tr>
<tr><td><div align="right"><a name="460"></a><a href="#460">460</a></div></td><td class="codeLine"> * @return Logger</td></tr>
<tr><td><div align="right"><a name="461"></a><a href="#461">461</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="462"></a><a href="#462">462</a></div></td><td class="codeLine"> public static function getLogger($name) {</td></tr>
<tr class="success popin" data-title="15 tests cover line 463" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="463"></a><a href="#463">463</a></div></td><td class="codeLine"> if(!self::isInitialized()) {</td></tr>
<tr class="success popin" data-title="2 tests cover line 464" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="464"></a><a href="#464">464</a></div></td><td class="codeLine"> self::configure();</td></tr>
<tr class="success popin" data-title="2 tests cover line 465" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="465"></a><a href="#465">465</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="15 tests cover line 466" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="466"></a><a href="#466">466</a></div></td><td class="codeLine"> return self::getHierarchy()-&gt;getLogger($name);</td></tr>
<tr><td><div align="right"><a name="467"></a><a href="#467">467</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="468"></a><a href="#468">468</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="469"></a><a href="#469">469</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="470"></a><a href="#470">470</a></div></td><td class="codeLine"> * Returns the Root Logger.</td></tr>
<tr><td><div align="right"><a name="471"></a><a href="#471">471</a></div></td><td class="codeLine"> * @return LoggerRoot</td></tr>
<tr><td><div align="right"><a name="472"></a><a href="#472">472</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="473"></a><a href="#473">473</a></div></td><td class="codeLine"> public static function getRootLogger() {</td></tr>
<tr class="success popin" data-title="19 tests cover line 474" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="474"></a><a href="#474">474</a></div></td><td class="codeLine"> if(!self::isInitialized()) {</td></tr>
<tr class="success popin" data-title="1 test covers line 475" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="475"></a><a href="#475">475</a></div></td><td class="codeLine"> self::configure();</td></tr>
<tr class="success popin" data-title="1 test covers line 476" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="476"></a><a href="#476">476</a></div></td><td class="codeLine"> }</td></tr>
<tr class="success popin" data-title="19 tests cover line 477" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="477"></a><a href="#477">477</a></div></td><td class="codeLine"> return self::getHierarchy()-&gt;getRootLogger();</td></tr>
<tr><td><div align="right"><a name="478"></a><a href="#478">478</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="479"></a><a href="#479">479</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="480"></a><a href="#480">480</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="481"></a><a href="#481">481</a></div></td><td class="codeLine"> * Clears all Logger definitions from the logger hierarchy.</td></tr>
<tr><td><div align="right"><a name="482"></a><a href="#482">482</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="483"></a><a href="#483">483</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="484"></a><a href="#484">484</a></div></td><td class="codeLine"> public static function clear() {</td></tr>
<tr class="success popin" data-title="10 tests cover line 485" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="485"></a><a href="#485">485</a></div></td><td class="codeLine"> return self::getHierarchy()-&gt;clear();</td></tr>
<tr><td><div align="right"><a name="486"></a><a href="#486">486</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="487"></a><a href="#487">487</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="488"></a><a href="#488">488</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="489"></a><a href="#489">489</a></div></td><td class="codeLine"> * Destroy configurations for logger definitions</td></tr>
<tr><td><div align="right"><a name="490"></a><a href="#490">490</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="491"></a><a href="#491">491</a></div></td><td class="codeLine"> public static function resetConfiguration() {</td></tr>
<tr class="success popin" data-title="64 tests cover line 492" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="492"></a><a href="#492">492</a></div></td><td class="codeLine"> self::getHierarchy()-&gt;resetConfiguration();</td></tr>
<tr class="success popin" data-title="64 tests cover line 493" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="493"></a><a href="#493">493</a></div></td><td class="codeLine"> self::getHierarchy()-&gt;clear(); // TODO: clear or not?</td></tr>
<tr class="success popin" data-title="64 tests cover line 494" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="494"></a><a href="#494">494</a></div></td><td class="codeLine"> self::$initialized = false;</td></tr>
<tr class="success popin" data-title="64 tests cover line 495" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderConfigNotArray&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testRequiresLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testActivationDoesNotCreateTheFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testConversion2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testNonExistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testInvalidXMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerWarning&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfigurationAdapterXMLTest::testDuplicateLoggerConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="495"></a><a href="#495">495</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="496"></a><a href="#496">496</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="497"></a><a href="#497">497</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="498"></a><a href="#498">498</a></div></td><td class="codeLine"> * Safely close all appenders.</td></tr>
<tr><td><div align="right"><a name="499"></a><a href="#499">499</a></div></td><td class="codeLine"> * @deprecated This is no longer necessary due the appenders shutdown via</td></tr>
<tr><td><div align="right"><a name="500"></a><a href="#500">500</a></div></td><td class="codeLine"> * destructors.</td></tr>
<tr><td><div align="right"><a name="501"></a><a href="#501">501</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="502"></a><a href="#502">502</a></div></td><td class="codeLine"> public static function shutdown() {</td></tr>
<tr class="danger"><td><div align="right"><a name="503"></a><a href="#503">503</a></div></td><td class="codeLine"> return self::getHierarchy()-&gt;shutdown();</td></tr>
<tr><td><div align="right"><a name="504"></a><a href="#504">504</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="505"></a><a href="#505">505</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="506"></a><a href="#506">506</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="507"></a><a href="#507">507</a></div></td><td class="codeLine"> * check if a given logger exists.</td></tr>
<tr><td><div align="right"><a name="508"></a><a href="#508">508</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="509"></a><a href="#509">509</a></div></td><td class="codeLine"> * @param string $name logger name</td></tr>
<tr><td><div align="right"><a name="510"></a><a href="#510">510</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="511"></a><a href="#511">511</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="512"></a><a href="#512">512</a></div></td><td class="codeLine"> public static function exists($name) {</td></tr>
<tr class="success popin" data-title="1 test covers line 513" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="513"></a><a href="#513">513</a></div></td><td class="codeLine"> return self::getHierarchy()-&gt;exists($name);</td></tr>
<tr><td><div align="right"><a name="514"></a><a href="#514">514</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="515"></a><a href="#515">515</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="516"></a><a href="#516">516</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="517"></a><a href="#517">517</a></div></td><td class="codeLine"> * Returns an array this whole Logger instances.</td></tr>
<tr><td><div align="right"><a name="518"></a><a href="#518">518</a></div></td><td class="codeLine"> * @see Logger</td></tr>
<tr><td><div align="right"><a name="519"></a><a href="#519">519</a></div></td><td class="codeLine"> * @return array</td></tr>
<tr><td><div align="right"><a name="520"></a><a href="#520">520</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="521"></a><a href="#521">521</a></div></td><td class="codeLine"> public static function getCurrentLoggers() {</td></tr>
<tr class="success popin" data-title="3 tests cover line 522" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="522"></a><a href="#522">522</a></div></td><td class="codeLine"> return self::getHierarchy()-&gt;getCurrentLoggers();</td></tr>
<tr><td><div align="right"><a name="523"></a><a href="#523">523</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="524"></a><a href="#524">524</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="525"></a><a href="#525">525</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="526"></a><a href="#526">526</a></div></td><td class="codeLine"> * Configures log4php.</td></tr>
<tr><td><div align="right"><a name="527"></a><a href="#527">527</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="528"></a><a href="#528">528</a></div></td><td class="codeLine"> * This method needs to be called before the first logging event has</td></tr>
<tr><td><div align="right"><a name="529"></a><a href="#529">529</a></div></td><td class="codeLine"> * occured. If this method is not called before then the default</td></tr>
<tr><td><div align="right"><a name="530"></a><a href="#530">530</a></div></td><td class="codeLine"> * configuration will be used.</td></tr>
<tr><td><div align="right"><a name="531"></a><a href="#531">531</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="532"></a><a href="#532">532</a></div></td><td class="codeLine"> * @param string|array $configuration Either a path to the configuration</td></tr>
<tr><td><div align="right"><a name="533"></a><a href="#533">533</a></div></td><td class="codeLine"> * file, or a configuration array.</td></tr>
<tr><td><div align="right"><a name="534"></a><a href="#534">534</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="535"></a><a href="#535">535</a></div></td><td class="codeLine"> * @param string|LoggerConfigurator $configurator A custom</td></tr>
<tr><td><div align="right"><a name="536"></a><a href="#536">536</a></div></td><td class="codeLine"> * configurator class: either a class name (string), or an object which</td></tr>
<tr><td><div align="right"><a name="537"></a><a href="#537">537</a></div></td><td class="codeLine"> * implements the LoggerConfigurator interface. If left empty, the default</td></tr>
<tr><td><div align="right"><a name="538"></a><a href="#538">538</a></div></td><td class="codeLine"> * configurator implementation will be used.</td></tr>
<tr><td><div align="right"><a name="539"></a><a href="#539">539</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="540"></a><a href="#540">540</a></div></td><td class="codeLine"> public static function configure($configuration = null, $configurator = null) {</td></tr>
<tr class="success popin" data-title="55 tests cover line 541" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="541"></a><a href="#541">541</a></div></td><td class="codeLine"> self::resetConfiguration();</td></tr>
<tr class="success popin" data-title="55 tests cover line 542" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="542"></a><a href="#542">542</a></div></td><td class="codeLine"> $configurator = self::getConfigurator($configurator);</td></tr>
<tr class="success popin" data-title="55 tests cover line 543" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="543"></a><a href="#543">543</a></div></td><td class="codeLine"> $configurator-&gt;configure(self::getHierarchy(), $configuration);</td></tr>
<tr class="success popin" data-title="33 tests cover line 544" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="544"></a><a href="#544">544</a></div></td><td class="codeLine"> self::$initialized = true;</td></tr>
<tr class="success popin" data-title="33 tests cover line 545" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="545"></a><a href="#545">545</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="546"></a><a href="#546">546</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="547"></a><a href="#547">547</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="548"></a><a href="#548">548</a></div></td><td class="codeLine"> * Creates a logger configurator instance based on the provided</td></tr>
<tr><td><div align="right"><a name="549"></a><a href="#549">549</a></div></td><td class="codeLine"> * configurator class. If no class is given, returns an instance of</td></tr>
<tr><td><div align="right"><a name="550"></a><a href="#550">550</a></div></td><td class="codeLine"> * the default configurator.</td></tr>
<tr><td><div align="right"><a name="551"></a><a href="#551">551</a></div></td><td class="codeLine"> *</td></tr>
<tr><td><div align="right"><a name="552"></a><a href="#552">552</a></div></td><td class="codeLine"> * @param string|LoggerConfigurator $configurator The configurator class</td></tr>
<tr><td><div align="right"><a name="553"></a><a href="#553">553</a></div></td><td class="codeLine"> * or LoggerConfigurator instance.</td></tr>
<tr><td><div align="right"><a name="554"></a><a href="#554">554</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="555"></a><a href="#555">555</a></div></td><td class="codeLine"> private static function getConfigurator($configurator = null) {</td></tr>
<tr class="success popin" data-title="55 tests cover line 556" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="556"></a><a href="#556">556</a></div></td><td class="codeLine"> if ($configurator === null) {</td></tr>
<tr class="success popin" data-title="55 tests cover line 557" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInputIsInteger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testYAMLFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterParamter&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderFilterClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoAppenderLayoutClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNoRenderedClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingRenderingClassSet&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerAddivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNotExistingLoggerAppendersClass&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFile&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderInvalidThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testInvalidRootLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testGetCurrentLoggers&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerRendererMapTest::testXMLConfig&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="557"></a><a href="#557">557</a></div></td><td class="codeLine"> return new LoggerConfiguratorDefault();</td></tr>
<tr><td><div align="right"><a name="558"></a><a href="#558">558</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="559"></a><a href="#559">559</a></div></td><td class="codeLine"></td></tr>
<tr class="danger"><td><div align="right"><a name="560"></a><a href="#560">560</a></div></td><td class="codeLine"> if (is_object($configurator)) {</td></tr>
<tr class="danger"><td><div align="right"><a name="561"></a><a href="#561">561</a></div></td><td class="codeLine"> if ($configurator instanceof LoggerConfigurator) {</td></tr>
<tr class="danger"><td><div align="right"><a name="562"></a><a href="#562">562</a></div></td><td class="codeLine"> return $configurator;</td></tr>
<tr><td><div align="right"><a name="563"></a><a href="#563">563</a></div></td><td class="codeLine"> } else {</td></tr>
<tr class="danger"><td><div align="right"><a name="564"></a><a href="#564">564</a></div></td><td class="codeLine"> trigger_error(&quot;log4php: Given configurator object [$configurator] does not implement the LoggerConfigurator interface. Reverting to default configurator.&quot;, E_USER_WARNING);</td></tr>
<tr class="danger"><td><div align="right"><a name="565"></a><a href="#565">565</a></div></td><td class="codeLine"> return new LoggerConfiguratorDefault();</td></tr>
<tr><td><div align="right"><a name="566"></a><a href="#566">566</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="567"></a><a href="#567">567</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="568"></a><a href="#568">568</a></div></td><td class="codeLine"></td></tr>
<tr class="danger"><td><div align="right"><a name="569"></a><a href="#569">569</a></div></td><td class="codeLine"> if (is_string($configurator)) {</td></tr>
<tr class="danger"><td><div align="right"><a name="570"></a><a href="#570">570</a></div></td><td class="codeLine"> if (!class_exists($configurator)) {</td></tr>
<tr class="danger"><td><div align="right"><a name="571"></a><a href="#571">571</a></div></td><td class="codeLine"> trigger_error(&quot;log4php: Specified configurator class [$configurator] does not exist. Reverting to default configurator.&quot;, E_USER_WARNING);</td></tr>
<tr class="danger"><td><div align="right"><a name="572"></a><a href="#572">572</a></div></td><td class="codeLine"> return new LoggerConfiguratorDefault();</td></tr>
<tr><td><div align="right"><a name="573"></a><a href="#573">573</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="574"></a><a href="#574">574</a></div></td><td class="codeLine"></td></tr>
<tr class="danger"><td><div align="right"><a name="575"></a><a href="#575">575</a></div></td><td class="codeLine"> $instance = new $configurator();</td></tr>
<tr><td><div align="right"><a name="576"></a><a href="#576">576</a></div></td><td class="codeLine"></td></tr>
<tr class="danger"><td><div align="right"><a name="577"></a><a href="#577">577</a></div></td><td class="codeLine"> if (!($instance instanceof LoggerConfigurator)) {</td></tr>
<tr class="danger"><td><div align="right"><a name="578"></a><a href="#578">578</a></div></td><td class="codeLine"> trigger_error(&quot;log4php: Specified configurator class [$configurator] does not implement the LoggerConfigurator interface. Reverting to default configurator.&quot;, E_USER_WARNING);</td></tr>
<tr class="danger"><td><div align="right"><a name="579"></a><a href="#579">579</a></div></td><td class="codeLine"> return new LoggerConfiguratorDefault();</td></tr>
<tr><td><div align="right"><a name="580"></a><a href="#580">580</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="581"></a><a href="#581">581</a></div></td><td class="codeLine"></td></tr>
<tr class="danger"><td><div align="right"><a name="582"></a><a href="#582">582</a></div></td><td class="codeLine"> return $instance;</td></tr>
<tr><td><div align="right"><a name="583"></a><a href="#583">583</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="584"></a><a href="#584">584</a></div></td><td class="codeLine"></td></tr>
<tr class="danger"><td><div align="right"><a name="585"></a><a href="#585">585</a></div></td><td class="codeLine"> trigger_error(&quot;log4php: Invalid configurator specified. Expected either a string or a LoggerConfigurator instance. Reverting to default configurator.&quot;, E_USER_WARNING);</td></tr>
<tr class="danger"><td><div align="right"><a name="586"></a><a href="#586">586</a></div></td><td class="codeLine"> return new LoggerConfiguratorDefault();</td></tr>
<tr><td><div align="right"><a name="587"></a><a href="#587">587</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="588"></a><a href="#588">588</a></div></td><td class="codeLine"></td></tr>
<tr><td><div align="right"><a name="589"></a><a href="#589">589</a></div></td><td class="codeLine"> /**</td></tr>
<tr><td><div align="right"><a name="590"></a><a href="#590">590</a></div></td><td class="codeLine"> * Returns true if the log4php framework has been initialized.</td></tr>
<tr><td><div align="right"><a name="591"></a><a href="#591">591</a></div></td><td class="codeLine"> * @return boolean</td></tr>
<tr><td><div align="right"><a name="592"></a><a href="#592">592</a></div></td><td class="codeLine"> */</td></tr>
<tr><td><div align="right"><a name="593"></a><a href="#593">593</a></div></td><td class="codeLine"> private static function isInitialized() {</td></tr>
<tr class="success popin" data-title="32 tests cover line 594" data-content="&lt;ul&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testDefaultConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testNonexistantFileFallback&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppendersWithLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testAppenderThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerConfiguratorTest::testLoggerThreshold&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testLoggerExist&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetRootLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanGetASpecificLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testCanLogToAllLevels&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testIsEnabledFor&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerTest::testAdditivity2&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendDefault&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStdout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderConsoleTest::testAppendStderr&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testAppend&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderEchoTest::testHtmlLineBreaks&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testSimpleLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagTrue&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderFileTest::testAppendFlagFalse&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderPhpTest::testPhp&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testLoggingViaLogger&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderRollingFileTest::testRolloverWithCompression&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerAppenderSocketTest::testLogging&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterDenyAllTest::testConfiguration&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testAcceptConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerFilterLevelMatchTest::testDenyConfig&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutPatternTest::testComplexLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayout&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerLayoutSerializedTest::testLayoutWithLocationInfo&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation&lt;/li&gt;&lt;li class=&quot;success&quot;&gt;LoggerPatternConverterTest::testLocation2&lt;/li&gt;&lt;/ul&gt;" data-placement="bottom"><td><div align="right"><a name="594"></a><a href="#594">594</a></div></td><td class="codeLine"> return self::$initialized;</td></tr>
<tr><td><div align="right"><a name="595"></a><a href="#595">595</a></div></td><td class="codeLine"> }</td></tr>
<tr><td><div align="right"><a name="596"></a><a href="#596">596</a></div></td><td class="codeLine">}</td></tr>
</tbody>
</table>
<footer>
<h4>Legend</h4>
<p>
<span class="success"><strong>Executed</strong></span>
<span class="danger"><strong>Not Executed</strong></span>
<span class="warning"><strong>Dead Code</strong></span>
</p>
<p>
<small>Generated by <a href="http://github.com/sebastianbergmann/php-code-coverage" target="_top">PHP_CodeCoverage 1.2.3</a> using <a href="http://www.php.net/" target="_top">PHP 5.3.13</a> and <a href="http://phpunit.de/">PHPUnit 3.7.6</a> at Sat Oct 13 8:58:14 BST 2012.</small>
</p>
</footer>
</div>
<script src="js/jquery.min.js" type="text/javascript"></script>
<script src="js/bootstrap.min.js" type="text/javascript"></script>
<script type="text/javascript">$('.popin').popover({trigger: 'hover'});</script>
</body>
</html>