aboutsummaryrefslogtreecommitdiff
path: root/aerogramme/tests
diff options
context:
space:
mode:
authorQuentin Dufour <quentin@deuxfleurs.fr>2024-05-25 19:30:59 +0200
committerQuentin Dufour <quentin@deuxfleurs.fr>2024-05-25 19:30:59 +0200
commit52f870633c2cab8a4aeeec74792774931139b8b5 (patch)
tree878d4ff16cdebd7fdfc50a278dbadedd7eb63480 /aerogramme/tests
parentff823a10f049e06c711537560ba10f3dc826afcd (diff)
downloadaerogramme-52f870633c2cab8a4aeeec74792774931139b8b5.tar.gz
aerogramme-52f870633c2cab8a4aeeec74792774931139b8b5.zip
add a new aero-ical module
Diffstat (limited to 'aerogramme/tests')
-rw-r--r--aerogramme/tests/behavior.rs40
1 files changed, 39 insertions, 1 deletions
diff --git a/aerogramme/tests/behavior.rs b/aerogramme/tests/behavior.rs
index b6c1c6e..0e6dab6 100644
--- a/aerogramme/tests/behavior.rs
+++ b/aerogramme/tests/behavior.rs
@@ -684,6 +684,7 @@ fn rfc4791_webdav_caldav() {
)
.send()?;
//@FIXME not yet supported. returns DAV: 1 ; expects DAV: 1 calendar-access
+ // Not used by any client I know, so not implementing it now.
// --- REPORT calendar-query ---
//@FIXME missing support for calendar-data...
@@ -729,7 +730,7 @@ fn rfc4791_webdav_caldav() {
});
// 8.2.1.2. Synchronize by Time Range (here: July 2006)
- let cal_query = r#" <?xml version="1.0" encoding="utf-8" ?>
+ let cal_query = r#"<?xml version="1.0" encoding="utf-8" ?>
<C:calendar-query xmlns:D="DAV:" xmlns:C="urn:ietf:params:xml:ns:caldav">
<D:prop>
<D:getetag/>
@@ -754,6 +755,43 @@ fn rfc4791_webdav_caldav() {
assert_eq!(multistatus.responses.len(), 1);
check_cal(&multistatus, ("/alice/calendar/Personal/rfc2.ics", Some(obj2_etag.to_str().expect("etag header convertible to str")), None));
+ // 7.8.5. Example: Retrieval of To-Dos by Alarm Time Range
+ let cal_query = r#"<?xml version="1.0" encoding="utf-8" ?>
+ <C:calendar-query xmlns:C="urn:ietf:params:xml:ns:caldav">
+ <D:prop xmlns:D="DAV:">
+ <D:getetag/>
+ <C:calendar-data/>
+ </D:prop>
+ <C:filter>
+ <C:comp-filter name="VCALENDAR">
+ <C:comp-filter name="VTODO">
+ <C:comp-filter name="VALARM">
+ <C:time-range start="20060106T100000Z" end="20060107T100000Z"/>
+ </C:comp-filter>
+ </C:comp-filter>
+ </C:comp-filter>
+ </C:filter>
+ </C:calendar-query>"#;
+ let resp = http
+ .request(
+ reqwest::Method::from_bytes(b"REPORT")?,
+ "http://localhost:8087/alice/calendar/Personal/",
+ )
+ .body(cal_query)
+ .send()?;
+ assert_eq!(resp.status(), 207);
+ let multistatus = dav_deserialize::<dav::Multistatus<All>>(&resp.text()?);
+ //assert_eq!(multistatus.responses.len(), 1);
+
+ // 7.8.6. Example: Retrieval of Event by UID
+ // @TODO
+
+ // 7.8.7. Example: Retrieval of Events by PARTSTAT
+ // @TODO
+
+ // 7.8.9. Example: Retrieval of All Pending To-Dos
+ // @TODO
+
// --- REPORT calendar-multiget ---
let cal_query = r#"<?xml version="1.0" encoding="utf-8" ?>