TEST(iCalendarJournal, BasicTests){
- CalendarJournalObject TestEvent;
+ CalendarJournalObject TestJournal;
- ASSERT_EQ(CALENDAROBJECTLOAD_MISSING, TestEvent.LoadFile("iCalendarJournal-Missing.vcf"));
- ASSERT_EQ(CALENDAROBJECTLOAD_CANNOTOPEN, TestEvent.LoadFile("iCalendarJournal-InvalidPermissions.vcf"));
- ASSERT_EQ(CALENDAROBJECTLOAD_OK, TestEvent.LoadFile("iCalendarJournal-Load1.vcf"));
+ ASSERT_EQ(CALENDAROBJECTLOAD_MISSING, TestJournal.LoadFile("iCalendarJournal-Missing.vcf"));
+ ASSERT_EQ(CALENDAROBJECTLOAD_CANNOTOPEN, TestJournal.LoadFile("iCalendarJournal-InvalidPermissions.vcf"));
+ ASSERT_EQ(CALENDAROBJECTLOAD_OK, TestJournal.LoadFile("iCalendarJournal-Load1.vcf"));
+
+}
+
+TEST(iCalendarJournal, ObjectDataTests){
+
+ CalendarJournalObject TestJournal;
+ ASSERT_EQ(CALENDAROBJECTLOAD_OK, TestJournal.LoadFile("iCalendarJournal-Load2.vcf"));
+ ASSERT_EQ(CALENDAROBJECTVALID_OK, TestJournal.ValidBaseObject());
+
+ // Tests for DTSTAMP.
+
+ ASSERT_EQ("20160131T141500Z", TestJournal.DateTimeStampData);
+ ASSERT_EQ("OTHER=PARAM", TestJournal.DateTimeStampTokens);
+
+ // Tests for UID.
+
+ ASSERT_EQ("b3a16392-ad86-4061-be53-c215af2306c1", TestJournal.UniqueID);
+ ASSERT_EQ("UNIQUEPARAM=CERTAINLY;OKAY=MAYBENOT", TestJournal.UniqueIDTokens);
+
+ // Tests for CLASS.
+
+ ASSERT_EQ("PUBLIC", TestJournal.ClassData);
+ ASSERT_EQ("CHOCOLATE=BAR", TestJournal.ClassDataTokens);
+
+ // Tests for DTSTART.
+
+ ASSERT_EQ("20160131T143500Z", TestJournal.DateTimeStartData);
+ ASSERT_EQ("DATE-TIME", TestJournal.DateTimeStartDataValue);
+ ASSERT_EQ("Europe/Truro", TestJournal.DateTimeStartDataTimeZoneID);
+ ASSERT_EQ("PARAMONE=YES;PARAMTWO=NO", TestJournal.DateTimeStartDataTokens);
+
+ // Tests for LAST-MODIFIED.
+
+ ASSERT_EQ("20160131T143700Z", TestJournal.LastModifiedData);
+ ASSERT_EQ("FUTURE=YES", TestJournal.LastModifiedTokens);
+
+ // Tests for ORGANIZER.
+
+ ASSERT_EQ("mailto:organiser@example.com", TestJournal.OrganiserData);
+ ASSERT_EQ("ExampleOrganiser", TestJournal.OrganiserDataCommonName);
+ ASSERT_EQ("null:nodata", TestJournal.OrganiserDataDirectoryEntry);
+ ASSERT_EQ("mailto:organiser.noreply@example.com", TestJournal.OrganiserDataSentByParam);
+ ASSERT_EQ("kw", TestJournal.OrganiserDataLanguage);
+ ASSERT_EQ("HAPPY=DAYS", TestJournal.OrganiserDataTokens);
+
+ // Tests for RECURRENCE-ID.
+
+ ASSERT_EQ("20160131", TestJournal.RecurranceIDData);
+ ASSERT_EQ("Europe/Truro", TestJournal.RecurranceIDDataTimeZoneParam);
+ ASSERT_EQ("THISANDFUTURE", TestJournal.RecurranceIDDataRangeParam);
+ ASSERT_EQ("DATE", TestJournal.RecurranceIDDataValue);
+ ASSERT_EQ("EXAMPLE=DATA", TestJournal.RecurranceIDDataTokens);
+
+ // Tests for SEQUENCE.
+
+ ASSERT_EQ(7, TestJournal.SequenceData);
+ ASSERT_EQ("TEST=YAY", TestJournal.SequenceTokens);
+
+ // Tests for STATUS.
+
+ ASSERT_EQ("2.0;Success", TestJournal.StatusData);
+ ASSERT_EQ("kw", TestJournal.StatusLanguage);
+ ASSERT_EQ("FAVOURITE=RICHTEA;NOTLIKE=UNKNOWN", TestJournal.StatusTokens);
+
+ // Tests for SUMMARY.
+
+ ASSERT_EQ("A summary of the journal entry.", TestJournal.SummaryData);
+ ASSERT_EQ("null:nodata", TestJournal.SummaryDataAltRep);
+ ASSERT_EQ("kw", TestJournal.SummaryDataLanguage);
+ ASSERT_EQ("FAVOURITE=TOFU;NOTLIKE=NONE", TestJournal.SummaryDataTokens);
+
+ // Tests for URL.
+
+ 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);
+
+ // Get the first RDATE.
+
+ std::string RecurrenceDate;
+
+ if (TestJournal.RecurranceDateData.begin() != TestJournal.RecurranceDateData.end()){
+
+ RecurrenceDate = TestJournal.RecurranceDateData[0];
+
+ }
+
+ ASSERT_EQ("20160120", RecurrenceDate);
+
+ // Get the second RDATE.
+
+ RecurrenceDate.clear();
+
+ std::string RecurrenceDateTimeZoneParam;
+ std::string RecurrenceDateValue;
+
+ if (TestJournal.RecurranceDateData.size() > 1){
+
+ RecurrenceDate = TestJournal.RecurranceDateData[1];
+
+ }
+
+ if (TestJournal.RecurranceDateData.size() > 1){
+
+ RecurrenceDateTimeZoneParam = TestJournal.RecurranceDateDataTimeZoneParam[1];
+
+ }
+
+ if (TestJournal.RecurranceDateData.size() > 1){
+
+ RecurrenceDateValue = TestJournal.RecurranceDateDataValue[1];
+
+ }
+
+ ASSERT_EQ("20160121", RecurrenceDate);
+ ASSERT_EQ("DATE", RecurrenceDateValue);
+ ASSERT_EQ("Europe/Truro", RecurrenceDateTimeZoneParam);
+
+ // Get the third RDATE.
+
+ RecurrenceDate.clear();
+
+ std::string RecurrenceTokens;
+
+ if (TestJournal.RecurranceDateData.size() > 2){
+
+ RecurrenceDate = TestJournal.RecurranceDateData[2];
+
+ }
+
+ if (TestJournal.RecurranceDateData.size() > 2){
+
+ RecurrenceTokens = TestJournal.RecurranceDateDataTokens[2];
+
+ }
+
+ ASSERT_EQ("20160520", RecurrenceDate);
+ ASSERT_EQ("ZILCH=DATA", RecurrenceTokens);
+
+ // Get the first REQUEST-STATUS.
+
+ std::string RequestStatus;
+
+ if (TestJournal.RequestStatusData.begin() != TestJournal.RequestStatusData.end()){
+
+ RequestStatus = TestJournal.RequestStatusData[0];
+
+ }
+
+ ASSERT_EQ("2.0;Success", RequestStatus);
+
+ // Get the second REQUEST-STATUS.
+
+ RequestStatus.clear();
+
+ std::string RequestLanguage;
+
+ if (TestJournal.ContactList.size() > 1){
+
+ RequestStatus = TestJournal.RequestStatusData[1];
+
+ }
+
+ if (TestJournal.ContactList.size() > 1){
+
+ RequestLanguage = TestJournal.RequestStatusLanguage[1];
+
+ }
+
+ ASSERT_EQ("3.42;Really big irrecoverable error caused by the user", RequestStatus);
+ ASSERT_EQ("en", RequestLanguage);
+
+ // Get the third REQUEST-STATUS.
+
+ RequestStatus.clear();
+
+ std::string RequestTokens;
+
+ if (TestJournal.ContactList.size() > 2){
+
+ RequestStatus = TestJournal.RequestStatusData[2];
+
+ }
+
+ if (TestJournal.ContactList.size() > 2){
+
+ RequestTokens = TestJournal.RequestStatusTokens[2];
+
+ }
+
+ ASSERT_EQ("3.7;Invalid calendar user", RequestStatus);
+ ASSERT_EQ("USER=MISSING", RequestTokens);
}
\ No newline at end of file