131 lines
2.3 KiB
PHP
131 lines
2.3 KiB
PHP
<?php
|
|
/**
|
|
* Copyright (c) 2013 Robin Appelman <icewind@owncloud.com>
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
* later.
|
|
* See the COPYING-README file.
|
|
*/
|
|
|
|
namespace Test\BackgroundJob;
|
|
|
|
class JobRun extends \Exception {
|
|
}
|
|
|
|
/**
|
|
* Class DummyJobList
|
|
*
|
|
* in memory job list for testing purposes
|
|
*/
|
|
class DummyJobList extends \OC\BackgroundJob\JobList {
|
|
/**
|
|
* @var \OC\BackgroundJob\Job[]
|
|
*/
|
|
private $jobs = array();
|
|
|
|
private $last = 0;
|
|
|
|
/**
|
|
* @param \OC\BackgroundJob\Job|string $job
|
|
* @param mixed $argument
|
|
*/
|
|
public function add($job, $argument = null) {
|
|
$job->setArgument($argument);
|
|
if (!$this->has($job, null)) {
|
|
$this->jobs[] = $job;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param \OC\BackgroundJob\Job|string $job
|
|
* @param mixed $argument
|
|
*/
|
|
public function remove($job, $argument = null) {
|
|
$index = array_search($job, $this->jobs);
|
|
if ($index !== false) {
|
|
unset($this->jobs[$index]);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* check if a job is in the list
|
|
*
|
|
* @param $job
|
|
* @param mixed $argument
|
|
* @return bool
|
|
*/
|
|
public function has($job, $argument) {
|
|
return array_search($job, $this->jobs) !== false;
|
|
}
|
|
|
|
/**
|
|
* get all jobs in the list
|
|
*
|
|
* @return \OC\BackgroundJob\Job[]
|
|
*/
|
|
public function getAll() {
|
|
return $this->jobs;
|
|
}
|
|
|
|
/**
|
|
* get the next job in the list
|
|
*
|
|
* @return \OC\BackgroundJob\Job
|
|
*/
|
|
public function getNext() {
|
|
if (count($this->jobs) > 0) {
|
|
if ($this->last < (count($this->jobs) - 1)) {
|
|
$i = $this->last + 1;
|
|
} else {
|
|
$i = 0;
|
|
}
|
|
return $this->jobs[$i];
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* set the job that was last ran
|
|
*
|
|
* @param \OC\BackgroundJob\Job $job
|
|
*/
|
|
public function setLastJob($job) {
|
|
$i = array_search($job, $this->jobs);
|
|
if ($i !== false) {
|
|
$this->last = $i;
|
|
} else {
|
|
$this->last = 0;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
* @return Job
|
|
*/
|
|
public function getById($id) {
|
|
foreach ($this->jobs as $job) {
|
|
if ($job->getId() === $id) {
|
|
return $job;
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* get the id of the last ran job
|
|
*
|
|
* @return int
|
|
*/
|
|
public function getLastJob() {
|
|
return $this->last;
|
|
}
|
|
|
|
/**
|
|
* set the lastRun of $job to now
|
|
*
|
|
* @param \OC\BackgroundJob\Job $job
|
|
*/
|
|
public function setLastRun($job) {
|
|
$job->setLastRun(time());
|
|
}
|
|
}
|