X-Git-Url: http://Server1/repobrowser/?a=blobdiff_plain;f=source%2Ftests%2Fxestiacalendar_icaltaskload.h;h=208f2d4c338f43366836db030228759a072fe068;hb=d96129306ce32a6c7c6507c78dafea512ba2762c;hp=d122854e47f1b04eec4156db59b4e4e8a6e87d2a;hpb=b171e8bfe1899ab15b443c31807542322ff74c72;p=xestiacalendar%2F.git diff --git a/source/tests/xestiacalendar_icaltaskload.h b/source/tests/xestiacalendar_icaltaskload.h index d122854..208f2d4 100644 --- a/source/tests/xestiacalendar_icaltaskload.h +++ b/source/tests/xestiacalendar_icaltaskload.h @@ -120,9 +120,280 @@ TEST(iCalendarTask, ObjectDataTests){ ASSERT_EQ("kw", TestTask.OrganiserDataLanguage); ASSERT_EQ("HAPPY=WEEKS", TestTask.OrganiserDataTokens); - // Tets for PERCENT-COMPLETE. + // Tests for PERCENT-COMPLETE. ASSERT_EQ("42", TestTask.PercentCompleteData); ASSERT_EQ("DEEP=THOUGHT", TestTask.PercentCompleteTokens); + // Tests for PRIORITY. + + ASSERT_EQ(5, TestTask.PriorityData); + ASSERT_EQ("STATUS=DEFAULT", TestTask.PriorityTokens); + + // Tests for RECURRENCE-ID. + + ASSERT_EQ("20160131", TestTask.RecurranceIDData); + ASSERT_EQ("Europe/Truro", TestTask.RecurranceIDDataTimeZoneParam); + ASSERT_EQ("THISANDFUTURE", TestTask.RecurranceIDDataRangeParam); + ASSERT_EQ("DATE", TestTask.RecurranceIDDataValue); + ASSERT_EQ("EXAMPLE=DATA", TestTask.RecurranceIDDataTokens); + + // Tests for SEQUENCE. + + ASSERT_EQ(3, TestTask.SequenceData); + ASSERT_EQ("TEST=YAY", TestTask.SequenceTokens); + + // Tests for STATUS. + + ASSERT_EQ("2.0;Success", TestTask.StatusData); + ASSERT_EQ("kw", TestTask.StatusLanguage); + ASSERT_EQ("FAVOURITE=BEANS;NOTLIKE=UNKNOWN", TestTask.StatusTokens); + + // Tests for SUMMARY. + + ASSERT_EQ("A summary of the todo.", TestTask.SummaryData); + ASSERT_EQ("null:nodata", TestTask.SummaryDataAltRep); + ASSERT_EQ("kw", TestTask.SummaryDataLanguage); + ASSERT_EQ("FAVOURITE=TOFU;NOTLIKE=NONE", TestTask.SummaryDataTokens); + + // Tests for URL. + + ASSERT_EQ("http://www.example.com/", TestTask.URLData); + ASSERT_EQ("EXTERNAL=YES", TestTask.URLDataTokens); + + // Tests for RRULE. + + ASSERT_EQ("FREQ=DAILY;COUNT=10", TestTask.RecurranceRuleData); + ASSERT_EQ("TEST=DATA", TestTask.RecurranceRuleDataTokens); + + // Tests for DUE. + + ASSERT_EQ("20160131T150000Z", TestTask.DueData); + ASSERT_EQ("Europe/Truro", TestTask.DueDataTimeZoneID); + ASSERT_EQ("DATE-TIME", TestTask.DueDataValue); + ASSERT_EQ("TEST=YES", TestTask.DueDataTokens); + + // Tests for DURATION. + + CalendarTaskObject TestTask2; + ASSERT_EQ(CALENDAROBJECTLOAD_OK, TestTask2.LoadFile("iCalendarTask-Load3.vcf")); + ASSERT_EQ(CALENDAROBJECTVALID_OK, TestTask2.ValidBaseObject()); + + ASSERT_EQ("PT15M", TestTask2.DurationData); + ASSERT_EQ("TEST=YES", TestTask2.DurationDataTokens); + + // Tests for ATTACH. First ATTACH property. + + std::string AttachData; + std::string AttachDataFormatType; + std::string AttachDataValue; + std::string AttachDataEncoding; + std::string AttachDataTokens; + + if (TestTask.AttachList.begin() != TestTask.AttachList.end()){ + + AttachData = TestTask.AttachList[0]; + + } + + if (TestTask.AttachListFormatType.begin() != TestTask.AttachListFormatType.end()){ + + AttachDataFormatType = TestTask.AttachListFormatType[0]; + + } + + ASSERT_EQ("http://www.example.com/", AttachData); + ASSERT_EQ("application/internet-shortcut", AttachDataFormatType); + + // Second ATTACH property. + + AttachData.clear(); + AttachDataFormatType.clear(); + AttachDataValue.clear(); + AttachDataEncoding.clear(); + + if (TestTask.AttachList.size() > 1){ + + AttachData = TestTask.AttachList[1]; + + } + + if (TestTask.AttachListFormatType.size() > 1){ + + AttachDataFormatType = TestTask.AttachListFormatType[1]; + + } + + ASSERT_EQ("http://www.example.com/page2.html", AttachData); + ASSERT_EQ("application/internet-shortcut", AttachDataFormatType); + + // Third ATTACH property. + + AttachData.clear(); + AttachDataFormatType.clear(); + AttachDataValue.clear(); + AttachDataEncoding.clear(); + AttachDataTokens.clear(); + + if (TestTask.AttachList.size() > 2){ + + AttachData = TestTask.AttachList[2]; + + } + + if (TestTask.AttachListFormatType.size() > 2){ + + AttachDataFormatType = TestTask.AttachListFormatType[2]; + + } + + if (TestTask.AttachListValue.size() > 2){ + + AttachDataValue = TestTask.AttachListValue[2]; + + } + + if (TestTask.AttachListFormatType.size() > 2){ + + AttachDataEncoding = TestTask.AttachListEncoding[2]; + + } + + if (TestTask.AttachListTokens.size() > 2){ + + AttachDataTokens = TestTask.AttachListTokens[2]; + + } + + ASSERT_EQ("VGhpcyBpcyBhbiBleGFtcGxlIGZpbGU=", AttachData); + ASSERT_EQ("text/plain", AttachDataFormatType); + ASSERT_EQ("BASE64", AttachDataEncoding); + ASSERT_EQ("BINARY", AttachDataValue); + ASSERT_EQ("STUPID=EXAMPLE", AttachDataTokens); + + // Tests for ATTENDEE. First ATTENDEE property. + + std::string AttendeeDataMember; + std::string AttendeeDataDelegatedFrom; + std::string AttendeeDataDelegatedTo; + std::string AttendeeDataRole; + std::string AttendeeDataRSVP; + std::string AttendeeDataDirectoryEntry; + std::string AttendeeDataSentBy; + std::string AttendeeDataCommonName; + std::string AttendeeDataCalendarUserType; + std::string AttendeeDataParticipationStatus; + std::string AttendeeDataLanguage; + std::string AttendeeDataTokens; + std::string AttendeeData; + + if (TestTask.AttendeeList.begin() != TestTask.AttendeeList.end()){ + + AttendeeData = TestTask.AttendeeList[0]; + + } + + ASSERT_EQ("Attendee One", AttendeeData); + + // Second ATTENDEE property. + + AttendeeData.clear(); + + if (TestTask.AttendeeList.size() > 1){ + + AttendeeData = TestTask.AttendeeList[1]; + + } + + if (TestTask.AttendeeList.size() > 1){ + + AttendeeDataDelegatedFrom = TestTask.AttendeeListDelegatedFrom[1]; + + } + + if (TestTask.AttendeeList.size() > 1){ + + AttendeeDataDelegatedTo = TestTask.AttendeeListDelegatedTo[1]; + + } + + if (TestTask.AttendeeList.size() > 1){ + + AttendeeDataRole = TestTask.AttendeeListRole[1]; + + } + + if (TestTask.AttendeeList.size() > 1){ + + AttendeeDataRSVP = TestTask.AttendeeListRSVP[1]; + + } + + ASSERT_EQ("Attendee Two", AttendeeData); + ASSERT_EQ("mailto:delegated.from@example.com", AttendeeDataDelegatedFrom); + ASSERT_EQ("mailto:delegated.to@example.com", AttendeeDataDelegatedTo); + ASSERT_EQ("CHAIR", AttendeeDataRole); + ASSERT_EQ("TRUE", AttendeeDataRSVP); + + // Third ATTENDEE property. + + AttendeeData.clear(); + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeData = TestTask.AttendeeList[2]; + + } + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeDataDirectoryEntry = TestTask.AttendeeListDirectoryEntry[2]; + + } + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeDataSentBy = TestTask.AttendeeListSentBy[2]; + + } + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeDataCommonName = TestTask.AttendeeListCommonName[2]; + + } + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeDataCalendarUserType = TestTask.AttendeeListCalendarUserType[2]; + + } + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeDataParticipationStatus = TestTask.AttendeeListParticipationStatus[2]; + + } + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeDataLanguage = TestTask.AttendeeListLanguage[2]; + + } + + if (TestTask.AttendeeList.size() > 2){ + + AttendeeDataTokens = TestTask.AttendeeListTokens[2]; + + } + + ASSERT_EQ("Attendee Three", AttendeeData); + ASSERT_EQ("null:nodata", AttendeeDataDirectoryEntry); + ASSERT_EQ("mailto:sent.by@example.com", AttendeeDataSentBy); + ASSERT_EQ("Attendee The Third", AttendeeDataCommonName); + ASSERT_EQ("INDIVIDUAL", AttendeeDataCalendarUserType); + ASSERT_EQ("ACCEPTED", AttendeeDataParticipationStatus); + ASSERT_EQ("kw", AttendeeDataLanguage); + ASSERT_EQ("EXAMPLE=DATA", AttendeeDataTokens); + } \ No newline at end of file