X-Git-Url: http://Server1/repobrowser/?a=blobdiff_plain;f=source%2Ftests%2Fxestiacalendar_icalfreebusyload.h;h=f6704d4e36fdc704607be3db303675369a54954f;hb=eed216d18d39cf31d30c5dd247d5edceb03dceec;hp=ced22050ad59e28f2832d0f6b9790b2109ce53c8;hpb=942bbbdfb05151bb8499bdff472c9bb549c56934;p=xestiacalendar%2F.git diff --git a/source/tests/xestiacalendar_icalfreebusyload.h b/source/tests/xestiacalendar_icalfreebusyload.h index ced2205..f6704d4 100644 --- a/source/tests/xestiacalendar_icalfreebusyload.h +++ b/source/tests/xestiacalendar_icalfreebusyload.h @@ -295,4 +295,120 @@ TEST(iCalendarFreeBusy, ObjectDataTests){ ASSERT_EQ("This is the third comment.", CommentData); ASSERT_EQ("ZEBRAS=YES", CommentDataTokens); + // Get the first FREEBUSY. + + std::string FreeBusyData; + + if (TestFreeBusy.FreeBusyList.begin() != TestFreeBusy.FreeBusyList.end()){ + + FreeBusyData = TestFreeBusy.FreeBusyList[0]; + + } + + ASSERT_EQ("20160202T210000Z/PT1H", FreeBusyData); + + // Get the second FREEBUSY. + + FreeBusyData.clear(); + + std::string FreeBusyType; + + if (TestFreeBusy.FreeBusyList.size() > 1){ + + FreeBusyData = TestFreeBusy.FreeBusyList[1]; + + } + + if (TestFreeBusy.FreeBusyListType.size() > 1){ + + FreeBusyType = TestFreeBusy.FreeBusyListType[1]; + + } + + ASSERT_EQ("FREE", FreeBusyType); + ASSERT_EQ("20160202T220000Z/PT1H", FreeBusyData); + + // Get the third FREEBUSY. + + FreeBusyData.clear(); + FreeBusyType.clear(); + + std::string FreeBusyTokens; + + if (TestFreeBusy.FreeBusyList.size() > 2){ + + FreeBusyData = TestFreeBusy.FreeBusyList[2]; + + } + + if (TestFreeBusy.FreeBusyListType.size() > 2){ + + FreeBusyType = TestFreeBusy.FreeBusyListType[2]; + + } + + if (TestFreeBusy.FreeBusyListTokens.size() > 2){ + + FreeBusyTokens = TestFreeBusy.FreeBusyListTokens[2]; + + } + + ASSERT_EQ("BUSY-UNAVAILABLE", FreeBusyType); + ASSERT_EQ("20160202T230000Z/PT9H", FreeBusyData); + ASSERT_EQ("RESULT=ARGH;TEST=YES", FreeBusyTokens); + + // Get the first REQUEST-STATUS. + + std::string RequestStatus; + + if (TestFreeBusy.RequestStatusData.begin() != TestFreeBusy.RequestStatusData.end()){ + + RequestStatus = TestFreeBusy.RequestStatusData[0]; + + } + + ASSERT_EQ("2.0;Success", RequestStatus); + + // Get the second REQUEST-STATUS. + + RequestStatus.clear(); + + std::string RequestLanguage; + + if (TestFreeBusy.RequestStatusData.size() > 1){ + + RequestStatus = TestFreeBusy.RequestStatusData[1]; + + } + + if (TestFreeBusy.RequestStatusData.size() > 1){ + + RequestLanguage = TestFreeBusy.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 (TestFreeBusy.RequestStatusData.size() > 2){ + + RequestStatus = TestFreeBusy.RequestStatusData[2]; + + } + + if (TestFreeBusy.RequestStatusData.size() > 2){ + + RequestTokens = TestFreeBusy.RequestStatusTokens[2]; + + } + + ASSERT_EQ("3.7;Invalid calendar user", RequestStatus); + ASSERT_EQ("USER=MISSING", RequestTokens); + } \ No newline at end of file