mirror of
https://git.friendi.ca/friendica/friendica-addons.git
synced 2025-07-09 18:08:49 +00:00
Initial Release of the calendar plugin
This commit is contained in:
parent
45cc9885fc
commit
7115197a33
561 changed files with 189494 additions and 0 deletions
135
dav/SabreDAV/tests/Sabre/CalDAV/Issue203Test.php
Normal file
135
dav/SabreDAV/tests/Sabre/CalDAV/Issue203Test.php
Normal file
|
@ -0,0 +1,135 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* This unittest is created to find out why an overwritten DAILY event has wrong DTSTART, DTEND, SUMMARY and RECURRENCEID
|
||||
*
|
||||
*
|
||||
* @copyright Copyright (C) 2007-2012 Rooftop Solutions. All rights reserved.
|
||||
* @author Evert Pot (http://www.rooftopsolutions.nl/)
|
||||
* @license http://code.google.com/p/sabredav/wiki/License Modified BSD License
|
||||
*/
|
||||
class Sabre_CalDAV_Issue203Test extends Sabre_DAVServerTest {
|
||||
|
||||
protected $setupCalDAV = true;
|
||||
|
||||
protected $caldavCalendars = array(
|
||||
array(
|
||||
'id' => 1,
|
||||
'name' => 'Calendar',
|
||||
'principaluri' => 'principals/user1',
|
||||
'uri' => 'calendar1',
|
||||
)
|
||||
);
|
||||
|
||||
protected $caldavCalendarObjects = array(
|
||||
1 => array(
|
||||
'event.ics' => array(
|
||||
'calendardata' => 'BEGIN:VCALENDAR
|
||||
VERSION:2.0
|
||||
BEGIN:VEVENT
|
||||
UID:20120330T155305CEST-6585fBUVgV
|
||||
DTSTAMP:20120330T135305Z
|
||||
DTSTART;TZID=Europe/Berlin:20120326T155200
|
||||
DTEND;TZID=Europe/Berlin:20120326T165200
|
||||
RRULE:FREQ=DAILY;COUNT=2;INTERVAL=1
|
||||
SUMMARY:original summary
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
UID:20120330T155305CEST-6585fBUVgV
|
||||
DTSTAMP:20120330T135352Z
|
||||
DESCRIPTION:
|
||||
DTSTART;TZID=Europe/Berlin:20120328T155200
|
||||
DTEND;TZID=Europe/Berlin:20120328T165200
|
||||
RECURRENCE-ID;TZID=Europe/Berlin:20120327T155200
|
||||
SEQUENCE:1
|
||||
SUMMARY:overwritten summary
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
END:VCALENDAR
|
||||
',
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
function testIssue203() {
|
||||
|
||||
$request = new Sabre_HTTP_Request(array(
|
||||
'REQUEST_METHOD' => 'REPORT',
|
||||
'HTTP_CONTENT_TYPE' => 'application/xml',
|
||||
'REQUEST_URI' => '/calendars/user1/calendar1',
|
||||
'HTTP_DEPTH' => '1',
|
||||
));
|
||||
|
||||
$request->setBody('<?xml version="1.0" encoding="utf-8" ?>
|
||||
<C:calendar-query xmlns:D="DAV:" xmlns:C="urn:ietf:params:xml:ns:caldav">
|
||||
<D:prop>
|
||||
<C:calendar-data>
|
||||
<C:expand start="20120325T220000Z" end="20120401T215959Z"/>
|
||||
</C:calendar-data>
|
||||
<D:getetag/>
|
||||
</D:prop>
|
||||
<C:filter>
|
||||
<C:comp-filter name="VCALENDAR">
|
||||
<C:comp-filter name="VEVENT">
|
||||
<C:time-range start="20120325T220000Z" end="20120401T215959Z"/>
|
||||
</C:comp-filter>
|
||||
</C:comp-filter>
|
||||
</C:filter>
|
||||
</C:calendar-query>');
|
||||
|
||||
$response = $this->request($request);
|
||||
|
||||
// Everts super awesome xml parser.
|
||||
$body = substr(
|
||||
$response->body,
|
||||
$start = strpos($response->body, 'BEGIN:VCALENDAR'),
|
||||
strpos($response->body, 'END:VCALENDAR') - $start + 13
|
||||
);
|
||||
$body = str_replace(' ','',$body);
|
||||
|
||||
$vObject = Sabre_VObject_Reader::read($body);
|
||||
|
||||
$this->assertEquals(2, count($vObject->VEVENT));
|
||||
|
||||
|
||||
$expectedEvents = array(
|
||||
array(
|
||||
'DTSTART' => '20120326T135200Z',
|
||||
'DTEND' => '20120326T145200Z',
|
||||
'SUMMARY' => 'original summary',
|
||||
),
|
||||
array(
|
||||
'DTSTART' => '20120328T135200Z',
|
||||
'DTEND' => '20120328T145200Z',
|
||||
'SUMMARY' => 'overwritten summary',
|
||||
'RECURRENCE-ID' => '20120327T135200Z',
|
||||
)
|
||||
);
|
||||
|
||||
// try to match agains $expectedEvents array
|
||||
foreach ($expectedEvents as $expectedEvent) {
|
||||
|
||||
$matching = false;
|
||||
|
||||
foreach ($vObject->VEVENT as $vevent) {
|
||||
/** @var $vevent Sabre_VObject_Component_VEvent */
|
||||
|
||||
foreach ($vevent->children as $child) {
|
||||
/** @var $child Sabre_VObject_Property */
|
||||
|
||||
if (isset($expectedEvent[$child->name])) {
|
||||
if ($expectedEvent[$child->name] != $child->value) {
|
||||
continue 2;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$matching = true;
|
||||
break;
|
||||
}
|
||||
|
||||
$this->assertTrue($matching, 'Did not find the following event in the response: '.var_export($expectedEvent, true));
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue