Completed
Push — master ( 4109b7...859c70 )
by Matthew
08:07 queued 02:26
created

BaseRunManager   A

Complexity

Total Complexity 17

Size/Duplication

Total Lines 123
Duplicated Lines 0 %

Coupling/Cohesion

Components 2
Dependencies 4

Test Coverage

Coverage 89.29%

Importance

Changes 0
Metric Value
wmc 17
lcom 2
cbo 4
dl 0
loc 123
ccs 50
cts 56
cp 0.8929
rs 10
c 0
b 0
f 0

13 Methods

Rating   Name   Duplication   Size   Complexity  
A getRepository() 0 4 1
A getRunArchiveClass() 0 4 1
A setRunArchiveClass() 0 4 1
A __construct() 0 5 1
A getObjectManager() 0 4 1
A recordJobRun() 0 14 2
A pruneStalledRuns() 0 19 4
A deleteOldRuns() 0 14 3
A flush() 0 4 1
getOldLiveRuns() 0 1 ?
removeOlderThan() 0 1 ?
A pruneArchivedRuns() 0 4 1
A pruneJobTimings() 0 4 1
1
<?php
2
3
namespace Dtc\QueueBundle\Doctrine;
4
5
use Doctrine\Common\Persistence\ObjectManager;
6
use Doctrine\Common\Persistence\ObjectRepository;
7
use Dtc\QueueBundle\Model\Job;
8
use Dtc\QueueBundle\Model\JobTiming;
9
use Dtc\QueueBundle\Model\Run;
10
use Dtc\QueueBundle\Model\RunManager;
11
12
abstract class BaseRunManager extends RunManager
13
{
14
    /** @var ObjectManager */
15
    protected $objectManager;
16
17
    /** @var string|null */
18
    protected $runArchiveClass;
19
20 8
    public function __construct(ObjectManager $objectManager, $runClass, $jobTimingClass, $recordTimings)
21
    {
22 8
        $this->objectManager = $objectManager;
23 8
        parent::__construct($runClass, $jobTimingClass, $recordTimings);
24 8
    }
25
26
    /**
27
     * @return ObjectManager
28
     */
29 3
    public function getObjectManager()
30
    {
31 3
        return $this->objectManager;
32
    }
33
34
    /**
35
     * @return ObjectRepository
36
     */
37
    public function getRepository()
38
    {
39
        return $this->objectManager->getRepository($this->getRunClass());
40
    }
41
42
    /**
43
     * @return null|string
44
     */
45 8
    public function getRunArchiveClass()
46
    {
47 8
        return $this->runArchiveClass;
48
    }
49
50
    /**
51
     * @param null|string $runArchiveClass
52
     */
53 8
    public function setRunArchiveClass($runArchiveClass)
54
    {
55 8
        $this->runArchiveClass = $runArchiveClass;
56 8
    }
57
58 1
    public function recordJobRun(Job $job)
59
    {
60 1
        parent::recordJobRun($job);
61
62 1
        $finishedAt = $job->getFinishedAt();
63 1
        if (null === $finishedAt) {
64
            $finishedAt = new \DateTime();
65
        }
66
        /** @var JobTiming $jobTiming */
67 1
        $jobTiming = new $this->jobTimingClass();
68 1
        $jobTiming->setFinishedAt($finishedAt);
69 1
        $this->objectManager->persist($jobTiming);
70 1
        $this->objectManager->flush();
71 1
    }
72
73 1
    public function pruneStalledRuns()
74
    {
75 1
        $runs = $this->getOldLiveRuns();
76
        /** @var Run $run */
77 1
        $delete = [];
78
79 1
        foreach ($runs as $run) {
80 1
            $lastHeartbeat = $run->getLastHeartbeatAt();
81 1
            $time = time() - 3600;
82 1
            $processTimeout = $run->getProcessTimeout();
83 1
            $time -= $processTimeout;
84 1
            $oldDate = new \DateTime("@$time");
85 1
            if (null === $lastHeartbeat || $oldDate > $lastHeartbeat) {
86 1
                $delete[] = $run;
87 1
            }
88 1
        }
89
90 1
        return $this->deleteOldRuns($delete);
91
    }
92
93
    /**
94
     * @param array $delete
95
     *
96
     * @return int
97
     */
98 1
    protected function deleteOldRuns(array $delete)
99
    {
100 1
        $count = count($delete);
101 1
        $objectManager = $this->getObjectManager();
102 1
        for ($i = 0; $i < $count; $i += 100) {
103 1
            $deleteList = array_slice($delete, $i, 100);
104 1
            foreach ($deleteList as $object) {
105 1
                $objectManager->remove($object);
106 1
            }
107 1
            $this->flush();
108 1
        }
109
110 1
        return $count;
111
    }
112
113 1
    protected function flush()
114
    {
115 1
        $this->getObjectManager()->flush();
116 1
    }
117
118
    /**
119
     * @return array
120
     */
121
    abstract protected function getOldLiveRuns();
122
123
    abstract protected function removeOlderThan($objectName, $field, \DateTime $olderThan);
124
125 1
    public function pruneArchivedRuns(\DateTime $olderThan)
126
    {
127 1
        return $this->removeOlderThan($this->getRunArchiveClass(), 'endedAt', $olderThan);
128
    }
129
130
    public function pruneJobTimings(\DateTime $olderThan)
131
    {
132
        return $this->removeOlderThan($this->getJobTimingClass(), 'createdAt', $olderThan);
133
    }
134
}
135