aboutsummaryrefslogtreecommitdiffstats
path: root/tests/lib/Calendar/Room/ManagerTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'tests/lib/Calendar/Room/ManagerTest.php')
-rw-r--r--tests/lib/Calendar/Room/ManagerTest.php134
1 files changed, 78 insertions, 56 deletions
diff --git a/tests/lib/Calendar/Room/ManagerTest.php b/tests/lib/Calendar/Room/ManagerTest.php
index b01d16945ad..e0f2de970ed 100644
--- a/tests/lib/Calendar/Room/ManagerTest.php
+++ b/tests/lib/Calendar/Room/ManagerTest.php
@@ -1,123 +1,145 @@
<?php
+
+declare(strict_types=1);
+
/**
- * @copyright 2018, Georg Ehrke <oc.list@georgehrke.com>
- *
- * @author Georg Ehrke <oc.list@georgehrke.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace Test\Calendar\Room;
+use OC\AppFramework\Bootstrap\Coordinator;
+use OC\AppFramework\Bootstrap\RegistrationContext;
+use OC\AppFramework\Bootstrap\ServiceRegistration;
+use OC\Calendar\ResourcesRoomsUpdater;
use OC\Calendar\Room\Manager;
use OCP\Calendar\Room\IBackend;
use OCP\IServerContainer;
+use PHPUnit\Framework\MockObject\MockObject;
use Test\TestCase;
class ManagerTest extends TestCase {
+ /** @var Coordinator|MockObject */
+ private $coordinator;
+
+ /** @var IServerContainer|MockObject */
+ private $server;
+
+ /** @var ResourcesRoomsUpdater|MockObject */
+ private $resourcesRoomsUpdater;
/** @var Manager */
private $manager;
- /** @var IServerContainer */
- private $server;
-
protected function setUp(): void {
parent::setUp();
+ $this->coordinator = $this->createMock(Coordinator::class);
$this->server = $this->createMock(IServerContainer::class);
- $this->manager = new Manager($this->server);
+ $this->resourcesRoomsUpdater = $this->createMock(ResourcesRoomsUpdater::class);
+
+ $this->manager = new Manager(
+ $this->coordinator,
+ $this->server,
+ $this->resourcesRoomsUpdater,
+ );
}
- public function testRegisterUnregisterBackend() {
+ public function testRegisterUnregisterBackend(): void {
$backend1 = $this->createMock(IBackend::class);
$backend1->method('getBackendIdentifier')->willReturn('backend_1');
- $this->server->expects($this->at(0))
- ->method('query')
- ->with('calendar_room_backend1')
- ->willReturn($backend1);
-
$backend2 = $this->createMock(IBackend::class);
$backend2->method('getBackendIdentifier')->willReturn('backend_2');
- $this->server->expects($this->at(1))
+ $this->server->expects(self::exactly(2))
->method('query')
- ->with('calendar_room_backend2')
- ->willReturn($backend2);
+ ->willReturnMap([
+ ['calendar_room_backend1', true, $backend1,],
+ ['calendar_room_backend2', true, $backend2,],
+ ]);
$this->manager->registerBackend('calendar_room_backend1');
$this->manager->registerBackend('calendar_room_backend2');
- $this->assertEquals([
+ self::assertEquals([
$backend1, $backend2
], $this->manager->getBackends());
$this->manager->unregisterBackend('calendar_room_backend1');
- $this->assertEquals([
+ self::assertEquals([
$backend2
], $this->manager->getBackends());
}
- public function testGetBackend() {
- $backend1 = $this->createMock(IBackend::class);
- $backend1->method('getBackendIdentifier')->willReturn('backend_1');
- $this->server->expects($this->at(0))
+ public function testGetBackendFromBootstrapRegistration(): void {
+ $backendClass = '\\OCA\\CalendarRoomFoo\\Backend';
+ $backend = $this->createMock(IBackend::class);
+ $backend->method('getBackendIdentifier')->willReturn('from_bootstrap');
+ $context = $this->createMock(RegistrationContext::class);
+ $this->coordinator->expects(self::once())
+ ->method('getRegistrationContext')
+ ->willReturn($context);
+ $context->expects(self::once())
+ ->method('getCalendarRoomBackendRegistrations')
+ ->willReturn([
+ new ServiceRegistration('calendar_room_foo', $backendClass)
+ ]);
+ $this->server->expects(self::once())
->method('query')
- ->with('calendar_room_backend1')
- ->willReturn($backend1);
+ ->with($backendClass)
+ ->willReturn($backend);
+
+ self::assertEquals($backend, $this->manager->getBackend('from_bootstrap'));
+ }
+ public function testGetBackend(): void {
+ $backend1 = $this->createMock(IBackend::class);
+ $backend1->method('getBackendIdentifier')->willReturn('backend_1');
$backend2 = $this->createMock(IBackend::class);
$backend2->method('getBackendIdentifier')->willReturn('backend_2');
- $this->server->expects($this->at(1))
+ $this->server->expects(self::exactly(2))
->method('query')
- ->with('calendar_room_backend2')
- ->willReturn($backend2);
+ ->willReturnMap([
+ ['calendar_room_backend1', true, $backend1,],
+ ['calendar_room_backend2', true, $backend2,],
+ ]);
$this->manager->registerBackend('calendar_room_backend1');
$this->manager->registerBackend('calendar_room_backend2');
- $this->assertEquals($backend1, $this->manager->getBackend('backend_1'));
- $this->assertEquals($backend2, $this->manager->getBackend('backend_2'));
+ self::assertEquals($backend1, $this->manager->getBackend('backend_1'));
+ self::assertEquals($backend2, $this->manager->getBackend('backend_2'));
}
- public function testClear() {
+ public function testClear(): void {
$backend1 = $this->createMock(IBackend::class);
$backend1->method('getBackendIdentifier')->willReturn('backend_1');
- $this->server->expects($this->at(0))
- ->method('query')
- ->with('calendar_room_backend1')
- ->willReturn($backend1);
-
$backend2 = $this->createMock(IBackend::class);
$backend2->method('getBackendIdentifier')->willReturn('backend_2');
- $this->server->expects($this->at(1))
+ $this->server->expects(self::exactly(2))
->method('query')
- ->with('calendar_room_backend2')
- ->willReturn($backend2);
+ ->willReturnMap([
+ ['calendar_room_backend1', true, $backend1,],
+ ['calendar_room_backend2', true, $backend2,],
+ ]);
$this->manager->registerBackend('calendar_room_backend1');
$this->manager->registerBackend('calendar_room_backend2');
- $this->assertEquals([
+ self::assertEquals([
$backend1, $backend2
], $this->manager->getBackends());
$this->manager->clear();
- $this->assertEquals([], $this->manager->getBackends());
+ self::assertEquals([], $this->manager->getBackends());
+ }
+
+ public function testUpdate(): void {
+ $this->resourcesRoomsUpdater->expects(self::once())
+ ->method('updateRooms');
+
+ $this->manager->update();
}
}