diff options
Diffstat (limited to 'tests/lib/Calendar/Room/ManagerTest.php')
-rw-r--r-- | tests/lib/Calendar/Room/ManagerTest.php | 134 |
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(); } } |