123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-only
- */
- namespace OCA\DAV\Tests\unit\CardDAV;
- use OCA\DAV\CardDAV\AddressBook;
- use OCA\DAV\CardDAV\Card;
- use OCA\DAV\CardDAV\CardDavBackend;
- use OCP\IL10N;
- use PHPUnit\Framework\MockObject\MockObject;
- use Psr\Log\LoggerInterface;
- use Sabre\DAV\Exception\Forbidden;
- use Sabre\DAV\PropPatch;
- use Test\TestCase;
- class AddressBookTest extends TestCase {
- public function testMove(): void {
- $backend = $this->createMock(CardDavBackend::class);
- $addressBookInfo = [
- '{http://owncloud.org/ns}owner-principal' => 'user1',
- '{DAV:}displayname' => 'Test address book',
- 'principaluri' => 'user2',
- 'id' => 666,
- 'uri' => 'default',
- ];
- $l10n = $this->createMock(IL10N::class);
- $logger = $this->createMock(LoggerInterface::class);
- $addressBook = new AddressBook($backend, $addressBookInfo, $l10n, $logger);
- $card = new Card($backend, $addressBookInfo, ['id' => 5, 'carddata' => 'RANDOM VCF DATA', 'uri' => 'something', 'addressbookid' => 23]);
- $backend->expects($this->once())->method('moveCard')->with(23, 666, 'something', 'user1')->willReturn(true);
- $addressBook->moveInto('new', 'old', $card);
- }
- public function testDelete(): void {
- /** @var MockObject | CardDavBackend $backend */
- $backend = $this->getMockBuilder(CardDavBackend::class)->disableOriginalConstructor()->getMock();
- $backend->expects($this->once())->method('updateShares');
- $backend->expects($this->any())->method('getShares')->willReturn([
- ['href' => 'principal:user2']
- ]);
- $addressBookInfo = [
- '{http://owncloud.org/ns}owner-principal' => 'user1',
- '{DAV:}displayname' => 'Test address book',
- 'principaluri' => 'user2',
- 'id' => 666,
- 'uri' => 'default',
- ];
- $l10n = $this->createMock(IL10N::class);
- $logger = $this->createMock(LoggerInterface::class);
- $addressBook = new AddressBook($backend, $addressBookInfo, $l10n, $logger);
- $addressBook->delete();
- }
- public function testDeleteFromGroup(): void {
- $this->expectException(Forbidden::class);
- /** @var MockObject | CardDavBackend $backend */
- $backend = $this->getMockBuilder(CardDavBackend::class)->disableOriginalConstructor()->getMock();
- $backend->expects($this->never())->method('updateShares');
- $backend->expects($this->any())->method('getShares')->willReturn([
- ['href' => 'principal:group2']
- ]);
- $addressBookInfo = [
- '{http://owncloud.org/ns}owner-principal' => 'user1',
- '{DAV:}displayname' => 'Test address book',
- 'principaluri' => 'user2',
- 'id' => 666,
- 'uri' => 'default',
- ];
- $l10n = $this->createMock(IL10N::class);
- $logger = $this->createMock(LoggerInterface::class);
- $addressBook = new AddressBook($backend, $addressBookInfo, $l10n, $logger);
- $addressBook->delete();
- }
- public function testPropPatchShared(): void {
- /** @var MockObject | CardDavBackend $backend */
- $backend = $this->getMockBuilder(CardDavBackend::class)->disableOriginalConstructor()->getMock();
- $backend->expects($this->never())->method('updateAddressBook');
- $addressBookInfo = [
- '{http://owncloud.org/ns}owner-principal' => 'user1',
- '{DAV:}displayname' => 'Test address book',
- 'principaluri' => 'user2',
- 'id' => 666,
- 'uri' => 'default',
- ];
- $l10n = $this->createMock(IL10N::class);
- $logger = $this->createMock(LoggerInterface::class);
- $addressBook = new AddressBook($backend, $addressBookInfo, $l10n, $logger);
- $addressBook->propPatch(new PropPatch(['{DAV:}displayname' => 'Test address book']));
- }
- public function testPropPatchNotShared(): void {
- /** @var MockObject | CardDavBackend $backend */
- $backend = $this->getMockBuilder(CardDavBackend::class)->disableOriginalConstructor()->getMock();
- $backend->expects($this->atLeast(1))->method('updateAddressBook');
- $addressBookInfo = [
- '{DAV:}displayname' => 'Test address book',
- 'principaluri' => 'user1',
- 'id' => 666,
- 'uri' => 'default',
- ];
- $l10n = $this->createMock(IL10N::class);
- $logger = $this->createMock(LoggerInterface::class);
- $addressBook = new AddressBook($backend, $addressBookInfo, $l10n, $logger);
- $addressBook->propPatch(new PropPatch(['{DAV:}displayname' => 'Test address book']));
- }
- /**
- * @dataProvider providesReadOnlyInfo
- */
- public function testAcl($expectsWrite, $readOnlyValue, $hasOwnerSet): void {
- /** @var MockObject | CardDavBackend $backend */
- $backend = $this->getMockBuilder(CardDavBackend::class)->disableOriginalConstructor()->getMock();
- $backend->expects($this->any())->method('applyShareAcl')->willReturnArgument(1);
- $addressBookInfo = [
- '{DAV:}displayname' => 'Test address book',
- 'principaluri' => 'user2',
- 'id' => 666,
- 'uri' => 'default'
- ];
- if (!is_null($readOnlyValue)) {
- $addressBookInfo['{http://owncloud.org/ns}read-only'] = $readOnlyValue;
- }
- if ($hasOwnerSet) {
- $addressBookInfo['{http://owncloud.org/ns}owner-principal'] = 'user1';
- }
- $l10n = $this->createMock(IL10N::class);
- $logger = $this->createMock(LoggerInterface::class);
- $addressBook = new AddressBook($backend, $addressBookInfo, $l10n, $logger);
- $acl = $addressBook->getACL();
- $childAcl = $addressBook->getChildACL();
- $expectedAcl = [[
- 'privilege' => '{DAV:}read',
- 'principal' => $hasOwnerSet ? 'user1' : 'user2',
- 'protected' => true
- ], [
- 'privilege' => '{DAV:}write',
- 'principal' => $hasOwnerSet ? 'user1' : 'user2',
- 'protected' => true
- ], [
- 'privilege' => '{DAV:}write-properties',
- 'principal' => $hasOwnerSet ? 'user1' : 'user2',
- 'protected' => true
- ]];
- if ($hasOwnerSet) {
- $expectedAcl[] = [
- 'privilege' => '{DAV:}read',
- 'principal' => 'user2',
- 'protected' => true
- ];
- if ($expectsWrite) {
- $expectedAcl[] = [
- 'privilege' => '{DAV:}write',
- 'principal' => 'user2',
- 'protected' => true
- ];
- }
- }
- $this->assertEquals($expectedAcl, $acl);
- $this->assertEquals($expectedAcl, $childAcl);
- }
- public function providesReadOnlyInfo(): array {
- return [
- 'read-only property not set' => [true, null, true],
- 'read-only property is false' => [true, false, true],
- 'read-only property is true' => [false, true, true],
- 'read-only property not set and no owner' => [true, null, false],
- 'read-only property is false and no owner' => [true, false, false],
- 'read-only property is true and no owner' => [false, true, false],
- ];
- }
- }
|