X-Git-Url: http://Server1/repobrowser/?a=blobdiff_plain;f=source%2Ftests%2Fxestiacalendar_icaljournalload.h;h=f102a6165c6f746a66da909b2948350e4cdaeca6;hb=0b32cbf57b00c44fc88b137b5aa6b1d6c5be258b;hp=04a3a790c6b566d83c113cf17580e7e286145534;hpb=3e63b1063bb4e62544be5a8e8c5c5fc3f400cf98;p=xestiacalendar%2F.git diff --git a/source/tests/xestiacalendar_icaljournalload.h b/source/tests/xestiacalendar_icaljournalload.h index 04a3a79..f102a61 100644 --- a/source/tests/xestiacalendar_icaljournalload.h +++ b/source/tests/xestiacalendar_icaljournalload.h @@ -61,4 +61,138 @@ TEST(iCalendarJournal, ObjectDataTests){ 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); + } \ No newline at end of file