diff options
author | Robin Appelman <robin@icewind.nl> | 2024-06-17 13:21:21 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-17 13:21:21 +0200 |
commit | 642cffd4ddeab35eb8c8fe00c4bea5dea33409e6 (patch) | |
tree | 3eb7fa8cdcd7377d043fa2886cd524fafb440ed3 /tests | |
parent | 0b805eab382e0235fa560c703f942fd5bc925062 (diff) | |
parent | 85b9552617a1989a56d1252e683b632cc002bf4c (diff) | |
download | nextcloud-server-642cffd4ddeab35eb8c8fe00c4bea5dea33409e6.tar.gz nextcloud-server-642cffd4ddeab35eb8c8fe00c4bea5dea33409e6.zip |
Merge pull request #45582 from nextcloud/joblist-cleanup-by-id
delete background jobs by id when cleaning up
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/BackgroundJob/DummyJobList.php | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/tests/lib/BackgroundJob/DummyJobList.php b/tests/lib/BackgroundJob/DummyJobList.php index fc80786d28b..7b7fce7e9e8 100644 --- a/tests/lib/BackgroundJob/DummyJobList.php +++ b/tests/lib/BackgroundJob/DummyJobList.php @@ -26,6 +26,7 @@ class DummyJobList extends \OC\BackgroundJob\JobList { private array $reserved = []; private int $last = 0; + private int $lastId = 0; public function __construct() { } @@ -40,6 +41,8 @@ class DummyJobList extends \OC\BackgroundJob\JobList { $job = \OCP\Server::get($job); } $job->setArgument($argument); + $job->setId($this->lastId); + $this->lastId++; if (!$this->has($job, null)) { $this->jobs[] = $job; } @@ -54,9 +57,20 @@ class DummyJobList extends \OC\BackgroundJob\JobList { * @param mixed $argument */ public function remove($job, $argument = null): void { - $index = array_search($job, $this->jobs); - if ($index !== false) { - unset($this->jobs[$index]); + foreach ($this->jobs as $index => $listJob) { + if (get_class($job) === get_class($listJob) && $job->getArgument() == $listJob->getArgument()) { + unset($this->jobs[$index]); + return; + } + } + } + + public function removeById(int $id): void { + foreach ($this->jobs as $index => $listJob) { + if ($listJob->getId() === $id) { + unset($this->jobs[$index]); + return; + } } } @@ -126,7 +140,7 @@ class DummyJobList extends \OC\BackgroundJob\JobList { } } - public function getById(int $id): IJob { + public function getById(int $id): ?IJob { foreach ($this->jobs as $job) { if ($job->getId() === $id) { return $job; |