X-Git-Url: http://Server1/repobrowser/?a=blobdiff_plain;f=source%2Ftests%2Fxestiacalendar_icaltaskload.h;h=c23779b943b860ed385d967ce3419f0606ccb7a8;hb=74b883756ce2aca0f8c566a2e8d93b3ae9ad3209;hp=8f5c586d5d7a0a0b51e79285d45387231835a082;hpb=3792eb3e835462df41a4cec845a9d99428978ddf;p=xestiacalendar%2F.git diff --git a/source/tests/xestiacalendar_icaltaskload.h b/source/tests/xestiacalendar_icaltaskload.h index 8f5c586..c23779b 100644 --- a/source/tests/xestiacalendar_icaltaskload.h +++ b/source/tests/xestiacalendar_icaltaskload.h @@ -156,4 +156,119 @@ TEST(iCalendarTask, ObjectDataTests){ 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); + } \ No newline at end of file