Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 9
0.00% covered (danger)
0.00%
0 / 1
CRAP
0.00% covered (danger)
0.00%
0 / 1
OneTimeWorker
0.00% covered (danger)
0.00%
0 / 9
0.00% covered (danger)
0.00%
0 / 1
12
0.00% covered (danger)
0.00%
0 / 1
 run
0.00% covered (danger)
0.00%
0 / 9
0.00% covered (danger)
0.00%
0 / 1
12
1<?php
2
3/**
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; under version 2
7 * of the License (non-upgradable).
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17 *
18 * Copyright (c) 2017 (original work) Open Assessment Technologies SA (under the project TAO-PRODUCT);
19 *
20 */
21
22namespace oat\tao\model\taskQueue\Worker;
23
24/**
25 * A simple worker implementation to fetch the latest task from a queue and run it.
26 * Exits after one run.
27 *
28 * @author Gyula Szucs <gyula@taotesting.com>
29 */
30final class OneTimeWorker extends AbstractWorker
31{
32    public function run()
33    {
34        $this->logDebug('Starting OneTimeWorker.');
35
36        try {
37            $this->logDebug('Fetching tasks from queue ');
38
39            $task = $this->queuer->dequeue();
40
41            if ($task) {
42                $this->processTask($task);
43            }
44
45            unset($task);
46        } catch (\Exception $e) {
47            $this->logError('Fetching data from queue failed with MSG: ' . $e->getMessage());
48        }
49
50        $this->logDebug('OneTimeWorker finished.');
51    }
52}