Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 7
0.00% covered (danger)
0.00%
0 / 2
CRAP
0.00% covered (danger)
0.00%
0 / 1
OneTimeTask
0.00% covered (danger)
0.00%
0 / 7
0.00% covered (danger)
0.00%
0 / 2
12
0.00% covered (danger)
0.00%
0 / 1
 run
0.00% covered (danger)
0.00%
0 / 6
0.00% covered (danger)
0.00%
0 / 1
6
 setTask
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
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
24use oat\tao\model\taskQueue\Task\TaskInterface;
25use oat\tao\model\taskQueue\TaskLogInterface;
26
27final class OneTimeTask extends AbstractWorker
28{
29    /** @var TaskInterface */
30    private $task;
31
32    /**
33     * Start processing tasks from a given queue
34     *
35     * @return string
36     */
37    public function run()
38    {
39        $this->logDebug('Starting Task.');
40        try {
41            return $this->processTask($this->task);
42        } catch (\Exception $e) {
43            $this->logError('Error processing task ' . $e->getMessage());
44        }
45
46        $this->logDebug('Task finished.');
47
48        return TaskLogInterface::STATUS_FAILED;
49    }
50
51    /**
52     * @param TaskInterface $task
53     */
54    public function setTask($task)
55    {
56        $this->task = $task;
57    }
58}