aboutsummaryrefslogtreecommitdiffstats
path: root/tests/lib/BackgroundJob/JobTest.php
blob: 9024742f432aa107c5b03c35523a82ee139a694b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
<?php
/**
 * SPDX-FileCopyrightText: 2017-2024 Nextcloud GmbH and Nextcloud contributors
 * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */

namespace Test\BackgroundJob;

use OCP\AppFramework\Utility\ITimeFactory;
use Psr\Log\LoggerInterface;

class JobTest extends \Test\TestCase {
	private $run = false;
	private ITimeFactory $timeFactory;
	private LoggerInterface $logger;

	protected function setUp(): void {
		parent::setUp();
		$this->run = false;
		$this->timeFactory = \OCP\Server::get(ITimeFactory::class);
		$this->logger = $this->createMock(LoggerInterface::class);

		\OC::$server->registerService(LoggerInterface::class, fn ($c) => $this->logger);
	}

	public function testRemoveAfterException(): void {
		$jobList = new DummyJobList();
		$e = new \Exception();
		$job = new TestJob($this->timeFactory, $this, function () use ($e) {
			throw $e;
		});
		$jobList->add($job);

		$this->logger->expects($this->once())
			->method('error');

		$this->assertCount(1, $jobList->getAll());
		$job->start($jobList);
		$this->assertTrue($this->run);
		$this->assertCount(1, $jobList->getAll());
	}

	public function testRemoveAfterError(): void {
		$jobList = new DummyJobList();
		$job = new TestJob($this->timeFactory, $this, function () {
			$test = null;
			$test->someMethod();
		});
		$jobList->add($job);

		$this->logger->expects($this->once())
			->method('error');

		$this->assertCount(1, $jobList->getAll());
		$job->start($jobList);
		$this->assertTrue($this->run);
		$this->assertCount(1, $jobList->getAll());
	}

	public function markRun() {
		$this->run = true;
	}
}