X-Git-Url: http://Server1/repobrowser/?p=xestiaab%2F.git;a=blobdiff_plain;f=source%2Ftests%2Fxestiaab_contactload.h;h=9239d5e96395e8af73fcb16b1bce370ae80fcfd2;hp=6894fa4cbe1007364eb9cddf55e23f2754e73427;hb=134b7476fefe9440a5120b15e3d913afc9c48f04;hpb=cb3074846231b7bee072eac2edd9ee3280711124 diff --git a/source/tests/xestiaab_contactload.h b/source/tests/xestiaab_contactload.h index 6894fa4..9239d5e 100644 --- a/source/tests/xestiaab_contactload.h +++ b/source/tests/xestiaab_contactload.h @@ -1,6 +1,6 @@ // xestiaab_contactload.h - Xestia Address Book Contact Load Unit Tests. // -// (c) 2012-2015 Xestia Software Development. +// (c) 2012-2017 Xestia Software Development. // // This file is part of Xestia Address Book. // @@ -17,290 +17,655 @@ // with Xestia Address Book. If not, see #include -#include "../contacteditor/ContactDataObject.h" +#include "../contacteditor/cdo/ContactDataObject.h" -TEST(ContactLoad, ContactLoadTests){ +TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithMissingFileThenReturnFileMissingError) +{ - ContactDataObject TestFile; + // Given - // Check that the file given is not missing. - - ASSERT_EQ(CONTACTLOAD_FILEMISSING, TestFile.LoadFile("MissingFile.vcf")); + ContactDataObject testFile; - // Check that the file given does not have an error when attempting to - // open it. + // When + + ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL; + testFile.LoadFile("MissingFile.vcf"); - ASSERT_EQ(CONTACTLOAD_FILEERROR, TestFile.LoadFile("InvalidPermissions.vcf")); + // Then + + ASSERT_EQ(CONTACTLOAD_FILEMISSING, testFileLoadStatus); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithInvalidPermissionsSetThenReturnInvalidPermissionsError) +{ + + // Given - // Check that the file is a valid vCard 4.0 file. + ContactDataObject testFile; - ASSERT_EQ(CONTACTLOAD_FILEINVALIDFORMAT, TestFile.LoadFile("LoadCheck-Load1-v3.vcf")); + // When - // Check that the vCard 4.0 file meets the base specification. + ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL; + testFileLoadStatus = testFile.LoadFile("InvalidPermissions.vcf"); - ASSERT_EQ(CONTACTLOAD_FILEBASESPECFAIL, TestFile.LoadFile("LoadCheck-Load3.vcf")); + // Then - // Check that the vCard 4.0 file loads OK. + ASSERT_EQ(CONTACTLOAD_FILEERROR, testFileLoadStatus); - ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); - - // Check that the kind status has been set. (KIND). +} + +TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithInvalidFormatThenReturnInvalidFormatError) +{ + + // Given - ASSERT_NE(CONTACTKIND_NONE, TestFile.ContactKind); - ASSERT_EQ(CONTACTKIND_INDIVIDUAL, TestFile.ContactKind); + ContactDataObject testFile; - // Check that the groups have been read (MEMBER). + // When + + ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL; + testFileLoadStatus = testFile.LoadFile("LoadCheck-Load1-v3.vcf"); - std::map::iterator TestFileIter; - std::map::iterator TestFileIntIter; + // Then + + ASSERT_EQ(CONTACTLOAD_FILEINVALIDFORMAT, testFileLoadStatus); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithNonMeetingBaseSpecificationThenReturnFileBaseSpecificationError) +{ + + // Given + + ContactDataObject testFile; - TestFileIter = TestFile.GroupsList.find(0); + // When - ASSERT_NE(TestFile.GroupsList.end(), TestFileIter); - ASSERT_EQ("7a2af44d-6431-4797-a55f-d86d56304fda", TestFileIter->second); + ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL; + testFileLoadStatus = testFile.LoadFile("LoadCheck-Load3.vcf"); - // Check the ALTID parameter. + // Then - TestFileIter = TestFile.GroupsListAltID.find(0); - ASSERT_NE(TestFile.GroupsListAltID.end(), TestFileIter); - ASSERT_EQ("35", TestFileIter->second); + ASSERT_EQ(CONTACTLOAD_FILEBASESPECFAIL, testFileLoadStatus); - // Check the PID parameter. +} + +TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledThenContactLoadedOK) +{ + + // Given + + ContactDataObject testFile; - TestFileIter = TestFile.GroupsListPID.find(0); - ASSERT_NE(TestFile.GroupsListPID.end(), TestFileIter); - ASSERT_EQ("40", TestFileIter->second); + // When + + ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL; + testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); - // Check the PREF parameter. + // Then + + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); + +} + +TEST(ContactLoad, GivenLoadedContactDataObjectWhenContactKindIsCheckedThenContactKindIsIndividual) +{ + + // Check that the kind status has been set. (KIND). + + // Given - TestFileIntIter = TestFile.GroupsListPref.find(0); - ASSERT_NE(TestFile.GroupsListPref.end(), TestFileIntIter); - ASSERT_EQ(45, TestFileIntIter->second); + ContactDataObject testFile; + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); + + // When - // Check the MEDIATYPE parameter. + ContactKindType testFileContactKindStatus = TestFile.ContactKind; - TestFileIter = TestFile.GroupsListMediaType.find(0); - ASSERT_NE(TestFile.GroupsListMediaType.end(), TestFileIter); - ASSERT_EQ("text/plain", TestFileIter->second); + // Then + // Check that the kind status has been set. (KIND). - // Check the extra tokens parameter. + ASSERT_NE(CONTACTKIND_NONE, testFileContactKindStatus); + ASSERT_EQ(CONTACTKIND_INDIVIDUAL, testFileContactKindStatus); - TestFileIter = TestFile.GroupsListTokens.find(0); - ASSERT_NE(TestFile.GroupsListTokens.end(), TestFileIter); - ASSERT_EQ("EXAMPLE=Meep", TestFileIter->second); +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListForFirstGroupThenOnlyFirstGroupIsReturned) +{ + + // Check that the groups have been read (MEMBER). + + std::map::iterator testFileIter; + + // Given + + ContactDataObject testFile; + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Check that the formatted name has been read (FN). + // When + + testFileIter = testFile.GroupsList.find(0); - TestFileIter = TestFile.FullNamesList.find(0); - ASSERT_NE(TestFile.FullNamesList.end(), TestFileIter); - ASSERT_EQ("Test Contact", TestFileIter->second); + // Then - // Check the TYPE parameter. + ASSERT_NE(testFile.GroupsList.end(), testFileIter); + ASSERT_EQ("7a2af44d-6431-4797-a55f-d86d56304fda", testFileIter->second); - TestFileIter = TestFile.FullNamesListType.find(0); - ASSERT_NE(TestFile.FullNamesListType.end(), TestFileIter); - ASSERT_EQ("work", TestFileIter->second); +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListAltIDForFirstGroupThenOnlyFirstGroupAltIDIsReturned) +{ + + // Check the ALTID parameter for MEMBER. + + std::map::iterator testFileIter; + + // Given - // Check the LANGUAGE parameter. + ContactDataObject testFile; + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - TestFileIter = TestFile.FullNamesListLanguage.find(0); - ASSERT_NE(TestFile.FullNamesListLanguage.end(), TestFileIter); - ASSERT_EQ("kw", TestFileIter->second); + // When - // Check the ALTID parameter. + testFileIter = testFile.GroupsListAltID.find(0); - TestFileIter = TestFile.FullNamesListAltID.find(0); - ASSERT_NE(TestFile.FullNamesListAltID.end(), TestFileIter); - ASSERT_EQ("500", TestFileIter->second); + // Then - // Check the PID parameter. + ASSERT_NE(testFile.GroupsListAltID.end(), testFileIter); + ASSERT_EQ("35", testFileIter->second); - TestFileIter = TestFile.FullNamesListPID.find(0); - ASSERT_NE(TestFile.FullNamesListPID.end(), TestFileIter); - ASSERT_EQ("40", TestFileIter->second); +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListPIDForFirstGroupThenOnlyFirstGroupPIDIsReturned) +{ + + // Check the PID parameter for MEMBER. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + + // Given - // Check the PREF parameter. + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - TestFileIntIter = TestFile.FullNamesListPref.find(0); - ASSERT_NE(TestFile.FullNamesListPref.end(), TestFileIntIter); - ASSERT_EQ(45, TestFileIntIter->second); + // When + + testFileIter = testFile.GroupsListPID.find(0); - // Check for the extra tokens parameter. + // Then + + ASSERT_NE(testFile.GroupsListPID.end(), testFileIter); + ASSERT_EQ("40", testFileIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListPreferenceForFirstGroupThenOnlyFirstGroupPreferenceIsReturned) +{ + + // Check the PREF parameter for MEMBER. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - TestFileIter = TestFile.FullNamesListTokens.find(0); - ASSERT_NE(TestFile.FullNamesListTokens.end(), TestFileIter); - ASSERT_EQ("EXAMPLE=Baaa", TestFileIter->second); + // When + + testFileIntIter = testFile.GroupsListPref.find(0); - // Check that the name has been read (N). + // Then + + ASSERT_NE(testFile.GroupsListPref.end(), testFileIntIter); + ASSERT_EQ(45, testFileIntIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListMediatypeForFirstGroupThenOnlyFirstGroupMediatypeIsReturned) +{ + + // Check the MEDIATYPE parameter for MEMBER. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - ASSERT_EQ("Contact", TestFile.NameSurname); - ASSERT_EQ("Test", TestFile.NameForename); - ASSERT_EQ("Example", TestFile.NameOtherNames); - ASSERT_EQ("Robot", TestFile.NameTitle); - ASSERT_EQ("LOONY", TestFile.NameSuffix); + // When - // Check the ALTID parameter. + testFileIter = testFile.GroupsListMediaType.find(0); - ASSERT_EQ("3", TestFile.NameAltID); + // Then + + ASSERT_NE(testFile.GroupsListMediaType.end(), testFileIter); + ASSERT_EQ("text/plain", testFileIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListExtraTokensForFirstGroupThenOnlyFirstGroupExtraTokensIsReturned) +{ + + // Check the extra tokens parameter for MEMBER. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Check the LANGUAGE parameter. + // When - ASSERT_EQ("kw", TestFile.NameLanguage); + TestFileIter = testFile.GroupsListTokens.find(0); - // Check the SORT-AS parameter. - - ASSERT_EQ("Contact,Test", TestFile.NameDisplayAs); + // Then - // Check the extra tokens parameter. - - ASSERT_EQ("TEST=Yes", TestFile.NameTokens); + ASSERT_NE(testFile.GroupsListTokens.end(), testFileIter); + ASSERT_EQ("EXAMPLE=Meep", testFileIter->second); } -TEST(ContactLoad, NicknameTests){ - - ContactDataObject TestFile; +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameForFirstFullNameThenOnlyFirstFullNameIsReturned) +{ - // Check that the vCard 4.0 file loads OK. + // Check that the formatted name has been read (FN). - ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; - std::map::iterator TestFileIter; - std::map::iterator TestFileIntIter; + // Given - // Check that the nickname has been read (NICKNAME). General. + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - TestFileIter = TestFile.GeneralNicknamesList.find(0); - ASSERT_NE(TestFile.GeneralNicknamesList.end(), TestFileIter); - ASSERT_EQ("Tester", TestFileIter->second); + // When - // Check the ALTID parameter. + testFileIter = testFile.FullNamesList.find(0); + + // Then + + ASSERT_NE(testFile.FullNamesList.end(), testFileIter); + ASSERT_EQ("Test Contact", testFileIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameTypeForFirstFullNameThenOnlyFirstFullNameTypeIsReturned) +{ + + // Check the TYPE parameter for FN. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); + + // When + + testFileIter = testFile.FullNamesListType.find(0); + + // Then + + ASSERT_NE(testFile.FullNamesListType.end(), testFileIter); + ASSERT_EQ("work", testFileIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameLanguageForFirstFullNameThenOnlyFirstFullNameLanguageIsReturned) +{ + + // Check the LANGUAGE parameter for FN. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - TestFileIter = TestFile.GeneralNicknamesListAltID.find(0); - ASSERT_NE(TestFile.GeneralNicknamesListAltID.end(), TestFileIter); - ASSERT_EQ("35", TestFileIter->second); + // When + + testFileIter = testFile.FullNamesListLanguage.find(0); + + // Then + + ASSERT_NE(testFile.FullNamesListLanguage.end(), testFileIter); + ASSERT_EQ("kw", testFileIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameAltIDForFirstFullNameThenOnlyFirstFullNameAltIDIsReturned) +{ + + // Check the ALTID parameter for FN. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Check the PID parameter. + // When - TestFileIter = TestFile.GeneralNicknamesListPID.find(0); - ASSERT_NE(TestFile.GeneralNicknamesListPID.end(), TestFileIter); - ASSERT_EQ("50", TestFileIter->second); + testFileIter = testFile.FullNamesListAltID.find(0); + + // Then - // Check the PREF parameter. + ASSERT_NE(testFile.FullNamesListAltID.end(), testFileIter); + ASSERT_EQ("500", testFileIter->second); - TestFileIntIter = TestFile.GeneralNicknamesListPref.find(0); - ASSERT_NE(TestFile.GeneralNicknamesListPref.end(), TestFileIntIter); - ASSERT_EQ(40, TestFileIntIter->second); +} - // Check the LANGUAGE parameter. +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNamePIDForFirstFullNameThenOnlyFirstFullNamePIDIsReturned) +{ - TestFileIter = TestFile.GeneralNicknamesListLanguage.find(0); - ASSERT_NE(TestFile.GeneralNicknamesListLanguage.end(), TestFileIter); - ASSERT_EQ("kw", TestFileIter->second); + // Check the PID parameter for FN. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Check the extra tokens parameter. + // When - TestFileIter = TestFile.GeneralNicknamesListTokens.find(0); - ASSERT_NE(TestFile.GeneralNicknamesListTokens.end(), TestFileIter); - ASSERT_EQ("YAY=Nope;Beep=Boop", TestFileIter->second); + testFileIter = testFile.FullNamesListPID.find(0); + + // Then + + ASSERT_NE(testFile.FullNamesListPID.end(), testFileIter); + ASSERT_EQ("40", testFileIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNamePrefForFirstFullNameThenOnlyFirstFullNamePrefIsReturned) +{ + + // Check the PREF parameter for FN. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Repeat for the home type. + // When + + testFileIntIter = testFile.FullNamesListPref.find(0); - TestFileIter = TestFile.HomeNicknamesList.find(1); - ASSERT_NE(TestFile.HomeNicknamesList.end(), TestFileIter); - ASSERT_EQ("Testy", TestFileIter->second); + // Then + + ASSERT_NE(testFile.FullNamesListPref.end(), testFileIntIter); + ASSERT_EQ(45, testFileIntIter->second); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameExtraTokensForFirstFullNameThenOnlyFirstFullNameExtraTokensIsReturned) +{ + + // Check for the extra tokens parameter for FN. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Check the ALTID parameter. + // When - TestFileIter = TestFile.HomeNicknamesListAltID.find(1); - ASSERT_NE(TestFile.HomeNicknamesListAltID.end(), TestFileIter); - ASSERT_EQ("17", TestFileIter->second); + testFileIter = testFile.FullNamesListTokens.find(0); - // Check the PID parameter. + // Then - TestFileIter = TestFile.HomeNicknamesListPID.find(1); - ASSERT_NE(TestFile.HomeNicknamesListPID.end(), TestFileIter); - ASSERT_EQ("39", TestFileIter->second); + ASSERT_NE(testFile.FullNamesListTokens.end(), testFileIter); + ASSERT_EQ("EXAMPLE=Baaa", testFileIter->second); - // Check the PREF parameter. +} - TestFileIntIter = TestFile.HomeNicknamesListPref.find(1); - ASSERT_NE(TestFile.HomeNicknamesListPref.end(), TestFileIntIter); - ASSERT_EQ(78, TestFileIntIter->second); +TEST(ContactLoad, GivenContactDataObjectWhenNameValuesAreRetrievedThenValuesForNameIsReturned) +{ - // Check the LANGUAGE parameter. + // Check that the name has been read for N. - TestFileIter = TestFile.HomeNicknamesListLanguage.find(1); - ASSERT_NE(TestFile.HomeNicknamesListLanguage.end(), TestFileIter); - ASSERT_EQ("en", TestFileIter->second); - - // Check the extra tokens parameter. - - TestFileIter = TestFile.HomeNicknamesListTokens.find(1); - ASSERT_NE(TestFile.HomeNicknamesListTokens.end(), TestFileIter); - ASSERT_EQ("YAY=Yep;Beep=Boop", TestFileIter->second); + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Repeat for the work type. + // When - TestFileIter = TestFile.BusinessNicknamesList.find(2); - ASSERT_NE(TestFile.BusinessNicknamesList.end(), TestFileIter); - ASSERT_EQ("The Testing One", TestFileIter->second); + wxString nameSurname = testFile.NameSurname; + wxString nameForename = testFile.NameForename; + wxString nameOtherNames = testFile.NameOtherNames; + wxString nameTitle = testFile.NameTitle; + wxString nameSuffix = testFile.NameSuffix; - // Check the ALTID parameter. + // Then - TestFileIter = TestFile.BusinessNicknamesListAltID.find(2); - ASSERT_NE(TestFile.BusinessNicknamesListAltID.end(), TestFileIter); - ASSERT_EQ("99", TestFileIter->second); + ASSERT_EQ("Contact", nameSurname); + ASSERT_EQ("Test", nameForename); + ASSERT_EQ("Example", nameOtherNames); + ASSERT_EQ("Robot", nameTitle); + ASSERT_EQ("LOONY", nameSuffix); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenNameAltIDIsRetrievedThenValueforNameAltIDIsReturned) +{ + + // Check the ALTID parameter for N. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Check the PID parameter. + // When + + wxString nameAltID = TestFile.NameAltID; - TestFileIter = TestFile.BusinessNicknamesListPID.find(2); - ASSERT_NE(TestFile.BusinessNicknamesListPID.end(), TestFileIter); - ASSERT_EQ("10", TestFileIter->second); + // Then - // Check the PREF parameter. + ASSERT_EQ("3", nameAltID); - TestFileIntIter = TestFile.BusinessNicknamesListPref.find(2); - ASSERT_NE(TestFile.BusinessNicknamesListPref.end(), TestFileIntIter); - ASSERT_EQ(1, TestFileIntIter->second); +} - // Check the LANGUAGE parameter. +TEST(ContactLoad, GivenContactDataObjectWhenNameAltIDIsRetrievedThenValueforNameAltIDIsReturned) +{ - TestFileIter = TestFile.BusinessNicknamesListLanguage.find(2); - ASSERT_NE(TestFile.BusinessNicknamesListLanguage.end(), TestFileIter); - ASSERT_EQ("en-GB", TestFileIter->second); + // Check the LANGUAGE parameter for N. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); - // Check the extra tokens parameter. + // When - TestFileIter = TestFile.BusinessNicknamesListTokens.find(2); - ASSERT_NE(TestFile.BusinessNicknamesListTokens.end(), TestFileIter); - ASSERT_EQ("YAY=Maybe;Boop=Boing", TestFileIter->second); + wxString nameLanguage = TestFile.NameLanguage; + + // Then + + ASSERT_EQ("kw", nameLanguage); } -TEST(ContactLoad, GenderTests){ +TEST(ContactLoad, GivenContactDataObjectWhenNameDisplayAsIsRetrievedThenValueforNameDisplayAsIsReturned) +{ - // Check that the gender has been read. + // Check the SORT-AS parameter for N. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); + + // When + + wxString nameDisplayAs = TestFile.NameDisplayAs; + + // Then + + ASSERT_EQ("Contact,Test", nameDisplayAs); + +} + +TEST(ContactLoad, GivenContactDataObjectWhenNameExtraTokensIsRetrievedThenValueforNameExtraTokensIsReturned) +{ + + // Check the extra tokens parameter for N. + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); + + // When + + wxString nameTokens = testFile.NameTokens; + + // Then + + ASSERT_EQ("TEST=Yes", nameTokens); + +} + +/* TEMPLATE: PLEASE COPY BEFORE USING IT. */ + +TEST(ContactLoad, GivenWhenThen) +{ + + std::map::iterator testFileIter; + std::map::iterator testFileIntIter; + ContactDataObject testFile; + + // Given + + ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); + + // When + + // Then + +} + +/* END OF TEMPLATE: LOOK UP */ + +TEST(ContactLoad, UIDTest){ ContactDataObject TestFile; // Check that the vCard 4.0 file loads OK. + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + ASSERT_EQ("903588-9082374-989120310-AAFECDBCDF", TestFile.UIDToken); + +} + +TEST(ContactLoad, ClientPIDMapTests){ + + ContactDataObject TestFile; + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); std::map::iterator TestFileIter; - std::map::iterator TestFileIntIter; + + // Test the first Client PID Map. + + TestFileIter = TestFile.ClientPIDList.find(0); + ASSERT_NE(TestFile.ClientPIDList.end(), TestFileIter); + ASSERT_EQ("1;urn;uuid:aaaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa", TestFileIter->second); + + TestFileIter = TestFile.ClientPIDListTokens.find(0); + ASSERT_EQ(TestFile.ClientPIDListTokens.end(), TestFileIter); + + // Test the second Client PID Map. + + TestFileIter = TestFile.ClientPIDList.find(1); + ASSERT_NE(TestFile.ClientPIDList.end(), TestFileIter); + ASSERT_EQ("2;urn;uuid:ccccccccc-cccc-cccc-cccc-cccccccccccc", TestFileIter->second); + + TestFileIter = TestFile.ClientPIDListTokens.find(1); + ASSERT_EQ(TestFile.ClientPIDListTokens.end(), TestFileIter); - ASSERT_NE("", TestFile.Gender); - ASSERT_EQ("F", TestFile.Gender); - ASSERT_EQ("Example Text", TestFile.GenderDetails); - ASSERT_EQ("BEEP=Boop", TestFile.GenderTokens); + // Test the third Client PID Map. + + TestFileIter = TestFile.ClientPIDListTokens.find(2); + ASSERT_NE(TestFile.ClientPIDListTokens.end(), TestFileIter); + ASSERT_EQ("MEEP=MOO;WOOP=WOO", TestFileIter->second); + + TestFileIter = TestFile.ClientPIDList.find(2); + ASSERT_NE(TestFile.ClientPIDList.end(), TestFileIter); + ASSERT_EQ("3;urn;uuid:bbbbbbbbb-bbbb-bbbb-bbbb-bbbbbbbbbbbb", TestFileIter->second); } -TEST(ContactLoad, BirthdayTests){ +TEST(ContactLoad, RevisionTests){ - // Check that the birthday has been read. + ContactDataObject TestFile; + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + ASSERT_EQ("20151227T033000Z", TestFile.Revision); + ASSERT_EQ("TEST=YES;DATA=NO;MORE=MAYBE", TestFile.RevisionTokens); + +} + +TEST(ContactLoad, SourceTests){ ContactDataObject TestFile; @@ -311,34 +676,134 @@ TEST(ContactLoad, BirthdayTests){ std::map::iterator TestFileIter; std::map::iterator TestFileIntIter; - ASSERT_NE("", TestFile.Birthday); - ASSERT_EQ("20040101", TestFile.Birthday); + // Start with a general source address. - // Check the ALTID parameter. + TestFileIter = TestFile.SourceList.find(0); + ASSERT_NE(TestFile.SourceList.end(), TestFileIter); + ASSERT_EQ("http://example.com/source/sourcea.vcf", TestFileIter->second); - ASSERT_EQ("35", TestFile.BirthdayAltID); + // Check the TYPE section. - // Check the CALSCALE parameter. + TestFileIter = TestFile.SourceListType.find(0); + ASSERT_EQ(TestFile.SourceListType.end(), TestFileIter); - ASSERT_EQ("georgian", TestFile.BirthdayCalScale); + // Check the ALTID section. - // Check the extra tokens parameter. + TestFileIter = TestFile.SourceListAltID.find(0); + ASSERT_NE(TestFile.SourceListAltID.end(), TestFileIter); + ASSERT_EQ("74", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.SourceListPID.find(0); + ASSERT_NE(TestFile.SourceListPID.end(), TestFileIter); + ASSERT_EQ("71", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.SourceListMediatype.find(0); + ASSERT_NE(TestFile.SourceListMediatype.end(), TestFileIter); + ASSERT_EQ("text/plain", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.SourceListPref.find(0); + ASSERT_NE(TestFile.SourceListPref.end(), TestFileIntIter); + ASSERT_EQ(72, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.SourceListTokens.find(0); + ASSERT_NE(TestFile.SourceListTokens.end(), TestFileIter); + ASSERT_EQ("STATUS=FEED", TestFileIter->second); + + // Start with the home source address. - ASSERT_EQ("HAPPY=Days", TestFile.BirthdayTokens); + TestFileIter = TestFile.SourceList.find(1); + ASSERT_NE(TestFile.SourceList.end(), TestFileIter); + ASSERT_EQ("http://example.com/source/sourceb.vcf", TestFileIter->second); - // Check the VALUE parameter. (Note have to use a different file - // due to the *1 rule in RFC6350. + // Check the TYPE section. - ContactDataObject TestFileValue; - ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4-BDayValue.vcf")); + TestFileIter = TestFile.SourceListType.find(1); + ASSERT_NE(TestFile.SourceListType.end(), TestFileIter); + ASSERT_EQ("home", TestFileIter->second); - ASSERT_EQ("Circa 2000s", TestFile.Birthday); + // Check the ALTID section. -} + TestFileIter = TestFile.SourceListAltID.find(1); + ASSERT_NE(TestFile.SourceListAltID.end(), TestFileIter); + ASSERT_EQ("84", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.SourceListPID.find(1); + ASSERT_NE(TestFile.SourceListPID.end(), TestFileIter); + ASSERT_EQ("81", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.SourceListMediatype.find(1); + ASSERT_NE(TestFile.SourceListMediatype.end(), TestFileIter); + ASSERT_EQ("text/plainpaper", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.SourceListPref.find(1); + ASSERT_NE(TestFile.SourceListPref.end(), TestFileIntIter); + ASSERT_EQ(82, TestFileIntIter->second); -TEST(ContactLoad, AnniversaryTests){ + // Check the extra tokens. + + TestFileIter = TestFile.SourceListTokens.find(1); + ASSERT_NE(TestFile.SourceListTokens.end(), TestFileIter); + ASSERT_EQ("STATUS=ONLINE", TestFileIter->second); - // Check that the anniversary has been read. + // Start with the home source address. + + TestFileIter = TestFile.SourceList.find(2); + ASSERT_NE(TestFile.SourceList.end(), TestFileIter); + ASSERT_EQ("http://example.com/source/sourcec.vcf", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.SourceListType.find(2); + ASSERT_NE(TestFile.SourceListType.end(), TestFileIter); + ASSERT_EQ("work", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.SourceListAltID.find(2); + ASSERT_NE(TestFile.SourceListAltID.end(), TestFileIter); + ASSERT_EQ("94", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.SourceListPID.find(2); + ASSERT_NE(TestFile.SourceListPID.end(), TestFileIter); + ASSERT_EQ("91", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.SourceListMediatype.find(2); + ASSERT_NE(TestFile.SourceListMediatype.end(), TestFileIter); + ASSERT_EQ("text/sandpaper", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.SourceListPref.find(2); + ASSERT_NE(TestFile.SourceListPref.end(), TestFileIntIter); + ASSERT_EQ(92, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.SourceListTokens.find(2); + ASSERT_NE(TestFile.SourceListTokens.end(), TestFileIter); + ASSERT_EQ("STATUS=OFFLINE", TestFileIter->second); + +} + +TEST(ContactLoad, XMLTest){ ContactDataObject TestFile; @@ -349,32 +814,28 @@ TEST(ContactLoad, AnniversaryTests){ std::map::iterator TestFileIter; std::map::iterator TestFileIntIter; - ASSERT_NE("", TestFile.Anniversary); - ASSERT_EQ("20200516", TestFile.Anniversary); - - // Check the ALTID parameter. - - ASSERT_EQ("70", TestFile.AnniversaryAltID); - - // Check the CALSCALE parameter. + // Start with the first XML property. - ASSERT_EQ("georgian", TestFile.AnniversaryCalScale); + // Start with a general source address. - // Check the extra tokens parameter. + TestFileIter = TestFile.XMLList.find(0); + ASSERT_NE(TestFile.XMLList.end(), TestFileIter); + ASSERT_EQ("Example Page 1", TestFileIter->second); - ASSERT_EQ("WONDERFUL=Day", TestFile.AnniversaryTokens); - - // Check the VALUE parameter. (Note have to use a different file - // due to the *1 rule in RFC6350. - - ContactDataObject TestFileValue; - ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4-BDayValue.vcf")); - - ASSERT_EQ("Circa 2020s", TestFile.Anniversary); + TestFileIter = TestFile.XMLList.find(1); + ASSERT_NE(TestFile.XMLList.end(), TestFileIter); + ASSERT_EQ("Example Page 2", TestFileIter->second); + + TestFileIter = TestFile.XMLList.find(2); + ASSERT_NE(TestFile.XMLList.end(), TestFileIter); + ASSERT_EQ("Example Page 3", TestFileIter->second); } -TEST(ContactLoad, TimeZoneTests){ +TEST(ContactLoad, NicknameTests){ ContactDataObject TestFile; @@ -385,95 +846,312 @@ TEST(ContactLoad, TimeZoneTests){ std::map::iterator TestFileIter; std::map::iterator TestFileIntIter; - // Check that the timezone has been read (TZ). General. + // Check that the nickname has been read (NICKNAME). General. + + TestFileIter = TestFile.GeneralNicknamesList.find(0); + ASSERT_NE(TestFile.GeneralNicknamesList.end(), TestFileIter); + ASSERT_EQ("Tester", TestFileIter->second); - TestFileIter = TestFile.GeneralTZList.find(0); - ASSERT_NE(TestFile.GeneralTZList.end(), TestFileIter); - ASSERT_EQ("Europe/Truro", TestFileIter->second); - // Check the ALTID parameter. - TestFileIter = TestFile.GeneralTZListAltID.find(0); - ASSERT_NE(TestFile.GeneralTZListAltID.end(), TestFileIter); + TestFileIter = TestFile.GeneralNicknamesListAltID.find(0); + ASSERT_NE(TestFile.GeneralNicknamesListAltID.end(), TestFileIter); ASSERT_EQ("35", TestFileIter->second); // Check the PID parameter. - TestFileIter = TestFile.GeneralTZListPID.find(0); - ASSERT_NE(TestFile.GeneralTZListPID.end(), TestFileIter); - ASSERT_EQ("60", TestFileIter->second); + TestFileIter = TestFile.GeneralNicknamesListPID.find(0); + ASSERT_NE(TestFile.GeneralNicknamesListPID.end(), TestFileIter); + ASSERT_EQ("50", TestFileIter->second); // Check the PREF parameter. - TestFileIntIter = TestFile.GeneralTZListPref.find(0); - ASSERT_NE(TestFile.GeneralTZListPref.end(), TestFileIntIter); - ASSERT_EQ(20, TestFileIntIter->second); + TestFileIntIter = TestFile.GeneralNicknamesListPref.find(0); + ASSERT_NE(TestFile.GeneralNicknamesListPref.end(), TestFileIntIter); + ASSERT_EQ(40, TestFileIntIter->second); // Check the LANGUAGE parameter. - TestFileIter = TestFile.GeneralTZListMediatype.find(0); - ASSERT_NE(TestFile.GeneralTZListMediatype.end(), TestFileIter); - ASSERT_EQ("text/plain", TestFileIter->second); + TestFileIter = TestFile.GeneralNicknamesListLanguage.find(0); + ASSERT_NE(TestFile.GeneralNicknamesListLanguage.end(), TestFileIter); + ASSERT_EQ("kw", TestFileIter->second); // Check the extra tokens parameter. - TestFileIter = TestFile.GeneralTZListTokens.find(0); - ASSERT_NE(TestFile.GeneralTZListTokens.end(), TestFileIter); - ASSERT_EQ("WHATS=This;A=Potato", TestFileIter->second); + TestFileIter = TestFile.GeneralNicknamesListTokens.find(0); + ASSERT_NE(TestFile.GeneralNicknamesListTokens.end(), TestFileIter); + ASSERT_EQ("YAY=Nope;Beep=Boop", TestFileIter->second); - // Check that the timezone has been read (TZ). Home. + // Repeat for the home type. + + TestFileIter = TestFile.HomeNicknamesList.find(1); + ASSERT_NE(TestFile.HomeNicknamesList.end(), TestFileIter); + ASSERT_EQ("Testy", TestFileIter->second); - TestFileIter = TestFile.HomeTZList.find(1); - ASSERT_NE(TestFile.HomeTZList.end(), TestFileIter); - ASSERT_EQ("Europe/Penzance", TestFileIter->second); - // Check the ALTID parameter. - TestFileIter = TestFile.HomeTZListAltID.find(1); - ASSERT_NE(TestFile.HomeTZListAltID.end(), TestFileIter); - ASSERT_EQ("15", TestFileIter->second); + TestFileIter = TestFile.HomeNicknamesListAltID.find(1); + ASSERT_NE(TestFile.HomeNicknamesListAltID.end(), TestFileIter); + ASSERT_EQ("17", TestFileIter->second); // Check the PID parameter. - TestFileIter = TestFile.HomeTZListPID.find(1); - ASSERT_NE(TestFile.HomeTZListPID.end(), TestFileIter); - ASSERT_EQ("20", TestFileIter->second); + TestFileIter = TestFile.HomeNicknamesListPID.find(1); + ASSERT_NE(TestFile.HomeNicknamesListPID.end(), TestFileIter); + ASSERT_EQ("39", TestFileIter->second); // Check the PREF parameter. - TestFileIntIter = TestFile.HomeTZListPref.find(1); - ASSERT_NE(TestFile.HomeTZListPref.end(), TestFileIntIter); - ASSERT_EQ(40, TestFileIntIter->second); + TestFileIntIter = TestFile.HomeNicknamesListPref.find(1); + ASSERT_NE(TestFile.HomeNicknamesListPref.end(), TestFileIntIter); + ASSERT_EQ(78, TestFileIntIter->second); // Check the LANGUAGE parameter. - TestFileIter = TestFile.HomeTZListMediatype.find(1); - ASSERT_NE(TestFile.HomeTZListMediatype.end(), TestFileIter); - ASSERT_EQ("text/plain", TestFileIter->second); + TestFileIter = TestFile.HomeNicknamesListLanguage.find(1); + ASSERT_NE(TestFile.HomeNicknamesListLanguage.end(), TestFileIter); + ASSERT_EQ("en", TestFileIter->second); // Check the extra tokens parameter. - TestFileIter = TestFile.HomeTZListTokens.find(1); - ASSERT_NE(TestFile.HomeTZListTokens.end(), TestFileIter); - ASSERT_EQ("MAYBE=not", TestFileIter->second); + TestFileIter = TestFile.HomeNicknamesListTokens.find(1); + ASSERT_NE(TestFile.HomeNicknamesListTokens.end(), TestFileIter); + ASSERT_EQ("YAY=Yep;Beep=Boop", TestFileIter->second); - // Check that the timezone has been read (TZ). Business. + // Repeat for the work type. + + TestFileIter = TestFile.BusinessNicknamesList.find(2); + ASSERT_NE(TestFile.BusinessNicknamesList.end(), TestFileIter); + ASSERT_EQ("The Testing One", TestFileIter->second); - TestFileIter = TestFile.BusinessTZList.find(2); - ASSERT_NE(TestFile.BusinessTZList.end(), TestFileIter); - ASSERT_EQ("Europe/St Austell", TestFileIter->second); - // Check the ALTID parameter. - TestFileIter = TestFile.BusinessTZListAltID.find(2); - ASSERT_NE(TestFile.BusinessTZListAltID.end(), TestFileIter); - ASSERT_EQ("45", TestFileIter->second); + TestFileIter = TestFile.BusinessNicknamesListAltID.find(2); + ASSERT_NE(TestFile.BusinessNicknamesListAltID.end(), TestFileIter); + ASSERT_EQ("99", TestFileIter->second); // Check the PID parameter. - TestFileIter = TestFile.BusinessTZListPID.find(2); - ASSERT_NE(TestFile.BusinessTZListPID.end(), TestFileIter); - ASSERT_EQ("70", TestFileIter->second); + TestFileIter = TestFile.BusinessNicknamesListPID.find(2); + ASSERT_NE(TestFile.BusinessNicknamesListPID.end(), TestFileIter); + ASSERT_EQ("10", TestFileIter->second); + + // Check the PREF parameter. + + TestFileIntIter = TestFile.BusinessNicknamesListPref.find(2); + ASSERT_NE(TestFile.BusinessNicknamesListPref.end(), TestFileIntIter); + ASSERT_EQ(1, TestFileIntIter->second); + + // Check the LANGUAGE parameter. + + TestFileIter = TestFile.BusinessNicknamesListLanguage.find(2); + ASSERT_NE(TestFile.BusinessNicknamesListLanguage.end(), TestFileIter); + ASSERT_EQ("en-GB", TestFileIter->second); + + // Check the extra tokens parameter. + + TestFileIter = TestFile.BusinessNicknamesListTokens.find(2); + ASSERT_NE(TestFile.BusinessNicknamesListTokens.end(), TestFileIter); + ASSERT_EQ("YAY=Maybe;Boop=Boing", TestFileIter->second); + +} + +TEST(ContactLoad, GenderTests){ + + // Check that the gender has been read. + + ContactDataObject TestFile; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + ASSERT_NE("", TestFile.Gender); + ASSERT_EQ("F", TestFile.Gender); + ASSERT_EQ("Example Text", TestFile.GenderDetails); + ASSERT_EQ("BEEP=Boop", TestFile.GenderTokens); + +} + +TEST(ContactLoad, BirthdayTests){ + + // Check that the birthday has been read. + + ContactDataObject TestFile; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + ASSERT_NE("", TestFile.Birthday); + ASSERT_EQ("20040101", TestFile.Birthday); + + // Check the ALTID parameter. + + ASSERT_EQ("35", TestFile.BirthdayAltID); + + // Check the CALSCALE parameter. + + ASSERT_EQ("georgian", TestFile.BirthdayCalScale); + + // Check the extra tokens parameter. + + ASSERT_EQ("HAPPY=Days", TestFile.BirthdayTokens); + + // Check the VALUE parameter. (Note have to use a different file + // due to the *1 rule in RFC6350. + + ContactDataObject TestFileValue; + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4-BDayValue.vcf")); + + ASSERT_EQ("Circa 2000s", TestFile.Birthday); + +} + +TEST(ContactLoad, AnniversaryTests){ + + // Check that the anniversary has been read. + + ContactDataObject TestFile; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + ASSERT_NE("", TestFile.Anniversary); + ASSERT_EQ("20200516", TestFile.Anniversary); + + // Check the ALTID parameter. + + ASSERT_EQ("70", TestFile.AnniversaryAltID); + + // Check the CALSCALE parameter. + + ASSERT_EQ("georgian", TestFile.AnniversaryCalScale); + + // Check the extra tokens parameter. + + ASSERT_EQ("WONDERFUL=Day", TestFile.AnniversaryTokens); + + // Check the VALUE parameter. (Note have to use a different file + // due to the *1 rule in RFC6350. + + ContactDataObject TestFileValue; + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4-BDayValue.vcf")); + + ASSERT_EQ("Circa 2020s", TestFile.Anniversary); + +} + +TEST(ContactLoad, TimeZoneTests){ + + ContactDataObject TestFile; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + // Check that the timezone has been read (TZ). General. + + TestFileIter = TestFile.GeneralTZList.find(0); + ASSERT_NE(TestFile.GeneralTZList.end(), TestFileIter); + ASSERT_EQ("Europe/Truro", TestFileIter->second); + + // Check the ALTID parameter. + + TestFileIter = TestFile.GeneralTZListAltID.find(0); + ASSERT_NE(TestFile.GeneralTZListAltID.end(), TestFileIter); + ASSERT_EQ("35", TestFileIter->second); + + // Check the PID parameter. + + TestFileIter = TestFile.GeneralTZListPID.find(0); + ASSERT_NE(TestFile.GeneralTZListPID.end(), TestFileIter); + ASSERT_EQ("60", TestFileIter->second); + + // Check the PREF parameter. + + TestFileIntIter = TestFile.GeneralTZListPref.find(0); + ASSERT_NE(TestFile.GeneralTZListPref.end(), TestFileIntIter); + ASSERT_EQ(20, TestFileIntIter->second); + + // Check the LANGUAGE parameter. + + TestFileIter = TestFile.GeneralTZListMediatype.find(0); + ASSERT_NE(TestFile.GeneralTZListMediatype.end(), TestFileIter); + ASSERT_EQ("text/plain", TestFileIter->second); + + // Check the extra tokens parameter. + + TestFileIter = TestFile.GeneralTZListTokens.find(0); + ASSERT_NE(TestFile.GeneralTZListTokens.end(), TestFileIter); + ASSERT_EQ("WHATS=This;A=Potato", TestFileIter->second); + + // Check that the timezone has been read (TZ). Home. + + TestFileIter = TestFile.HomeTZList.find(1); + ASSERT_NE(TestFile.HomeTZList.end(), TestFileIter); + ASSERT_EQ("Europe/Penzance", TestFileIter->second); + + // Check the ALTID parameter. + + TestFileIter = TestFile.HomeTZListAltID.find(1); + ASSERT_NE(TestFile.HomeTZListAltID.end(), TestFileIter); + ASSERT_EQ("15", TestFileIter->second); + + // Check the PID parameter. + + TestFileIter = TestFile.HomeTZListPID.find(1); + ASSERT_NE(TestFile.HomeTZListPID.end(), TestFileIter); + ASSERT_EQ("20", TestFileIter->second); + + // Check the PREF parameter. + + TestFileIntIter = TestFile.HomeTZListPref.find(1); + ASSERT_NE(TestFile.HomeTZListPref.end(), TestFileIntIter); + ASSERT_EQ(40, TestFileIntIter->second); + + // Check the LANGUAGE parameter. + + TestFileIter = TestFile.HomeTZListMediatype.find(1); + ASSERT_NE(TestFile.HomeTZListMediatype.end(), TestFileIter); + ASSERT_EQ("text/plain", TestFileIter->second); + + // Check the extra tokens parameter. + + TestFileIter = TestFile.HomeTZListTokens.find(1); + ASSERT_NE(TestFile.HomeTZListTokens.end(), TestFileIter); + ASSERT_EQ("MAYBE=not", TestFileIter->second); + + // Check that the timezone has been read (TZ). Business. + + TestFileIter = TestFile.BusinessTZList.find(2); + ASSERT_NE(TestFile.BusinessTZList.end(), TestFileIter); + ASSERT_EQ("Europe/St Austell", TestFileIter->second); + + // Check the ALTID parameter. + + TestFileIter = TestFile.BusinessTZListAltID.find(2); + ASSERT_NE(TestFile.BusinessTZListAltID.end(), TestFileIter); + ASSERT_EQ("45", TestFileIter->second); + + // Check the PID parameter. + + TestFileIter = TestFile.BusinessTZListPID.find(2); + ASSERT_NE(TestFile.BusinessTZListPID.end(), TestFileIter); + ASSERT_EQ("70", TestFileIter->second); // Check the PREF parameter. @@ -566,7 +1244,7 @@ TEST(ContactLoad, AddressTests){ TestFileIter = TestFile.GeneralAddressListGeo.find(0); ASSERT_NE(TestFile.GeneralAddressListGeo.end(), TestFileIter); - ASSERT_EQ("\"geo:1.0, 1.0\"", TestFileIter->second); + ASSERT_EQ("geo:1.0, 1.0", TestFileIter->second); // Check the TZ section. @@ -652,7 +1330,7 @@ TEST(ContactLoad, AddressTests){ TestFileIter = TestFile.HomeAddressListGeo.find(1); ASSERT_NE(TestFile.HomeAddressListGeo.end(), TestFileIter); - ASSERT_EQ("\"geo:4.0, 4.0\"", TestFileIter->second); + ASSERT_EQ("geo:4.0, 4.0", TestFileIter->second); // Check the TZ section. @@ -738,7 +1416,7 @@ TEST(ContactLoad, AddressTests){ TestFileIter = TestFile.BusinessAddressListGeo.find(2); ASSERT_NE(TestFile.BusinessAddressListGeo.end(), TestFileIter); - ASSERT_EQ("\"geo:7.0, 7.0\"", TestFileIter->second); + ASSERT_EQ("geo:7.0, 7.0", TestFileIter->second); // Check the TZ section. @@ -1006,13 +1684,19 @@ TEST(ContactLoad, TelephoneTests){ TestFileIter = TestFile.GeneralTelephoneList.find(0); ASSERT_NE(TestFile.GeneralTelephoneList.end(), TestFileIter); - ASSERT_EQ("tel:00000000", TestFileIter->second); + ASSERT_EQ("00000000", TestFileIter->second); + + // Check the data type section. + + TestFileIter = TestFile.GeneralTelephoneListDataType.find(0); + ASSERT_NE(TestFile.GeneralTelephoneListDataType.end(), TestFileIter); + ASSERT_EQ("tel", TestFileIter->second); // Check the type section. TestFileIter = TestFile.GeneralTelephoneListTypeInfo.find(0); ASSERT_NE(TestFile.GeneralTelephoneListTypeInfo.end(), TestFileIter); - ASSERT_EQ("fax,mobile", TestFileIter->second); + ASSERT_EQ("fax,cell", TestFileIter->second.ToStdString()); // Check the ALTID section. @@ -1042,7 +1726,13 @@ TEST(ContactLoad, TelephoneTests){ TestFileIter = TestFile.HomeTelephoneList.find(1); ASSERT_NE(TestFile.HomeTelephoneList.end(), TestFileIter); - ASSERT_EQ("tel:00001111", TestFileIter->second); + ASSERT_EQ("00001111", TestFileIter->second); + + // Check the data type section. + + TestFileIter = TestFile.HomeTelephoneListDataType.find(1); + ASSERT_NE(TestFile.HomeTelephoneListDataType.end(), TestFileIter); + ASSERT_EQ("tel", TestFileIter->second); // Check the type section. @@ -1078,7 +1768,13 @@ TEST(ContactLoad, TelephoneTests){ TestFileIter = TestFile.BusinessTelephoneList.find(2); ASSERT_NE(TestFile.BusinessTelephoneList.end(), TestFileIter); - ASSERT_EQ("tel:22221111", TestFileIter->second); + ASSERT_EQ("22221111", TestFileIter->second); + + // Check the data type section. + + TestFileIter = TestFile.BusinessTelephoneListDataType.find(2); + ASSERT_NE(TestFile.BusinessTelephoneListDataType.end(), TestFileIter); + ASSERT_EQ("tel", TestFileIter->second); // Check the type section. @@ -1230,7 +1926,7 @@ TEST(ContactLoad, GeographicTests){ TestFileIter = TestFile.GeneralGeographyList.find(0); ASSERT_NE(TestFile.GeneralGeographyList.end(), TestFileIter); - ASSERT_EQ("geo:3.5,3.5", TestFileIter->second); + ASSERT_EQ("3.5,3.5", TestFileIter->second); // Check the ALTID section. @@ -1266,7 +1962,7 @@ TEST(ContactLoad, GeographicTests){ TestFileIter = TestFile.HomeGeographyList.find(1); ASSERT_NE(TestFile.HomeGeographyList.end(), TestFileIter); - ASSERT_EQ("geo:7.0,7.0", TestFileIter->second); + ASSERT_EQ("7.0,7.0", TestFileIter->second); // Check the ALTID section. @@ -1302,7 +1998,7 @@ TEST(ContactLoad, GeographicTests){ TestFileIter = TestFile.BusinessGeographyList.find(2); ASSERT_NE(TestFile.BusinessGeographyList.end(), TestFileIter); - ASSERT_EQ("geo:14.0,14.0", TestFileIter->second); + ASSERT_EQ("14.0,14.0", TestFileIter->second); // Check the ALTID section. @@ -2347,6 +3043,11 @@ TEST(ContactLoad, PhotoTests){ ASSERT_NE(TestFile.PicturesListPID.end(), TestFileIter); ASSERT_EQ("71", TestFileIter->second); + // Check the TYPE section. + + TestFileIter = TestFile.PicturesListType.find(0); + ASSERT_EQ(TestFile.PicturesListType.end(), TestFileIter); + // Check the MEDIATYPE section. TestFileIter = TestFile.PicturesListMediatype.find(0); @@ -2396,6 +3097,12 @@ TEST(ContactLoad, PhotoTests){ ASSERT_NE(TestFile.PicturesListPID.end(), TestFileIter); ASSERT_EQ("21", TestFileIter->second); + // Check the TYPE section. + + TestFileIter = TestFile.PicturesListType.find(1); + ASSERT_NE(TestFile.PicturesListType.end(), TestFileIter); + ASSERT_EQ("home", TestFileIter->second); + // Check the MEDIATYPE section. TestFileIter = TestFile.PicturesListMediatype.find(1); @@ -2445,6 +3152,12 @@ TEST(ContactLoad, PhotoTests){ ASSERT_NE(TestFile.PicturesListPID.end(), TestFileIter); ASSERT_EQ("91", TestFileIter->second); + // Check the TYPE section. + + TestFileIter = TestFile.PicturesListType.find(2); + ASSERT_NE(TestFile.PicturesListType.end(), TestFileIter); + ASSERT_EQ("work", TestFileIter->second); + // Check the MEDIATYPE section. TestFileIter = TestFile.PicturesListMediatype.find(2); @@ -2508,6 +3221,8 @@ TEST(ContactLoad, LogoTests){ ASSERT_NE(TestFile.LogosListPID.end(), TestFileIter); ASSERT_EQ("71", TestFileIter->second); + // Check the TYPE section. + // Check the MEDIATYPE section. TestFileIter = TestFile.LogosListMediatype.find(0); @@ -2556,6 +3271,12 @@ TEST(ContactLoad, LogoTests){ TestFileIter = TestFile.LogosListPID.find(1); ASSERT_NE(TestFile.LogosListPID.end(), TestFileIter); ASSERT_EQ("21", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.LogosListType.find(1); + ASSERT_NE(TestFile.LogosListType.end(), TestFileIter); + ASSERT_EQ("home", TestFileIter->second); // Check the MEDIATYPE section. @@ -2606,6 +3327,12 @@ TEST(ContactLoad, LogoTests){ ASSERT_NE(TestFile.LogosListPID.end(), TestFileIter); ASSERT_EQ("91", TestFileIter->second); + // Check the TYPE section. + + TestFileIter = TestFile.LogosListType.find(2); + ASSERT_NE(TestFile.LogosListType.end(), TestFileIter); + ASSERT_EQ("work", TestFileIter->second); + // Check the MEDIATYPE section. TestFileIter = TestFile.LogosListMediatype.find(2); @@ -3063,6 +3790,11 @@ TEST(ContactLoad, SoundTests){ ASSERT_NE(TestFile.SoundsListMediatype.end(), TestFileIter); ASSERT_EQ("application/ogg", TestFileIter->second); + // Check the TYPE section. + + TestFileIter = TestFile.SoundsListType.find(0); + ASSERT_EQ(TestFile.SoundsListType.end(), TestFileIter); + // Check the LANGUAGE section. TestFileIter = TestFile.SoundsListLanguage.find(0); @@ -3203,4 +3935,832 @@ TEST(ContactLoad, SoundTests){ } -// TODO: Add tests for the Contact Loading process. \ No newline at end of file +TEST(ContactLoad, CalendarURITests){ + + ContactDataObject TestFile; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + // Start with a general calendar address. + + TestFileIter = TestFile.CalendarList.find(0); + ASSERT_NE(TestFile.CalendarList.end(), TestFileIter); + ASSERT_EQ("http://example.com", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.CalendarListType.find(0); + ASSERT_EQ(TestFile.CalendarListType.end(), TestFileIter); + + // Check the ALTID section. + + TestFileIter = TestFile.CalendarListAltID.find(0); + ASSERT_NE(TestFile.CalendarListAltID.end(), TestFileIter); + ASSERT_EQ("34", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.CalendarListPID.find(0); + ASSERT_NE(TestFile.CalendarListPID.end(), TestFileIter); + ASSERT_EQ("31", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.CalendarListMediatype.find(0); + ASSERT_NE(TestFile.CalendarListMediatype.end(), TestFileIter); + ASSERT_EQ("text/plain", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.CalendarListPref.find(0); + ASSERT_NE(TestFile.CalendarListPref.end(), TestFileIntIter); + ASSERT_EQ(32, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.CalendarListTokens.find(0); + ASSERT_NE(TestFile.CalendarListTokens.end(), TestFileIter); + ASSERT_EQ("CALENDARS=FLYING", TestFileIter->second); + + // Start with a home calendar address. + + TestFileIter = TestFile.CalendarList.find(1); + ASSERT_NE(TestFile.CalendarList.end(), TestFileIter); + ASSERT_EQ("http://example.com/home", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.CalendarListType.find(1); + ASSERT_NE(TestFile.CalendarListType.end(), TestFileIter); + ASSERT_EQ("home", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.CalendarListAltID.find(1); + ASSERT_NE(TestFile.CalendarListAltID.end(), TestFileIter); + ASSERT_EQ("44", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.CalendarListPID.find(1); + ASSERT_NE(TestFile.CalendarListPID.end(), TestFileIter); + ASSERT_EQ("41", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.CalendarListMediatype.find(1); + ASSERT_NE(TestFile.CalendarListMediatype.end(), TestFileIter); + ASSERT_EQ("text/dryplain", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.CalendarListPref.find(1); + ASSERT_NE(TestFile.CalendarListPref.end(), TestFileIntIter); + ASSERT_EQ(42, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.CalendarListTokens.find(1); + ASSERT_NE(TestFile.CalendarListTokens.end(), TestFileIter); + ASSERT_EQ("CALENDARS=GROUNDED", TestFileIter->second); + + // Start with a business calendar address. + + TestFileIter = TestFile.CalendarList.find(2); + ASSERT_NE(TestFile.CalendarList.end(), TestFileIter); + ASSERT_EQ("http://example.com/business", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.CalendarListType.find(2); + ASSERT_NE(TestFile.CalendarListType.end(), TestFileIter); + ASSERT_EQ("work", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.CalendarListAltID.find(2); + ASSERT_NE(TestFile.CalendarListAltID.end(), TestFileIter); + ASSERT_EQ("54", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.CalendarListPID.find(2); + ASSERT_NE(TestFile.CalendarListPID.end(), TestFileIter); + ASSERT_EQ("51", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.CalendarListMediatype.find(2); + ASSERT_NE(TestFile.CalendarListMediatype.end(), TestFileIter); + ASSERT_EQ("text/stillwetink", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.CalendarListPref.find(2); + ASSERT_NE(TestFile.CalendarListPref.end(), TestFileIntIter); + ASSERT_EQ(52, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.CalendarListTokens.find(2); + ASSERT_NE(TestFile.CalendarListTokens.end(), TestFileIter); + ASSERT_EQ("CALENDARS=CANCELLED", TestFileIter->second); + +} + +TEST(ContactLoad, CalendarAddressURITests){ + + ContactDataObject TestFile; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + // Start with a general calendar request address. + + TestFileIter = TestFile.CalendarRequestList.find(0); + ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter); + ASSERT_EQ("http://example.com/request", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.CalendarRequestListType.find(0); + ASSERT_EQ(TestFile.CalendarRequestListType.end(), TestFileIter); + + // Check the ALTID section. + + TestFileIter = TestFile.CalendarRequestListAltID.find(0); + ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter); + ASSERT_EQ("14", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.CalendarRequestListPID.find(0); + ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter); + ASSERT_EQ("11", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.CalendarRequestListMediatype.find(0); + ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter); + ASSERT_EQ("text/plain", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.CalendarRequestListPref.find(0); + ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter); + ASSERT_EQ(12, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.CalendarRequestListTokens.find(0); + ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter); + ASSERT_EQ("REQUEST=YES", TestFileIter->second); + + // Start with a home calendar request address. + + TestFileIter = TestFile.CalendarRequestList.find(1); + ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter); + ASSERT_EQ("http://example.com/home/request", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.CalendarRequestListType.find(1); + ASSERT_NE(TestFile.CalendarRequestListType.end(), TestFileIter); + ASSERT_EQ("home", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.CalendarRequestListAltID.find(1); + ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter); + ASSERT_EQ("24", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.CalendarRequestListPID.find(1); + ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter); + ASSERT_EQ("21", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.CalendarRequestListMediatype.find(1); + ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter); + ASSERT_EQ("text/dryplain", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.CalendarRequestListPref.find(1); + ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter); + ASSERT_EQ(22, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.CalendarRequestListTokens.find(1); + ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter); + ASSERT_EQ("REQUEST=MAYBE", TestFileIter->second); + + // Start with a business calendar request address. + + TestFileIter = TestFile.CalendarRequestList.find(2); + ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter); + ASSERT_EQ("http://example.com/business/request", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.CalendarRequestListType.find(2); + ASSERT_NE(TestFile.CalendarRequestListType.end(), TestFileIter); + ASSERT_EQ("work", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.CalendarRequestListAltID.find(2); + ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter); + ASSERT_EQ("34", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.CalendarRequestListPID.find(2); + ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter); + ASSERT_EQ("31", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.CalendarRequestListMediatype.find(2); + ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter); + ASSERT_EQ("text/stillwetink", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.CalendarRequestListPref.find(2); + ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter); + ASSERT_EQ(32, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.CalendarRequestListTokens.find(2); + ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter); + ASSERT_EQ("REQUEST=NO", TestFileIter->second); + +} + +TEST(ContactLoad, FreeBusyTests){ + + ContactDataObject TestFile; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + // Start with a general calendar free busy address. + + TestFileIter = TestFile.FreeBusyList.find(0); + ASSERT_NE(TestFile.FreeBusyList.end(), TestFileIter); + ASSERT_EQ("http://example.com/freebusy", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.FreeBusyListType.find(0); + ASSERT_EQ(TestFile.FreeBusyListType.end(), TestFileIter); + + // Check the ALTID section. + + TestFileIter = TestFile.FreeBusyListAltID.find(0); + ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter); + ASSERT_EQ("74", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.FreeBusyListPID.find(0); + ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter); + ASSERT_EQ("71", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.FreeBusyListMediatype.find(0); + ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter); + ASSERT_EQ("text/plain", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.FreeBusyListPref.find(0); + ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter); + ASSERT_EQ(72, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.FreeBusyListTokens.find(0); + ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter); + ASSERT_EQ("STATUS=OUT", TestFileIter->second); + + // Start with a home calendar free busy address. + + TestFileIter = TestFile.FreeBusyList.find(1); + ASSERT_NE(TestFile.FreeBusyList.end(), TestFileIter); + ASSERT_EQ("http://example.com/home/freebusy", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.FreeBusyListType.find(1); + ASSERT_NE(TestFile.FreeBusyListType.end(), TestFileIter); + ASSERT_EQ("home", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.FreeBusyListAltID.find(1); + ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter); + ASSERT_EQ("84", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.FreeBusyListPID.find(1); + ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter); + ASSERT_EQ("81", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.FreeBusyListMediatype.find(1); + ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter); + ASSERT_EQ("text/dryplain", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.FreeBusyListPref.find(1); + ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter); + ASSERT_EQ(82, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.FreeBusyListTokens.find(1); + ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter); + ASSERT_EQ("STATUS=FREE", TestFileIter->second); + + // Start with a business calendar free busy address. + + TestFileIter = TestFile.FreeBusyList.find(2); + ASSERT_NE(TestFile.FreeBusyList.end(), TestFileIter); + ASSERT_EQ("http://example.com/business/freebusy", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.FreeBusyListType.find(2); + ASSERT_NE(TestFile.FreeBusyListType.end(), TestFileIter); + ASSERT_EQ("work", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.FreeBusyListAltID.find(2); + ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter); + ASSERT_EQ("94", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.FreeBusyListPID.find(2); + ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter); + ASSERT_EQ("91", TestFileIter->second); + + // Check the MEDIATYPE section. + + TestFileIter = TestFile.FreeBusyListMediatype.find(2); + ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter); + ASSERT_EQ("text/stillwetink", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.FreeBusyListPref.find(2); + ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter); + ASSERT_EQ(92, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.FreeBusyListTokens.find(2); + ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter); + ASSERT_EQ("STATUS=BUSY", TestFileIter->second); + +} + +TEST(ContactLoad, KeyTests){ + + ContactDataObject TestFile; + + wxString KeyA = "LS0tLS1CRUdJTiBQR1AgUFVCTElDIEtFWSBCTE9DSy0tLS0tClZlcnNpb246IEdudVBHIHYyCgpt" + "UU11QkZaL0JyWVJDQUN2cTNueUl4dXJPOFovMHcwQWdkeUdhN1d2cWRpdk5OWVdEM3dmZkgrSi83" + "R2o1dkNOClJwWFQ5TVI4SEdmR0Jwai9hc0NsajltbjhnRENMcVZJaXFybXZXK3dHbnhBVWxFU05V" + "T201cEx6NTRwTzBzOW0KYzJ5SDRkYWVYR3pRTXFLUit2TDZaTWpDc0pSRk1UWVAzSDlTMlBFaHFF" + "MXl4TnBpRi9ZTS9jNGNOYmU5bEZsTgpKMnJ2QzA2bzZuMFlzYWtuZTk3bWlndGNyTUpZVDljVDF4" + "cjB5YUhDekcrVXZqOG1RMnlGT0tpVEpxeGlCVEdhClRMWjJjTFBVZVFFbnpjSWNwNnhVTitQZlZY" + "ZzNNVllHWUZQakk0aUg0anNCQUFDc1BEMmpYSExnYVVzLzJ5VHUKNVF4M1RKSHljVTArOXZidC85" + "VDJKdGt3c1R5SXlqQnJ0eGd6QVFERENaaFZoNU5oOFJuSWlSRDFzMzNmN1RoZgp4eENUMU0yWHI3" + "dWh1WVFTZ1FmNUFRYkFscDZpUk9xTms5VVlBeHNSWVdPelRFd3RWMGlCLzBJamwyZFBUTm1YClJx" + "NW9FN0JOT3JYZjEzMmM4NlFpNWdPbGVHbWNoNFEvUUZTbUYwT05FZCs4aVNWemMvaVdFTUh4SzRO" + "Z1ZMN0kKc0FMMDVweGZhdWxpWlRlWVVGcGM1ajZnWHFpUExyNy93ODB4Q05vOWZsWmZXQkZzYVhM" + "Zm10Z3I1MU9kYXhJNQpLZnFjRjg1cnVQSkZkZjJWb1hxRU81YXpHZ1VsS0xoZDg5NkZUR21tZEF0" + "SUp5b0RtTldyVFgwS1VqQ05ELzM4Ck5UZDZrK3h6bW1NcTJCRy9VRy9NVGtlTUl1T3BEenZGQjBi" + "R2NRZnlGSC9iVnRjQzBOS2lnT0crMStPZ1dMMGUKQzZqcGRyYXU3THNKeXcrbU9VSjdHWHFTN2pK" + "WnU2ZjBZcWxLbEZrUllBZi9VekVUL3lBU2VhQUV2a1BqMnF5Lwo4b1ZIQWdrVGFZSWUvSHF1UEN4" + "RVc4bmgzWEp2emIxaWVlOHMrT2lZaE1wWVFIdFVTYTdESWR1eTgzZllTS2REClZzUnNNWExiMFly" + "Z1IvamhxdVZhYzR3TXFvZ3JJTGRoK3lhcDdtUEhwdUVrOCtLcGROUldJNkZMS0srekpxcVYKZWh6" + "ckNDc1QzL09URUd6bnpTSllXOXdQWkhlbEViMVhjQjIvbXJZSWlaZkZvUUI5K1ozNkYzS051UDR5" + "cTdGcQpacWV5L0NLRFN4OTl4ckJwaTlLVENJUTl6UE5QS0xiSk0xUWFSVlNMNEhIcmh6dFJQc2Jt" + "bzlOS01lVHliSkE5ClpvY0JZRno1d1Q1RWRuZEdRUG51eWhESHY4UHZrbStWQXJnRVpkdUdFL0tI" + "T1N6amlOVFE0QUtzaWc2OThFWGYKb0xRc1JYaGhiWEJzWlNCVmMyVnlJQ2hKYm5aaGJHbGtLU0E4" + "WlhoaGJYQnNaVUJsZUdGdGNHeGxMbU52YlQ2SQpnUVFURVFnQUtRVUNWbjhHdGdJYkF3VUpBREJD" + "Q2djTENRZ0hBd0lCQmhVSUFna0tDd1FXQWdNQkFoNEJBaGVBCkFBb0pFSWJ1TXE0ZVZZTFY0L01B" + "L2lSUG41cUttdC9MK0doWVlIcCtlNmRiTHdxRFpCRkI3WGRlTTNZNlVScC8KQVFDZ21NSGM4d21Y" + "S0M0QTJUMURPTHdhMUNVVzFLWHBaWm9xWEEwLzFhcHBHcmtCalFSV2Z3YTJFQVlBbnZYZgp0OWg1" + "QnYyWTdvckp2UGQvTXNYTlZMc0E1UTh3TTc2TytrRjdWMktsNzBjZitJVDM5UUpWRGtKSk15NjFG" + "UEQvClFoME5WNm05VjVsZ0E0U2psamo0SzIvc0ExUlhkRHVtaWFrWk1naUN4eXBveEhjM09uOEdX" + "di9kZXl0WExpU2YKQnRrVHpiZEZmMDVHdGk1NXc1cnREQmxEM1o2YmR6U0ZtRS8rK2VFYXR4Uzh5" + "NXJBNTM2WmpoSm5RQm43dm1aSQpwb3FUeTR0SEQ3aU5oWjN5eXFjZlpBd3BzSmNpZy9RdGVhZWNF" + "UVgvSVlvL01wQllMTkp1V1VSRVpqeERBQU1GCkJmOUxmVlZJakhBdWt3NzUxeHFsQmhaUTRCVVV5" + "eHE4UTVicjZXVjJzeVppNnhWSW5OS2h3Q2NGYkZNVjV4TUIKczg3eGFzc1UrVzlaZktuODdScDRp" + "a3JxOEVvV3FPZTVMQW93SUF6bHYxVUlzMWRpOENHeStlU1lhYVMzVGd0Ywo2REhGS004Vk5KUU8w" + "VWZkUXNwS2FuNUVLL1ZUNy9QQVJONGFKcFZxdjNtYkVFWkdJdDJHMStpUm15VW5LbFd4CkxoaUky" + "REs5Rm9CajhucXlJVG1KMTBVTmRib2lmeUtFNTFwU2VlYjN3Rm8yNGhNNlVkbEVwVitQVGJvU0dG" + "ZXAKNGQrSVp3UVlFUWdBRHdVQ1ZuOEd0Z0liREFVSkFEQkNDZ0FLQ1JDRzdqS3VIbFdDMVlJT0FR" + "Q0FyWXRSZDBqSQpFYWNPbUxRWUNNUzNGVUNQRDc3dFlxd1VqM3NjSGVYWTdBRDhEKzAvMWdDdlZX" + "elJuZ1dBSFZidXZxSkhmUEFpCm1HVFVHa1ZHOGNZdlBlUT0KPWtxclcKLS0tLS1FTkQgUEdQIFBV" + "QkxJQyBLRVkgQkxPQ0stLS0tLQo="; + + wxString KeyB = "LS0tLS1CRUdJTiBQR1AgUFVCTElDIEtFWSBCTE9DSy0tLS0tClZlcnNpb246IEdudVBHIHYyCgpt" + "UU11QkZaL0tiWVJDQUNqTDdwMDZEVTJaQTZwdmJkZ1BVQU5hd1dwTGt3ZlFnZHdWdkVNcFQvRnZu" + "QjNGbDV4CnFFL2dMRFJDZlhLTVF4UEF1NWRBWUVpZVhxN01KN0ZtVXVYbDhJSjZiY3pKRUNmWUF6" + "RFJ0VmJlMm5ReXMyUDcKaXBFcnREK1dOZFM5MEVPbFVYb2lhOGR3NmpXczl5QUIvb3BubXBDV21w" + "QjI2UVBKNDlNWTBVNWZ1NzhwamJ2MAppMWxmUXIyaWp4QzRDWHZlOGxld05Uak1pOU5UNkt6R1lw" + "UXc1MHpXUng0Zk9teENselE5c3lQUWFuZ1htaTVECmk5MytNYXBaSlZpY3UyT3I1VkdqUlRXYWov" + "UDNqN1p2REdtNGNwaUhqMURsNTFVam5ZM09xOXE4VnczMkEvK2YKbW9SWWxiY3dtWU1LeVMzMHJx" + "SjVCOE0xcTdsenJ3TTBGQXczQVFEN3FnOE9pR2E1emR1UnlYdGlQMFFNSVZBOApDZUxuR25xYUJQ" + "dytEYkhDUndmK05ZelJiNUxBUXZQTXpsNlkrUTczb3N4VXhMYzBHOUt5K2tNWVRNSFg5S2xzCmV2" + "UThoQkFEc3Y5WDhVeklBRXpLUUJVQ2tWT0JQT2xLMnJiaHdrRzZGendDdzJDemxmU0NXSzBxaWhP" + "bGFQVEsKL0c1SVJEQWg2SkFXTitjM1c5SHp1TUN1T1Vhb3didENhU2cxcFdocWNEY2hoWFZtNGdP" + "Z3F6cDNkWXdKU3FEQwpCWGV4KzRsWk84TzZSa3BPMVhmTHlkSWpxSlQrQUNMdkFjek8zbW90c2J6" + "OEZNWWZzVTQ2ZWsvd05DczZJdlFDCjJQcFFJbHFHU3NmZXFLUGpsUXVGbkRQNHEvNUNlVU5odmZr" + "Mm5VeTcwTzc4Z2hFdEViUU44MXNxWUpROHBTdTcKRExjVS8zQ1oyYXJ0RWxkVGJ5a0p1RTJ6a3BV" + "MjA1WTJvU0lDMkI1eXFnZjlIeWZOemYxU3lsRVV5d3ZzZ3F2LwpuNUNzbDdobDNML3BSQ1A0dEF0" + "NTA5TFFiejNDRk8vSGk3Umg1V3luOFVXZ1EzU0dYdThWQjNrUGhmRkFDNFZPCjJBUVdnMFlDeEth" + "SSs1dUljUWRGSDR6b0s0cWNidmxZN0xWNXozOWIza2JGWUgzVytEZjJkNkhJRzZaZUF2aXQKZXhZ" + "ZWNlMGNpS0l6dklqVUJydUI0R3BRREhZbGN5QmpxcWtOVE5zTzU4aEsvQisvangxMGdLUVJTa0lw" + "c0VJVgpLa0dBRk5sVnlMTGthck1hYnRNWUlzZnBidWtoSjF3d09aTXJITGJwSGxQSFFzSDJJczNI" + "dmlkQ2RBdUdRMWQyCjE2U3lEMGFUMHFIMnlkY1V2WFAyUnIwRnFzR3BLY2dWeThMOTcyQWpCTmRT" + "RWU0YXVQVGhWRXE5RWtScENSVGIKQUxRdlJYaGhiWEJzWlNCVmMyVnlJRElnS0VsdWRtRnNhV1Fw" + "SUR4bGVHRnRjR3hsTWtCbGVHRnRjR3hsTG1OdgpiVDZJZ1FRVEVRZ0FLUVVDVm44cHRnSWJBd1VK" + "QUNnMkNnY0xDUWdIQXdJQkJoVUlBZ2tLQ3dRV0FnTUJBaDRCCkFoZUFBQW9KRUFBdVBvS2h3WmFq" + "VmFFQkFMN01saU5wLzR0cy9QWkQwdlRCcTYySjBUV0hvTjBDcHpqUXJKQUwKblNZeUFQMGJYY0Y4" + "UHRFejNlUkJkazBkTlNFeU1EMkVWVGQ0K3hhZTRRNUx4Q3gxU0xrQmpRUldmeW0yRUFZQQp4eWs4" + "dUQ4MnZTZ2xORFA0UlQ3ZzExSjdnTXROV1g0SjBEbmdocVZVc0svY2xFQm4yenZYN080eElpQnlu" + "VG9wCmRKeDZaeE5pdFBKVG0zZzI4alRLUElKeXlDVGVHLzJiaWtFc0hUYlFpMStpaXBkcEpjZm9E" + "cTlJMVBMVk41Mm8KaFVMaUJhdXdwNHFIeTFyTys3ajhtbWVlL1M5ckpzM2NmQnZHR09acmpFK3g4" + "TTRMdjJDeGlEWnJzRUFkdHNPUgpnMHgxMFFqNjJwOExuTHg2TzQ4ZWh0cGZTV1JnRmZOdU9vSEJV" + "U3RwSW5pMHRrajJSQitGaUgwZWxkc1VyRndMCkFBTUdCZ0NPYzk5bjB3OWEvelRDL0VxSnRjU2ll" + "RkNtckMvODYrcW12OEJ3aW5zdU1STUtVSG1UdFFkR1RRQkcKL0ZXa2pKYm9YMEhZckp0d1JBaC9t" + "M2N6UnNMZjZkT3QxL2hEUVF2ZGVIcVhuZ1JleitWNzAyY0pUVVdwVGg5RgpjYnZ3NFpjMk93Yzhz" + "am13L3dYc2NMK0ZNU09mT3l6eC8xWmxBUDVoSkQ5TTNnV1dEL0ZLSk0weUxSZDI5OW92CkpoNDZV" + "VkIvaHdxelEyYnlEUzV2QXhXUlFsT0FHaEdXVzNOcjlQRE82N2dsSWRPM2o5VzN4bENUNjJ4cmEv" + "VmMKbDVDTU9qU0lad1FZRVFnQUR3VUNWbjhwdGdJYkRBVUpBQ2cyQ2dBS0NSQUFMajZDb2NHV296" + "aThBUUNqc09YbQpGdEFCcEU4b0EzVmtPT1o4b28wMFZTcUhKVFkxRzhpNXgvNmtZQUVBMC9kR0Jm" + "RHVhMDBxL2Z1Z3dYTmlPREJXCjh2a2hlMEVIOWFlYzJQaUd3VTg9Cj1ZWmZuCi0tLS0tRU5EIFBH" + "UCBQVUJMSUMgS0VZIEJMT0NLLS0tLS0K"; + + wxString KeyC = "LS0tLS1CRUdJTiBQR1AgUFVCTElDIEtFWSBCTE9DSy0tLS0tClZlcnNpb246IEdudVB" + "HIHYyCgptUU11QkZaL0x3d1JDQUN0cVNJa3hYN2NBWkJHNFlIUmRldkRudndvM1V4dEQ0ZmxmaW" + "1NQmdTemUwbHJTMHNjCmEyaDRmMzJ1eklpR2Q1S0plT0psV3AwSUFBOXNCUW5lQVpXVm9XUjZaO" + "TlZZnNtUjhoSENZVERqTGpVRUFnMTYKYzNsbUpWbkRqTDF4bmhSR2RjUGJxS2VQOGVuZ0hQWE4w" + "M0tuSkVYcUNZSnFNc3NySFNlN3crMFNMeVJPQkJkeQprSE5Lb1B1bUdOUWIvakhLd0QzNFg1SEJ" + "MbUVkbXczR1gzNXVwbm9pVnNqSGJzcHY3bVBQRVJxdlNGMUtlTmVHCkhnSllHdlZiNUJZenpMQ3" + "dRRXU0VFNVMFRLQytMeUZUUFpPZE9pVzU2RG5qbktrNk1Od2xCWTFDZXRzZFpwR2QKUXFWZmNYd" + "FRnNG1SNGZzVVJaQ0JXR0w3OFMrQ2tDUFh4NTRIQVFDbEhVbUFzK3hnV0ExbU11SzVva2FadDYz" + "eQoyb09CSXBseXZkcDhreCtVY3dmL2FWUGQ1dGZ2S3JPVTV0VVZDdlpMN0syVnlkNUNSckFTUG9" + "3VkwrWmxjYXNDCloyaDEvRGJKQ1FYOVVPTU5LNXVVMUZYNFErLy83OWR3ZlZVOEZYZUpzM1NKeD" + "hHQlB3Z0s4RStmait2MWVNSmMKTkhCMlV2eGtrU050akErUHB1dW5sYXhGYWpBRTU2ckt6N2U0N" + "GI5NUNjVldkUTAxbTByeGptSGhTUmtXeDlWNQp4cExsbUZ2Q1ZLMXFsMlV5eCtzZU9RQXJpMjBG" + "cUUzbktQMU9BNWt2QTd3b2NpZ1JVakVVWk1XOEFxL1daV2xnCnk2YW9pVTFPSlp6Q2tkeStPcWV" + "xL0djeWRIYmcwdUZ0N3UvSTROTWFLVlZMREhWdStSWXZlcGlzNy93TVMvclMKQTVwVk56NURRMX" + "R3cTlJTWV0NGNGRnBjOFdIeTVnR0pUNEFRVk1UYU5RZ0FuR1JqKytBTEpObCtsc1AzaDBjbwpTa" + "0xqOElWbjlkaXRFUGMxRGVRbllUb092WStLSDA3a09MekJmbXcvdmRlTVdkZzd6VDZhQTRza2hB" + "L2VHNWdDCm1sL25IQmM1TS9pV2htRE9FUzFXZTRVYWMzbVNWeG9iSS9oYzNlM3pVcTlkQ0F5OFc" + "4eUxvUThxMVArTnlScFkKd250bUxuZ2RVek00VTFLbEdMTWx3aGF1V3liQlBHTnlqYy9KUWtvdk" + "dVa1g5dHU0cGdzaVlOb2F1MjV5NUs3OQo0Z1MxQUtlQjgya3lteWlQaGQvdnZpK3VhRXIzdFQ5Z" + "2x0WjRiaW1YR3ZQZG1xRnV1MkVYTXhmQXJGL21NSzJoClN5Z1BIUG5jVW9kc3NNV0ZxZjEvNWo1" + "MkwrTzlUK1RLVXhxQ2RHMVFSOVZDU0NoUDY0c0NFaGpqeis5R1g1eHAKZGJRdlJYaGhiWEJzWlN" + "CVmMyVnlJRE1nS0VsdWRtRnNhV1FwSUR4bGVHRnRjR3hsTTBCbGVHRnRjR3hsTG1OdgpiVDZJZ1" + "FRVEVRZ0FLUVVDVm44dkRBSWJBd1VKQUFuZU5BY0xDUWdIQXdJQkJoVUlBZ2tLQ3dRV0FnTUJBa" + "DRCCkFoZUFBQW9KRU1IakNSbG51dzVEOVFrQS9qWGFUTjJSVEhKSytMWEs1dXJEVDBLTElBTUVW" + "ak1lT1dQWmlyVXkKcldnRkFQd09XSi80eDVBT3dvZFVPTnh6Rk5NRXJBV2o5N3Y1bm5ZaURJcm1" + "jUjl1ZzdrQmpRUldmeThNRUFZQQorVFBWcit3VGk2U0RxN25pd3pNZUo2c05QMHlwaXVJaTB3c2" + "pXRDVndnJROGZqVE41STdtL3hldEhtcXdvbDdiCnhEL09iUE1GRm9Tdm1kRERlVlR5cnl0cDI3U" + "05QNVgzUFlxTldKbW9XN09mUTBQRlIvbmprdVNGdmN0NkZDNTMKVjhvU0JPcVVuRWlZckRGSU1z" + "REdOQ25UZ1VUeG9GaFZ1MEVESFRhWVFxV2tYMWxldTJFQTlZTjJub3FFVVh2bgpEOE92TXZaWGx" + "QcTFzdDVmc2IyODB1RGJYMWRvWVpNK0pPRWo3bHp4bEtzUjJNZFlOallKci9RZUwwaEMxVlpmCk" + "FBTUZCZjR0bWdvRmt4a0Y4N2Z4ejB4eU9sYXhGclUzYnhVZXJiYTZPUGZJTjV3cXZmOEFsNGdwZ" + "XRRRitNQysKUnBlR01rYk5iaTRwV3MvV1BUbmhIN2R3UTI4a0c3VXFkSjdiMDdYUkpVbTJrenRu" + "NGRucFJpTGJBU1Z0MFVlRApxeWpNY1hRa21KTTFjVlNDMWpzY0ROUTl1anNjMXBQUi9iK2xPa0F" + "2ZGJtK0x3RHZNMmVJa25LWDZsdkZsa0RlCng1dU82ZXpKTktLZEdMSW53c2hpVHdzSjZoTS9OL3" + "JjbGFZeWpsSlBwY216VFhuaks5SmN1SU9MVHVsVXFwQUwKbHQyWXh1aUlad1FZRVFnQUR3VUNWb" + "jh2REFJYkRBVUpBQW5lTkFBS0NSREI0d2taWjdzT1E1Uk5BUUNUSHVjOQpjM1dORURZY1hhV2N6" + "S3ZwN2R4aWJ1YS9FanNxRC85eHNUOHRZUUQrT2VqRndvRmVrbnpZa2RFMmdJb2ZuaDk0CjdKeUh" + "aNDUyTERkamZXQ1BZWFU9Cj16T3NxCi0tLS0tRU5EIFBHUCBQVUJMSUMgS0VZIEJMT0NLLS0tLS" + "0K"; + + // Check that the vCard 4.0 file loads OK. + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + // Start with a general key. + + TestFileIter = TestFile.KeyList.find(0); + ASSERT_NE(TestFile.KeyList.end(), TestFileIter); + ASSERT_EQ(KeyA, TestFileIter->second); + + // Check the encoding type. + + TestFileIter = TestFile.KeyListDataEncType.find(0); + ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter); + ASSERT_EQ("base64", TestFileIter->second.ToStdString()); + + // Check the file type. + + TestFileIter = TestFile.KeyListDataType.find(0); + ASSERT_NE(TestFile.KeyListDataType.end(), TestFileIter); + ASSERT_EQ("application/pgp-keys", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.KeyListType.find(0); + ASSERT_EQ(TestFile.KeyListType.end(), TestFileIter); + + // Check the ALTID section. + + TestFileIter = TestFile.KeyListAltID.find(0); + ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter); + ASSERT_EQ("54", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.KeyListPID.find(0); + ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter); + ASSERT_EQ("51", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.KeyListPref.find(0); + ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter); + ASSERT_EQ(52, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.KeyListTokens.find(0); + ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter); + ASSERT_EQ("KEYS=JUSTONE", TestFileIter->second); + + // Start with a work key. + + TestFileIter = TestFile.KeyList.find(1); + ASSERT_NE(TestFile.KeyList.end(), TestFileIter); + ASSERT_EQ(KeyB, TestFileIter->second); + + // Check the encoding type. + + TestFileIter = TestFile.KeyListDataEncType.find(1); + ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter); + ASSERT_EQ("base64", TestFileIter->second.ToStdString()); + + // Check the file type. + + TestFileIter = TestFile.KeyListDataType.find(1); + ASSERT_NE(TestFile.KeyListDataType.end(), TestFileIter); + ASSERT_EQ("application/pgp-keys", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.KeyListType.find(1); + ASSERT_NE(TestFile.KeyListType.end(), TestFileIter); + ASSERT_EQ("home", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.KeyListAltID.find(1); + ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter); + ASSERT_EQ("64", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.KeyListPID.find(1); + ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter); + ASSERT_EQ("61", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.KeyListPref.find(1); + ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter); + ASSERT_EQ(62, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.KeyListTokens.find(1); + ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter); + ASSERT_EQ("KEYS=NONE", TestFileIter->second); + + // Start with a business key. + + TestFileIter = TestFile.KeyList.find(2); + ASSERT_NE(TestFile.KeyList.end(), TestFileIter); + ASSERT_EQ(KeyC, TestFileIter->second); + + // Check the encoding type. + + TestFileIter = TestFile.KeyListDataEncType.find(2); + ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter); + ASSERT_EQ("base64", TestFileIter->second.ToStdString()); + + // Check the file type. + + TestFileIter = TestFile.KeyListDataType.find(2); + ASSERT_NE(TestFile.KeyListDataType.end(), TestFileIter); + ASSERT_EQ("application/pgp-keys", TestFileIter->second); + + // Check the TYPE section. + + TestFileIter = TestFile.KeyListType.find(2); + ASSERT_NE(TestFile.KeyListType.end(), TestFileIter); + ASSERT_EQ("work", TestFileIter->second); + + // Check the ALTID section. + + TestFileIter = TestFile.KeyListAltID.find(2); + ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter); + ASSERT_EQ("74", TestFileIter->second); + + // Check the PID section. + + TestFileIter = TestFile.KeyListPID.find(2); + ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter); + ASSERT_EQ("71", TestFileIter->second); + + // Check the PREF section. + + TestFileIntIter = TestFile.KeyListPref.find(2); + ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter); + ASSERT_EQ(72, TestFileIntIter->second); + + // Check the extra tokens. + + TestFileIter = TestFile.KeyListTokens.find(2); + ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter); + ASSERT_EQ("KEYS=MISSING", TestFileIter->second); + +} + +TEST(ContactLoad, VendorTests){ + + ContactDataObject TestFile; + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + // Start with the first vendor namespace. + + TestFileIter = TestFile.VendorList.find(0); + ASSERT_NE(TestFile.VendorList.end(), TestFileIter); + ASSERT_EQ("Lemon", TestFileIter->second); + + TestFileIter = TestFile.VendorListPEN.find(0); + ASSERT_NE(TestFile.VendorListPEN.end(), TestFileIter); + ASSERT_EQ("696", TestFileIter->second); + + TestFileIter = TestFile.VendorListElement.find(0); + ASSERT_NE(TestFile.VendorListElement.end(), TestFileIter); + ASSERT_EQ("CAKE", TestFileIter->second); + + // Start with the second vendor namespace. + + TestFileIter = TestFile.VendorList.find(1); + ASSERT_NE(TestFile.VendorList.end(), TestFileIter); + ASSERT_EQ("Orange", TestFileIter->second); + + TestFileIter = TestFile.VendorListPEN.find(1); + ASSERT_NE(TestFile.VendorListPEN.end(), TestFileIter); + ASSERT_EQ("696", TestFileIter->second); + + TestFileIter = TestFile.VendorListElement.find(1); + ASSERT_NE(TestFile.VendorListElement.end(), TestFileIter); + ASSERT_EQ("DRINK", TestFileIter->second); + + // Start with the third vendor namespace. + + TestFileIter = TestFile.VendorList.find(2); + ASSERT_NE(TestFile.VendorList.end(), TestFileIter); + ASSERT_EQ("Shiena Nishizawa", TestFileIter->second); + + TestFileIter = TestFile.VendorListPEN.find(2); + ASSERT_NE(TestFile.VendorListPEN.end(), TestFileIter); + ASSERT_EQ("696", TestFileIter->second); + + TestFileIter = TestFile.VendorListElement.find(2); + ASSERT_NE(TestFile.VendorListElement.end(), TestFileIter); + ASSERT_EQ("MUSIC", TestFileIter->second); + +} + +TEST(ContactLoad, XTokenTest){ + + ContactDataObject TestFile; + + ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf")); + + std::map::iterator TestFileIter; + std::map::iterator TestFileIntIter; + + // Three X-FARM variables. + + TestFileIter = TestFile.XTokenList.find(0); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("Yard", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(0); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("FARM", TestFileIter->second); + + TestFileIter = TestFile.XTokenList.find(1); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("Animals", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(1); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("FARM", TestFileIter->second); + + TestFileIter = TestFile.XTokenList.find(2); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("Shed", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(2); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("FARM;LOCATION=Back;TYPE=Vehicles", TestFileIter->second.ToStdString()); + + // Three X-DISKSERIAL variables. + + TestFileIter = TestFile.XTokenList.find(3); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("14444", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(3); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("DISKSERIAL", TestFileIter->second); + + TestFileIter = TestFile.XTokenList.find(4); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("7555", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(4); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("DISKSERIAL", TestFileIter->second); + + TestFileIter = TestFile.XTokenList.find(5); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("3250539032590", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(5); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("DISKSERIAL;STATUS=DESTROYED;TYPE=FLASH", TestFileIter->second.ToStdString()); + + // Three X-FOODS variables. + + TestFileIter = TestFile.XTokenList.find(6); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("Lemon Cake", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(6); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("FOODS;STATUS=HIGH", TestFileIter->second); + + TestFileIter = TestFile.XTokenList.find(7); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("Starrey Gazey Pie", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(7); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("FOODS;STATUS=LOW", TestFileIter->second); + + TestFileIter = TestFile.XTokenList.find(8); + ASSERT_NE(TestFile.XTokenList.end(), TestFileIter); + ASSERT_EQ("Cornish Pasties", TestFileIter->second); + + TestFileIter = TestFile.XTokenListTokens.find(8); + ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter); + ASSERT_EQ("FOODS;STATUS=FAVOURITE;TYPE=CHEESEANDONION", TestFileIter->second.ToStdString()); + +} \ No newline at end of file