Completed
Pull Request — master (#37)
by Alessandro
05:15
created

TestResultFactory::createFromLog()   B

Complexity

Conditions 5
Paths 4

Size

Total Lines 20
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 10
CRAP Score 5

Importance

Changes 5
Bugs 0 Features 0
Metric Value
c 5
b 0
f 0
dl 0
loc 20
ccs 10
cts 10
cp 1
rs 8.8571
cc 5
eloc 10
nc 4
nop 1
crap 5
1
<?php
2
3
namespace Paraunit\TestResult;
4
5
use Paraunit\Parser\JSONLogFetcher;
6
use Paraunit\TestResult\Interfaces\PrintableTestResultInterface;
7
8
/**
9
 * Class TestResultFactory
10
 * @package Paraunit\TestResult
11
 */
12
class TestResultFactory
13
{
14
    /** @var  TestResultFormat */
15
    private $format;
16
17
    /**
18
     * TestResultFactory constructor.
19
     * @param TestResultFormat $format
20
     */
21 41
    public function __construct(TestResultFormat $format)
22
    {
23 41
        $this->format = $format;
24 41
    }
25
26
    /**
27
     * @param \stdClass $log
28
     * @return PrintableTestResultInterface
29
     */
30 26
    public function createFromLog(\stdClass $log)
31
    {
32 26
        if (property_exists($log, 'status') && $log->status == JSONLogFetcher::LOG_ENDING_STATUS) {
33 8
            return new TestResultWithAbnormalTermination($this->format, $log->test, 'Abnormal termination -- complete test output:');
34
        }
35
36 22
        if ( ! property_exists($log, 'message')) {
37 4
            return new MuteTestResult();
38
39
        }
40
41 19
        if (property_exists($log, 'trace')) {
42 18
            $result = new FullTestResult($this->format, $log->test, $log->message);
43 18
            $this->addTraceToResult($result, $log);
44
45 18
            return $result;
46
        }
47
48 1
        return new TestResultWithMessage($this->format, $log->test, $log->message);
49
    }
50
51
    /**
52
     * @param FullTestResult $result
53
     * @param \stdClass $log
54
     */
55 18
    private function addTraceToResult(FullTestResult $result, $log)
56
    {
57 18
        foreach ($log->trace as $traceStep) {
58 10
            $result->addTraceStep(new TraceStep($traceStep->file, $traceStep->line));
59 18
        }
60 18
    }
61
}
62