X-Git-Url: http://Server1/repobrowser/?a=blobdiff_plain;f=source%2Ftests%2Fxestiacalendar_icaljournalload.h;h=708fd722aa150d1b33da6483563e0900d12baaea;hb=21c4c8ea2f2464ad83d458adbe4ef451817eb3db;hp=a18be03a044adae89271501886793561bd1177ef;hpb=500c60854b21599d281f1b0146cb5eee8332ffee;p=xestiacalendar%2F.git diff --git a/source/tests/xestiacalendar_icaljournalload.h b/source/tests/xestiacalendar_icaljournalload.h index a18be03..708fd72 100644 --- a/source/tests/xestiacalendar_icaljournalload.h +++ b/source/tests/xestiacalendar_icaljournalload.h @@ -101,4 +101,587 @@ TEST(iCalendarJournal, ObjectDataTests){ ASSERT_EQ("http://www.example.com/", TestJournal.URLData); ASSERT_EQ("EXTERNAL=YES", TestJournal.URLDataTokens); + // Tests for RRULE. + + ASSERT_EQ("FREQ=DAILY;COUNT=10", TestJournal.RecurranceRuleData); + ASSERT_EQ("TEST=DATA", TestJournal.RecurranceRuleDataTokens); + + // Tests for ATTACH. First ATTACH property. + + std::string AttachData; + std::string AttachDataFormatType; + std::string AttachDataValue; + std::string AttachDataEncoding; + std::string AttachDataTokens; + + if (TestJournal.AttachList.begin() != TestJournal.AttachList.end()){ + + AttachData = TestJournal.AttachList[0]; + + } + + if (TestJournal.AttachListFormatType.begin() != TestJournal.AttachListFormatType.end()){ + + AttachDataFormatType = TestJournal.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 (TestJournal.AttachList.size() > 1){ + + AttachData = TestJournal.AttachList[1]; + + } + + if (TestJournal.AttachListFormatType.size() > 1){ + + AttachDataFormatType = TestJournal.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 (TestJournal.AttachList.size() > 2){ + + AttachData = TestJournal.AttachList[2]; + + } + + if (TestJournal.AttachListFormatType.size() > 2){ + + AttachDataFormatType = TestJournal.AttachListFormatType[2]; + + } + + if (TestJournal.AttachListValue.size() > 2){ + + AttachDataValue = TestJournal.AttachListValue[2]; + + } + + if (TestJournal.AttachListFormatType.size() > 2){ + + AttachDataEncoding = TestJournal.AttachListEncoding[2]; + + } + + if (TestJournal.AttachListTokens.size() > 2){ + + AttachDataTokens = TestJournal.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 (TestJournal.AttendeeList.begin() != TestJournal.AttendeeList.end()){ + + AttendeeData = TestJournal.AttendeeList[0]; + + } + + ASSERT_EQ("Attendee One", AttendeeData); + + // Second ATTENDEE property. + + AttendeeData.clear(); + + if (TestJournal.AttendeeList.size() > 1){ + + AttendeeData = TestJournal.AttendeeList[1]; + + } + + if (TestJournal.AttendeeList.size() > 1){ + + AttendeeDataDelegatedFrom = TestJournal.AttendeeListDelegatedFrom[1]; + + } + + if (TestJournal.AttendeeList.size() > 1){ + + AttendeeDataDelegatedTo = TestJournal.AttendeeListDelegatedTo[1]; + + } + + if (TestJournal.AttendeeList.size() > 1){ + + AttendeeDataRole = TestJournal.AttendeeListRole[1]; + + } + + if (TestJournal.AttendeeList.size() > 1){ + + AttendeeDataRSVP = TestJournal.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 (TestJournal.AttendeeList.size() > 2){ + + AttendeeData = TestJournal.AttendeeList[2]; + + } + + if (TestJournal.AttendeeList.size() > 2){ + + AttendeeDataDirectoryEntry = TestJournal.AttendeeListDirectoryEntry[2]; + + } + + if (TestJournal.AttendeeList.size() > 2){ + + AttendeeDataSentBy = TestJournal.AttendeeListSentBy[2]; + + } + + if (TestJournal.AttendeeList.size() > 2){ + + AttendeeDataCommonName = TestJournal.AttendeeListCommonName[2]; + + } + + if (TestJournal.AttendeeList.size() > 2){ + + AttendeeDataCalendarUserType = TestJournal.AttendeeListCalendarUserType[2]; + + } + + if (TestJournal.AttendeeList.size() > 2){ + + AttendeeDataParticipationStatus = TestJournal.AttendeeListParticipationStatus[2]; + + } + + if (TestJournal.AttendeeList.size() > 2){ + + AttendeeDataLanguage = TestJournal.AttendeeListLanguage[2]; + + } + + if (TestJournal.AttendeeList.size() > 2){ + + AttendeeDataTokens = TestJournal.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); + + // Get the first CATEGORIES. + + std::string CategoryData; + + if (TestJournal.CategoriesList.begin() != TestJournal.CategoriesList.end()){ + + CategoryData = TestJournal.CategoriesList[0]; + + } + + ASSERT_EQ("CATEGORY ONE, CATEGORY TWO", CategoryData); + + CategoryData.clear(); + + std::string CategoryLanguage; + + // Get the second CATEGORIES. + + if (TestJournal.CategoriesList.size() > 1){ + + CategoryData = TestJournal.CategoriesList[1]; + + } + + if (TestJournal.CategoriesList.size() > 1){ + + CategoryLanguage = TestJournal.CategoriesListLanguage[1]; + + } + + ASSERT_EQ("CATEGORY THREE, CATEGORY FOUR", CategoryData); + ASSERT_EQ("en", CategoryLanguage); + + CategoryData.clear(); + CategoryLanguage.clear(); + + // Get the third CATEGORIES. + + std::string CategoryTokens; + + if (TestJournal.CategoriesList.size() > 2){ + + CategoryData = TestJournal.CategoriesList[2]; + + } + + if (TestJournal.CategoriesList.size() > 2){ + + CategoryLanguage = TestJournal.CategoriesListLanguage[2]; + + } + + if (TestJournal.CategoriesList.size() > 2){ + + CategoryTokens = TestJournal.CategoriesListTokens[2]; + + } + + ASSERT_EQ("CATEGORY FIVE, CATEGORY SIX, CATEGORY SEVEN", CategoryData); + ASSERT_EQ("en-GB", CategoryLanguage); + ASSERT_EQ("SAMPLE=TOKEN", CategoryTokens); + + // Get the first COMMENT. + + std::string CommentData; + + if (TestJournal.CommentList.begin() != TestJournal.CommentList.end()){ + + CommentData = TestJournal.CommentList[0]; + + } + + ASSERT_EQ("This is the first comment.", CommentData); + + // Get the second COMMENT. + + CommentData.clear(); + + std::string CommentDataAltRep; + std::string CommentDataLanguage; + + if (TestJournal.CommentList.size() > 1){ + + CommentData = TestJournal.CommentList[1]; + + } + + if (TestJournal.CommentList.size() > 1){ + + CommentDataAltRep = TestJournal.CommentListAltRep[1]; + + } + + if (TestJournal.CommentList.size() > 1){ + + CommentDataLanguage = TestJournal.CommentListLanguage[1]; + + } + + ASSERT_EQ("This is the second comment.", CommentData); + ASSERT_EQ("null:nodata", CommentDataAltRep); + ASSERT_EQ("en", CommentDataLanguage); + + // Get the third COMMENT. + + CommentData.clear(); + + std::string CommentDataTokens; + + if (TestJournal.CommentList.size() > 2){ + + CommentData = TestJournal.CommentList[2]; + + } + + if (TestJournal.CommentList.size() > 2){ + + CommentDataTokens = TestJournal.CommentListTokens[2]; + + } + + ASSERT_EQ("This is the third comment.", CommentData); + ASSERT_EQ("ZEBRAS=YES", CommentDataTokens); + + // Get the first CONTACT. + + std::string ContactData; + + if (TestJournal.ContactList.begin() != TestJournal.ContactList.end()){ + + ContactData = TestJournal.ContactList[0]; + + } + + ASSERT_EQ("First Contact", ContactData); + + // Get the second CONTACT. + + ContactData.clear(); + + std::string ContactDataAltRep; + std::string ContactDataLanguage; + + if (TestJournal.ContactList.size() > 1){ + + ContactData = TestJournal.ContactList[1]; + + } + + if (TestJournal.ContactList.size() > 1){ + + ContactDataAltRep = TestJournal.ContactListAltRep[1]; + + } + + if (TestJournal.ContactList.size() > 1){ + + ContactDataLanguage = TestJournal.ContactListLanguage[1]; + + } + + ASSERT_EQ("Second Contact", ContactData); + ASSERT_EQ("null:nodata", ContactDataAltRep); + ASSERT_EQ("en-GB", ContactDataLanguage); + + // Get the third CONTACT. + + ContactData.clear(); + + std::string ContactDataTokens; + + if (TestJournal.ContactList.size() > 2){ + + ContactData = TestJournal.ContactList[2]; + + } + + if (TestJournal.ContactList.size() > 2){ + + ContactDataTokens = TestJournal.ContactListTokens[2]; + + } + + ASSERT_EQ("Third Contact", ContactData); + ASSERT_EQ("ZEBRAS=NO", ContactDataTokens); + + // Get the first DESCRIPTION. + + std::string DescriptionData; + + if (TestJournal.DescriptionList.begin() != TestJournal.DescriptionList.end()){ + + DescriptionData = TestJournal.DescriptionList[0]; + + } + + ASSERT_EQ("First Journal Entry Description", DescriptionData); + + // Get the second DESCRIPTION. + + DescriptionData.clear(); + + std::string DescriptionAltRep; + std::string DescriptionLanguage; + + if (TestJournal.DescriptionList.size() > 1){ + + DescriptionData = TestJournal.DescriptionList[1]; + + } + + if (TestJournal.DescriptionList.size() > 1){ + + DescriptionAltRep = TestJournal.DescriptionListAltRep[1]; + + } + + if (TestJournal.DescriptionList.size() > 1){ + + DescriptionLanguage = TestJournal.DescriptionListLanguage[1]; + + } + + ASSERT_EQ("This is the second journal description.", DescriptionData); + ASSERT_EQ("null:nodata", DescriptionAltRep); + ASSERT_EQ("en-GB", DescriptionLanguage); + + // Get the third DESCRIPTION. + + DescriptionData.clear(); + + std::string DescriptionDataTokens; + + if (TestJournal.DescriptionList.size() > 2){ + + DescriptionData = TestJournal.DescriptionList[2]; + + } + + if (TestJournal.DescriptionList.size() > 2){ + + DescriptionDataTokens = TestJournal.DescriptionListTokens[2]; + + } + + ASSERT_EQ("This is the third journal description.", DescriptionData); + ASSERT_EQ("ZEBRAS=NO", DescriptionDataTokens); + + // Get the first EXDATE. + + std::string ExcludeDate; + + if (TestJournal.ExcludeDateData.begin() != TestJournal.ExcludeDateData.end()){ + + ExcludeDate = TestJournal.ExcludeDateData[0]; + + } + + ASSERT_EQ("20160125T120000Z", ExcludeDate); + + // Get the second EXDATE. + + ExcludeDate.clear(); + + std::string ExcludeDataTimeZoneParam; + std::string ExcludeDataValue; + + if (TestJournal.ContactList.size() > 1){ + + ExcludeDate = TestJournal.ExcludeDateData[1]; + + } + + if (TestJournal.ContactList.size() > 1){ + + ExcludeDataTimeZoneParam = TestJournal.ExcludeDateDataTimeZoneParam[1]; + + } + + if (TestJournal.ContactList.size() > 1){ + + ExcludeDataValue = TestJournal.ExcludeDateDataValue[1]; + + } + + ASSERT_EQ("20160125T130000Z", ExcludeDate); + ASSERT_EQ("DATE-TIME", ExcludeDataValue); + ASSERT_EQ("Europe/Truro", ExcludeDataTimeZoneParam); + + // Get the third EXDATE. + + ExcludeDate.clear(); + + std::string ExcludeDataTokens; + + if (TestJournal.ContactList.size() > 2){ + + ExcludeDate = TestJournal.ExcludeDateData[2]; + + } + + if (TestJournal.ContactList.size() > 2){ + + ExcludeDataTokens = TestJournal.ExcludeDateDataTokens[2]; + + } + + ASSERT_EQ("20160125T133000Z", ExcludeDate); + ASSERT_EQ("ZOOP=ZIPPO", ExcludeDataTokens); + + // Get the first RELATED-TO. + + std::string RelatedTo; + + if (TestJournal.RelatedToData.begin() != TestJournal.RelatedToData.end()){ + + RelatedTo = TestJournal.RelatedToData[0]; + + } + + ASSERT_EQ("person.1@example.com", RelatedTo); + + // Get the second RELATED-TO. + + RelatedTo.clear(); + + std::string RelatedToType; + + if (TestJournal.RelatedToData.size() > 1){ + + RelatedTo = TestJournal.RelatedToData[1]; + + } + + if (TestJournal.RelatedToData.size() > 1){ + + RelatedToType = TestJournal.RelatedToDataRelationType[1]; + + } + + ASSERT_EQ("person.2@example.com", RelatedTo); + ASSERT_EQ("PARENT", RelatedToType); + + // Get the third RELATED-TO. + + RelatedTo.clear(); + + std::string RelatedToTokens; + + if (TestJournal.RelatedToData.size() > 2){ + + RelatedTo = TestJournal.RelatedToData[2]; + + } + + if (TestJournal.RelatedToData.size() > 2){ + + RelatedToTokens = TestJournal.RelatedToDataTokens[2]; + + } + + ASSERT_EQ("person.3@example.com", RelatedTo); + ASSERT_EQ("SCHOOL=MEETING", RelatedToTokens); + } \ No newline at end of file