Completed
Push — master ( 0fb6e4...5eed2b )
by Siad
15:28
created

SilentLoggerTest::buildFinished()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 4
nc 1
nop 0
dl 0
loc 6
rs 10
c 1
b 0
f 0
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
use PHPUnit\Framework\TestCase;
21
22
class SilentLoggerTest extends TestCase
23
{
24
    /**
25
     * @test
26
     */
27
    public function buildFinished()
28
    {
29
        $event = new BuildEvent(new Project());
30
        $logger = new SilentLogger();
31
        $this->expectOutputString('');
32
        $logger->buildFinished($event);
33
    }
34
    /**
35
     * @test
36
     */
37
    public function buildFinishedException()
38
    {
39
        $event = new BuildEvent(new Project());
40
        $event->setException(new Exception('test'));
41
        $logger = new class extends SilentLogger {
42
            public function printMessage($message, ?OutputStream $stream = null, $priority = null)
43
            {
44
                echo $message;
45
            }
46
47
            public static function formatTime($micros)
48
            {
49
                return 'TIME_STRING';
50
            }
51
        };
52
        $msg = '/' . PHP_EOL . 'BUILD FAILED' . PHP_EOL . 'test' . PHP_EOL . '/';
53
        $this->expectOutputRegex($msg);
54
        $logger->buildFinished($event);
55
    }
56
}
57