Passed
Push — main ( 2c83d5...fb3f8a )
by Siad
05:21
created

SilentLoggerTest   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 13
dl 0
loc 34
rs 10
c 0
b 0
f 0
wmc 3

3 Methods

Rating   Name   Duplication   Size   Complexity  
A hp$0 ➔ formatTime() 0 3 1
A buildFinished() 0 6 1
A hp$0 ➔ printMessage() 0 3 1
1
<?php
2
/**
3
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
4
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
5
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
6
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
7
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
8
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
9
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
10
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
11
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
12
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
13
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
14
 *
15
 * This software consists of voluntary contributions made by many individuals
16
 * and is licensed under the LGPL. For more information please see
17
 * <http://phing.info>.
18
 */
19
20
namespace Phing\Test\Listener;
21
22
use Exception;
23
use Phing\Io\OutputStream;
24
use Phing\Listener\BuildEvent;
25
use Phing\Listener\SilentLogger;
26
use Phing\Project;
27
use PHPUnit\Framework\TestCase;
28
29
class SilentLoggerTest extends TestCase
30
{
31
    /**
32
     * @test
33
     */
34
    public function buildFinished()
35
    {
36
        $event = new BuildEvent(new Project());
37
        $logger = new SilentLogger();
38
        $this->expectOutputString('');
39
        $logger->buildFinished($event);
40
    }
41
42
    /**
43
     * @test
44
     */
45
    public function buildFinishedException()
46
    {
47
        $event = new BuildEvent(new Project());
48
        $event->setException(new Exception('test'));
49
        $logger = new class() extends SilentLogger {
50
            public function printMessage($message, ?OutputStream $stream = null, $priority = null)
51
            {
52
                echo $message;
53
            }
54
55
            public static function formatTime(float $micros): string
56
            {
57
                return 'TIME_STRING';
58
            }
59
        };
60
        $msg = '/' . PHP_EOL . 'BUILD FAILED' . PHP_EOL . 'test' . PHP_EOL . '/';
61
        $this->expectOutputRegex($msg);
62
        $logger->buildFinished($event);
63
    }
64
}
65