mirror of
https://gitlab.com/davical-project/davical.git
synced 2026-04-22 14:40:38 +00:00
This allows us to have more complex test files where an action is taken, then we test something, then another action is taken, etc. Changes to test files are required so that URL is defined after all the required settings are set. Changes to the result files are either whitespace changes due to above logic changes, or printing out a SQL Result header before each result. I figured it was useful.
54 lines
1.9 KiB
Plaintext
54 lines
1.9 KiB
Plaintext
#
|
|
# Testing for how iCal does a POST for free/busy
|
|
#
|
|
TYPE=POST
|
|
HEADER=User-Agent: DAVKit/3.0.4 (652); CalendarStore/3.0.5 (841); iCal/3.0.5 (1270); Mac OS X/10.5.5 (9F33)
|
|
HEADER=Recipient: mailto:user2@example.net
|
|
HEADER=Content-Type: text/calendar
|
|
HEADER=Originator: mailto:user1@example.net
|
|
|
|
|
|
BEGINDATA
|
|
BEGIN:VCALENDAR
|
|
PRODID:-//Apple Inc.//iCal 3.0//EN
|
|
CALSCALE:GREGORIAN
|
|
VERSION:2.0
|
|
METHOD:REQUEST
|
|
BEGIN:VFREEBUSY
|
|
DTSTART:20081022T054500Z
|
|
UID:89E43E7F-911D-4052-9FE3-4782268649E0
|
|
ORGANIZER:mailto:user1@example.net
|
|
X-WR-ATTENDEE:mailto:user2@example.net
|
|
DTSTAMP:20081025T112708Z
|
|
SUMMARY:Availability for mailto:user2@example.net
|
|
CREATED:20081025T112708Z
|
|
DTEND:20081024T083000Z
|
|
X-CALENDARSERVER-MASK-UID:174F9C2A-1223-40C4-9E06-6E91F2EA9491
|
|
END:VFREEBUSY
|
|
END:VCALENDAR
|
|
ENDDATA
|
|
|
|
REPLACE=#<creationdate>\d{8}T\d{6}</creationdate>#<creationdate>YYYYMMDDThhmmss</creationdate>#
|
|
REPLACE=/^DTSTAMP:\d{4}[01]\d[0123]\dT[012]\d[0-5]\d[0-6]\dZ\r?$/DTSTAMP:yyyymmddThhmmssZ/
|
|
|
|
URL=http://regression.host/caldav.php/user1/.out/
|
|
|
|
QUERY
|
|
SELECT calendar_item.rrule, calendar_item.status,
|
|
dtstart AT TIME ZONE olson_name AS "a) Start",
|
|
olson_name AS "b) Location",
|
|
to_char(calendar_item.dtstart at time zone 'GMT','YYYYMMDD"T"HH24MISS"Z"') AS "c)UTC Start",
|
|
to_char(calendar_item.dtend at time zone 'GMT','YYYYMMDD"T"HH24MISS"Z"') AS "d) UTC End"
|
|
FROM usr INNER JOIN collection USING (user_no)
|
|
INNER JOIN caldav_data USING (collection_id)
|
|
INNER JOIN calendar_item USING(dav_id)
|
|
LEFT JOIN timezones ON (tz_id=tzid)
|
|
WHERE caldav_data.dav_name ~ '^/user2/'
|
|
AND collection.is_calendar
|
|
AND rrule_event_overlaps( dtstart, dtend, rrule, '20081022T054500Z', '20081024T083000Z' )
|
|
AND caldav_data.caldav_type IN ( 'VEVENT', 'VFREEBUSY' )
|
|
AND (calendar_item.transp != 'TRANSPARENT' OR calendar_item.transp IS NULL)
|
|
AND (calendar_item.status != 'CANCELLED' OR calendar_item.status IS NULL)
|
|
ORDER BY 2, 3
|
|
ENDQUERY
|