Completed
Push — output_parsers_refactor ( 755930...b5c5df )
by Alessandro
07:17
created

JSONLogFetcher   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 43
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 87.5%

Importance

Changes 4
Bugs 0 Features 0
Metric Value
wmc 4
c 4
b 0
f 0
lcom 1
cbo 2
dl 0
loc 43
ccs 7
cts 8
cp 0.875
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A fetch() 0 12 2
A cleanLog() 0 6 1
1
<?php
2
3
namespace Paraunit\Parser;
4
5
use Paraunit\Configuration\JSONLogFilename;
6
use Paraunit\Exception\JSONLogNotFoundException;
7
use Paraunit\Process\ParaunitProcessInterface;
8
9
/**
10
 * Class JSONLogFetcher
11
 * @package Paraunit\Parser
12
 */
13
class JSONLogFetcher
14
{
15
    /** @var  JSONLogFilename */
16
    private $fileName;
17
18
    /**
19
     * JSONLogFetcher constructor.
20
     * @param JSONLogFilename $fileName
21
     */
22 1
    public function __construct(JSONLogFilename $fileName)
23
    {
24 1
        $this->fileName = $fileName;
25 1
    }
26
27
    /**
28
     * @param ParaunitProcessInterface $process
29
     * @return array
30
     * @throws JSONLogNotFoundException
31
     */
32 1
    public function fetch(ParaunitProcessInterface $process)
33
    {
34 1
        $filePath = $this->fileName->generate($process);
35
36 1
        if ( ! file_exists($filePath)) {
37 1
            throw new JSONLogNotFoundException($process);
38
        }
39
40
        return json_decode(
41
            $this->cleanLog(file_get_contents($filePath))
42
        );
43
    }
44
45
    /**
46
     * @param string $jsonString The dirty output
47
     * @return string            The normalized log, as an array of JSON objects
48
     */
49
    private static function cleanLog($jsonString)
50
    {
51
        $splitted = preg_replace('/\}\{/', '},{', $jsonString);
52
53
        return '[' . $splitted . ']';
54
    }
55
}
56