diff options
author | Morris Jobke <hey@morrisjobke.de> | 2017-11-16 21:10:35 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-11-16 21:10:35 +0100 |
commit | f32fbbca2e90559458460be40df6850903b1168e (patch) | |
tree | eff22898eba04034d7e83cc50a12337d44a9dc45 /apps/dav/tests | |
parent | 44b423be355b9fdf1f8354b3c62a2344c53b141c (diff) | |
parent | 7784672cc00c83f1bfce57fc61eebe40c8f8c8a8 (diff) | |
download | nextcloud-server-f32fbbca2e90559458460be40df6850903b1168e.tar.gz nextcloud-server-f32fbbca2e90559458460be40df6850903b1168e.zip |
Merge pull request #6840 from nextcloud/feature/5282/calendar_api
Calendar API for apps
Diffstat (limited to 'apps/dav/tests')
-rw-r--r-- | apps/dav/tests/unit/CalDAV/CalDavBackendTest.php | 109 | ||||
-rw-r--r-- | apps/dav/tests/unit/CalDAV/CalendarImplTest.php | 126 | ||||
-rw-r--r-- | apps/dav/tests/unit/CalDAV/CalendarManagerTest.php | 81 |
3 files changed, 316 insertions, 0 deletions
diff --git a/apps/dav/tests/unit/CalDAV/CalDavBackendTest.php b/apps/dav/tests/unit/CalDAV/CalDavBackendTest.php index fae2156a6b4..fc34a7af952 100644 --- a/apps/dav/tests/unit/CalDAV/CalDavBackendTest.php +++ b/apps/dav/tests/unit/CalDAV/CalDavBackendTest.php @@ -721,4 +721,113 @@ EOD; ]); $this->assertEquals(count($search5), 0); } + + /** + * @dataProvider searchDataProvider + */ + public function testSearch($isShared, $count) { + $calendarId = $this->createTestCalendar(); + + $uris = []; + $calData = []; + + $uris[] = static::getUniqueID('calobj'); + $calData[] = <<<EOD +BEGIN:VCALENDAR +VERSION:2.0 +PRODID:Nextcloud Calendar +BEGIN:VEVENT +CREATED;VALUE=DATE-TIME:20130910T125139Z +UID:47d15e3ec8-1 +LAST-MODIFIED;VALUE=DATE-TIME:20130910T125139Z +DTSTAMP;VALUE=DATE-TIME:20130910T125139Z +SUMMARY:Test Event +DTSTART;VALUE=DATE-TIME:20130912T130000Z +DTEND;VALUE=DATE-TIME:20130912T140000Z +CLASS:PUBLIC +END:VEVENT +END:VCALENDAR +EOD; + + $uris[] = static::getUniqueID('calobj'); + $calData[] = <<<EOD +BEGIN:VCALENDAR +VERSION:2.0 +PRODID:Nextcloud Calendar +BEGIN:VEVENT +CREATED;VALUE=DATE-TIME:20130910T125139Z +UID:47d15e3ec8-2 +LAST-MODIFIED;VALUE=DATE-TIME:20130910T125139Z +DTSTAMP;VALUE=DATE-TIME:20130910T125139Z +SUMMARY:123 +LOCATION:Test +DTSTART;VALUE=DATE-TIME:20130912T130000Z +DTEND;VALUE=DATE-TIME:20130912T140000Z +CLASS:PUBLIC +END:VEVENT +END:VCALENDAR +EOD; + + $uris[] = static::getUniqueID('calobj'); + $calData[] = <<<EOD +BEGIN:VCALENDAR +VERSION:2.0 +PRODID:Nextcloud Calendar +BEGIN:VEVENT +CREATED;VALUE=DATE-TIME:20130910T125139Z +UID:47d15e3ec8-3 +LAST-MODIFIED;VALUE=DATE-TIME:20130910T125139Z +DTSTAMP;VALUE=DATE-TIME:20130910T125139Z +SUMMARY:123 +ATTENDEE;CN=test:mailto:foo@bar.com +DTSTART;VALUE=DATE-TIME:20130912T130000Z +DTEND;VALUE=DATE-TIME:20130912T140000Z +CLASS:PRIVATE +END:VEVENT +END:VCALENDAR +EOD; + + $uris[] = static::getUniqueID('calobj'); + $calData[] = <<<EOD +BEGIN:VCALENDAR +VERSION:2.0 +PRODID:Nextcloud Calendar +BEGIN:VEVENT +CREATED;VALUE=DATE-TIME:20130910T125139Z +UID:47d15e3ec8-4 +LAST-MODIFIED;VALUE=DATE-TIME:20130910T125139Z +DTSTAMP;VALUE=DATE-TIME:20130910T125139Z +SUMMARY:123 +ATTENDEE;CN=foobar:mailto:test@bar.com +DTSTART;VALUE=DATE-TIME:20130912T130000Z +DTEND;VALUE=DATE-TIME:20130912T140000Z +CLASS:CONFIDENTIAL +END:VEVENT +END:VCALENDAR +EOD; + + $uriCount = count($uris); + for ($i=0; $i < $uriCount; $i++) { + $this->backend->createCalendarObject($calendarId, + $uris[$i], $calData[$i]); + } + + $calendarInfo = [ + 'id' => $calendarId, + 'principaluri' => 'user1', + '{http://owncloud.org/ns}owner-principal' => $isShared ? 'user2' : 'user1', + ]; + + $result = $this->backend->search($calendarInfo, 'Test', + ['SUMMARY', 'LOCATION', 'ATTENDEE'], [], null, null); + + $this->assertCount($count, $result); + } + + public function searchDataProvider() { + return [ + [false, 4], + [true, 2], + ]; + } } diff --git a/apps/dav/tests/unit/CalDAV/CalendarImplTest.php b/apps/dav/tests/unit/CalDAV/CalendarImplTest.php new file mode 100644 index 00000000000..ca3256773b3 --- /dev/null +++ b/apps/dav/tests/unit/CalDAV/CalendarImplTest.php @@ -0,0 +1,126 @@ +<?php +/** + * @copyright 2017, 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/>. + * + */ + +namespace OCA\DAV\Tests\unit\CalDAV; + +use OCA\DAV\CalDAV\CalDavBackend; +use OCA\DAV\CalDAV\Calendar; +use OCA\DAV\CalDAV\CalendarImpl; + +class CalendarImplTest extends \Test\TestCase { + + /** @var CalendarImpl */ + private $calendarImpl; + + /** @var Calendar | \PHPUnit_Framework_MockObject_MockObject */ + private $calendar; + + /** @var array */ + private $calendarInfo; + + /** @var CalDavBackend | \PHPUnit_Framework_MockObject_MockObject */ + private $backend; + + protected function setUp() { + parent::setUp(); + + $this->calendar = $this->createMock(Calendar::class); + $this->calendarInfo = [ + 'id' => 'fancy_id_123', + '{DAV:}displayname' => 'user readable name 123', + '{http://apple.com/ns/ical/}calendar-color' => '#AABBCC', + ]; + $this->backend = $this->createMock(CalDavBackend::class); + + $this->calendarImpl = new CalendarImpl($this->calendar, + $this->calendarInfo, $this->backend); + } + + + public function testGetKey() { + $this->assertEquals($this->calendarImpl->getKey(), 'fancy_id_123'); + } + + public function testGetDisplayname() { + $this->assertEquals($this->calendarImpl->getDisplayName(),'user readable name 123'); + } + + public function testGetDisplayColor() { + $this->assertEquals($this->calendarImpl->getDisplayColor(), '#AABBCC'); + } + + public function testSearch() { + $this->backend->expects($this->once()) + ->method('search') + ->with($this->calendarInfo, 'abc', ['def'], ['ghi'], 42, 1337) + ->will($this->returnValue(['SEARCHRESULTS'])); + + $result = $this->calendarImpl->search('abc', ['def'], ['ghi'], 42, 1337); + $this->assertEquals($result, ['SEARCHRESULTS']); + } + + public function testGetPermissionRead() { + $this->calendar->expects($this->once()) + ->method('getACL') + ->with() + ->will($this->returnValue([ + ['privilege' => '{DAV:}read'] + ])); + + $this->assertEquals(1, $this->calendarImpl->getPermissions()); + } + + public function testGetPermissionWrite() { + $this->calendar->expects($this->once()) + ->method('getACL') + ->with() + ->will($this->returnValue([ + ['privilege' => '{DAV:}write'] + ])); + + $this->assertEquals(6, $this->calendarImpl->getPermissions()); + } + + public function testGetPermissionReadWrite() { + $this->calendar->expects($this->once()) + ->method('getACL') + ->with() + ->will($this->returnValue([ + ['privilege' => '{DAV:}read'], + ['privilege' => '{DAV:}write'] + ])); + + $this->assertEquals(7, $this->calendarImpl->getPermissions()); + } + + public function testGetPermissionAll() { + $this->calendar->expects($this->once()) + ->method('getACL') + ->with() + ->will($this->returnValue([ + ['privilege' => '{DAV:}all'] + ])); + + $this->assertEquals(31, $this->calendarImpl->getPermissions()); + } +} diff --git a/apps/dav/tests/unit/CalDAV/CalendarManagerTest.php b/apps/dav/tests/unit/CalDAV/CalendarManagerTest.php new file mode 100644 index 00000000000..db8c536da53 --- /dev/null +++ b/apps/dav/tests/unit/CalDAV/CalendarManagerTest.php @@ -0,0 +1,81 @@ +<?php +/** + * @copyright 2017, 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/>. + * + */ + +namespace OCA\DAV\Tests\unit\CalDAV; + +use OC\Calendar\Manager; +use OCA\DAV\CalDAV\CalDavBackend; +use OCA\DAV\CalDAV\CalendarImpl; +use OCA\DAV\CalDAV\CalendarManager; +use OCP\Calendar\IManager; +use OCP\IL10N; + +class CalendarManagerTest extends \Test\TestCase { + + /** @var CalDavBackend | \PHPUnit_Framework_MockObject_MockObject */ + private $backend; + + /** @var IL10N | \PHPUnit_Framework_MockObject_MockObject */ + private $l10n; + + /** @var CalendarManager */ + private $manager; + + protected function setUp() { + parent::setUp(); + $this->backend = $this->createMock(CalDavBackend::class); + $this->l10n = $this->createMock(IL10N::class); + $this->manager = new CalendarManager($this->backend, + $this->l10n); + } + + public function testSetupCalendarProvider() { + $this->backend->expects($this->once()) + ->method('getCalendarsForUser') + ->with('principals/users/user123') + ->will($this->returnValue([ + ['id' => 123, 'uri' => 'blablub1'], + ['id' => 456, 'uri' => 'blablub2'], + ])); + + /** @var IManager | \PHPUnit_Framework_MockObject_MockObject $calendarManager */ + $calendarManager = $this->createMock(Manager::class); + $calendarManager->expects($this->at(0)) + ->method('registerCalendar') + ->will($this->returnCallback(function() { + $parameter = func_get_arg(0); + $this->assertInstanceOf(CalendarImpl::class, $parameter); + $this->assertEquals(123, $parameter->getKey()); + })); + + $calendarManager->expects($this->at(1)) + ->method('registerCalendar') + ->will($this->returnCallback(function() { + $parameter = func_get_arg(0); + $this->assertInstanceOf(CalendarImpl::class, $parameter); + $this->assertEquals(456, $parameter->getKey()); + })); + + $this->manager->setupCalendarProvider($calendarManager, 'user123'); + } +} |