Home | News | Projects | Releases
Bugs | RFE | Repositories | Help
ContactLoad Unit Tests: Partial split of tests to Given/When/Then format
[xestiaab/.git] / source / tests / xestiaab_contactload.h
index 09e4c4a..9239d5e 100644 (file)
@@ -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.
 //
 // with Xestia Address Book. If not, see <http://www.gnu.org/licenses/>
 
 #include <gtest/gtest.h>
-#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<int,wxString>::iterator TestFileIter;
-       std::map<int,int>::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<int,wxString>::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<int,wxString>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::iterator testFileIntIter;
+       ContactDataObject testFile;
 
-       std::map<int,wxString>::iterator TestFileIter;
-       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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){
-
-       // Check that the gender has been read.
+TEST(ContactLoad, GivenContactDataObjectWhenNameDisplayAsIsRetrievedThenValueforNameDisplayAsIsReturned)
+{
 
-       ContactDataObject TestFile;
+       // Check the SORT-AS parameter for N.
 
-       // Check that the vCard 4.0 file loads OK.
+       std::map<int,wxString>::iterator testFileIter;
+       std::map<int,int>::iterator testFileIntIter;
+       ContactDataObject testFile;
 
-       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+       // 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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator testFileIter;
+       std::map<int,int>::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<int,wxString>::iterator TestFileIter;
-       std::map<int,int>::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<int,wxString>::iterator TestFileIter;
        std::map<int,int>::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<int,wxString>::iterator TestFileIter;
        std::map<int,int>::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("<a xmlns=\"http://www.w3.org/1999/xhtml\"\\n"
+    "   href=\"http://example.com/\">Example Page 1</a>", 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("<a xmlns=\"http://www.w3.org/1999/xhtml\"\\n"
+    "   href=\"http://example.com/page2.html\">Example Page 2</a>", TestFileIter->second);
+
+       TestFileIter = TestFile.XMLList.find(2);
+       ASSERT_NE(TestFile.XMLList.end(), TestFileIter);
+       ASSERT_EQ("<a xmlns=\"http://www.w3.org/1999/xhtml\"\\n"
+    "   href=\"http://example.com/page3.html\">Example Page 3</a>", TestFileIter->second);
 
 }
 
-TEST(ContactLoad, TimeZoneTests){
+TEST(ContactLoad, NicknameTests){
 
        ContactDataObject TestFile;
 
@@ -385,101 +846,318 @@ TEST(ContactLoad, TimeZoneTests){
        std::map<int,wxString>::iterator TestFileIter;
        std::map<int,int>::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.BusinessTZListPref.find(2);
-       ASSERT_NE(TestFile.BusinessTZListPref.end(), TestFileIntIter);
-       ASSERT_EQ(80, TestFileIntIter->second);
+       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<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::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<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::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<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::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<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::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.
+
+       TestFileIntIter = TestFile.BusinessTZListPref.find(2);
+       ASSERT_NE(TestFile.BusinessTZListPref.end(), TestFileIntIter);
+       ASSERT_EQ(80, TestFileIntIter->second);
 
        // Check the LANGUAGE 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.
        
@@ -766,8 +1444,2636 @@ TEST(ContactLoad, AddressTests){
 
 }
 
-
-TEST(ContactLoad, EmailTests){
+
+TEST(ContactLoad, EmailTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+       
+       // Start with the general email.
+       
+       TestFileIter = TestFile.GeneralEmailList.find(0);
+       ASSERT_NE(TestFile.GeneralEmailList.end(), TestFileIter);
+       ASSERT_EQ("moo@example.com", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralEmailListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralEmailListAltID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralEmailListPID.find(0);
+       ASSERT_NE(TestFile.GeneralEmailListPID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralEmailListPref.find(0);
+       ASSERT_NE(TestFile.GeneralEmailListPref.end(), TestFileIntIter);
+       ASSERT_EQ(40, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralEmailListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralEmailListTokens.end(), TestFileIter);
+       ASSERT_EQ("WONDERFUL=Colour", TestFileIter->second);
+
+       // Start with the home email.
+       
+       TestFileIter = TestFile.HomeEmailList.find(1);
+       ASSERT_NE(TestFile.HomeEmailList.end(), TestFileIter);
+       ASSERT_EQ("moo.home@example.com", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeEmailListAltID.find(1);
+       ASSERT_NE(TestFile.HomeEmailListAltID.end(), TestFileIter);
+       ASSERT_EQ("5", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeEmailListPID.find(1);
+       ASSERT_NE(TestFile.HomeEmailListPID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeEmailListPref.find(1);
+       ASSERT_NE(TestFile.HomeEmailListPref.end(), TestFileIntIter);
+       ASSERT_EQ(20, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeEmailListTokens.find(1);
+       ASSERT_NE(TestFile.HomeEmailListTokens.end(), TestFileIter);
+       ASSERT_EQ("PEACE=quiet", TestFileIter->second);
+
+       // Start with the business email.
+       
+       TestFileIter = TestFile.BusinessEmailList.find(2);
+       ASSERT_NE(TestFile.BusinessEmailList.end(), TestFileIter);
+       ASSERT_EQ("moo.business@example.com", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessEmailListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessEmailListAltID.end(), TestFileIter);
+       ASSERT_EQ("1", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessEmailListPID.find(2);
+       ASSERT_NE(TestFile.BusinessEmailListPID.end(), TestFileIter);
+       ASSERT_EQ("2", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessEmailListPref.find(2);
+       ASSERT_NE(TestFile.BusinessEmailListPref.end(), TestFileIntIter);
+       ASSERT_EQ(3, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessEmailListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessEmailListTokens.end(), TestFileIter);
+       ASSERT_EQ("BUSINESS=Money", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, IMTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+       
+       // Start with the general IM.
+       
+       TestFileIter = TestFile.GeneralIMList.find(0);
+       ASSERT_NE(TestFile.GeneralIMList.end(), TestFileIter);
+       ASSERT_EQ("moo@example.com", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralIMListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralIMListAltID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralIMListPID.find(0);
+       ASSERT_NE(TestFile.GeneralIMListPID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.GeneralIMListMediatype.find(0);
+       ASSERT_NE(TestFile.GeneralIMListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/plain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralIMListPref.find(0);
+       ASSERT_NE(TestFile.GeneralIMListPref.end(), TestFileIntIter);
+       ASSERT_EQ(40, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralIMListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralIMListTokens.end(), TestFileIter);
+       ASSERT_EQ("WONDERFUL=Colour", TestFileIter->second);
+
+       // Start with the home IM.
+       
+       TestFileIter = TestFile.HomeIMList.find(1);
+       ASSERT_NE(TestFile.HomeIMList.end(), TestFileIter);
+       ASSERT_EQ("moo.home@example.com", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeIMListAltID.find(1);
+       ASSERT_NE(TestFile.HomeIMListAltID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeIMListPID.find(1);
+       ASSERT_NE(TestFile.HomeIMListPID.end(), TestFileIter);
+       ASSERT_EQ("40", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.HomeIMListMediatype.find(1);
+       ASSERT_NE(TestFile.HomeIMListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/reallyplain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeIMListPref.find(1);
+       ASSERT_NE(TestFile.HomeIMListPref.end(), TestFileIntIter);
+       ASSERT_EQ(80, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeIMListTokens.find(1);
+       ASSERT_NE(TestFile.HomeIMListTokens.end(), TestFileIter);
+       ASSERT_EQ("PEACE=quiet", TestFileIter->second);
+
+       // Start with the business IM.
+       
+       TestFileIter = TestFile.BusinessIMList.find(2);
+       ASSERT_NE(TestFile.BusinessIMList.end(), TestFileIter);
+       ASSERT_EQ("moo.business@example.com", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessIMListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessIMListAltID.end(), TestFileIter);
+       ASSERT_EQ("98", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessIMListPID.find(2);
+       ASSERT_NE(TestFile.BusinessIMListPID.end(), TestFileIter);
+       ASSERT_EQ("99", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.BusinessIMListMediatype.find(2);
+       ASSERT_NE(TestFile.BusinessIMListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/superplain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessIMListPref.find(2);
+       ASSERT_NE(TestFile.BusinessIMListPref.end(), TestFileIntIter);
+       ASSERT_EQ(50, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessIMListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessIMListTokens.end(), TestFileIter);
+       ASSERT_EQ("BUSINESS=Money", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, TelephoneTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+       
+       // Start with the general Telephone.
+       
+       TestFileIter = TestFile.GeneralTelephoneList.find(0);
+       ASSERT_NE(TestFile.GeneralTelephoneList.end(), TestFileIter);
+       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,cell", TestFileIter->second.ToStdString());      
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralTelephoneListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralTelephoneListAltID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralTelephoneListPID.find(0);
+       ASSERT_NE(TestFile.GeneralTelephoneListPID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralTelephoneListPref.find(0);
+       ASSERT_NE(TestFile.GeneralTelephoneListPref.end(), TestFileIntIter);
+       ASSERT_EQ(40, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralTelephoneListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralTelephoneListTokens.end(), TestFileIter);
+       ASSERT_EQ("WONDERFUL=Colour", TestFileIter->second);
+       
+       // Start with the home Telephone.
+       
+       TestFileIter = TestFile.HomeTelephoneList.find(1);
+       ASSERT_NE(TestFile.HomeTelephoneList.end(), TestFileIter);
+       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.
+       
+       TestFileIter = TestFile.HomeTelephoneListTypeInfo.find(1);
+       ASSERT_NE(TestFile.HomeTelephoneListTypeInfo.end(), TestFileIter);
+       ASSERT_EQ("fax", TestFileIter->second); 
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeTelephoneListAltID.find(1);
+       ASSERT_NE(TestFile.HomeTelephoneListAltID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeTelephoneListPID.find(1);
+       ASSERT_NE(TestFile.HomeTelephoneListPID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeTelephoneListPref.find(1);
+       ASSERT_NE(TestFile.HomeTelephoneListPref.end(), TestFileIntIter);
+       ASSERT_EQ(40, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeTelephoneListTokens.find(1);
+       ASSERT_NE(TestFile.HomeTelephoneListTokens.end(), TestFileIter);
+       ASSERT_EQ("BUSINESS=Money", TestFileIter->second);
+
+       // Start with the business Telephone.
+       
+       TestFileIter = TestFile.BusinessTelephoneList.find(2);
+       ASSERT_NE(TestFile.BusinessTelephoneList.end(), TestFileIter);
+       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.
+       
+       TestFileIter = TestFile.BusinessTelephoneListTypeInfo.find(2);
+       ASSERT_NE(TestFile.BusinessTelephoneListTypeInfo.end(), TestFileIter);
+       ASSERT_EQ("voice", TestFileIter->second);       
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessTelephoneListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessTelephoneListAltID.end(), TestFileIter);
+       ASSERT_EQ("25", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessTelephoneListPID.find(2);
+       ASSERT_NE(TestFile.BusinessTelephoneListPID.end(), TestFileIter);
+       ASSERT_EQ("50", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessTelephoneListPref.find(2);
+       ASSERT_NE(TestFile.BusinessTelephoneListPref.end(), TestFileIntIter);
+       ASSERT_EQ(75, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessTelephoneListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessTelephoneListTokens.end(), TestFileIter);
+       ASSERT_EQ("BEEP=Boop", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, LanguageTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+       
+       // Start with the general language.
+       
+       TestFileIter = TestFile.GeneralLanguageList.find(0);
+       ASSERT_NE(TestFile.GeneralLanguageList.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralLanguageListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralLanguageListAltID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralLanguageListPID.find(0);
+       ASSERT_NE(TestFile.GeneralLanguageListPID.end(), TestFileIter);
+       ASSERT_EQ("40", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralLanguageListPref.find(0);
+       ASSERT_NE(TestFile.GeneralLanguageListPref.end(), TestFileIntIter);
+       ASSERT_EQ(80, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralLanguageListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralLanguageListTokens.end(), TestFileIter);
+       ASSERT_EQ("GELFORN=Great", TestFileIter->second);
+       
+       // Start with the home language.
+       
+       TestFileIter = TestFile.HomeLanguageList.find(1);
+       ASSERT_NE(TestFile.HomeLanguageList.end(), TestFileIter);
+       ASSERT_EQ("en", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeLanguageListAltID.find(1);
+       ASSERT_NE(TestFile.HomeLanguageListAltID.end(), TestFileIter);
+       ASSERT_EQ("22", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeLanguageListPID.find(1);
+       ASSERT_NE(TestFile.HomeLanguageListPID.end(), TestFileIter);
+       ASSERT_EQ("45", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeLanguageListPref.find(1);
+       ASSERT_NE(TestFile.HomeLanguageListPref.end(), TestFileIntIter);
+       ASSERT_EQ(90, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeLanguageListTokens.find(1);
+       ASSERT_NE(TestFile.HomeLanguageListTokens.end(), TestFileIter);
+       ASSERT_EQ("LANGUAGE=yes", TestFileIter->second);
+
+       // Start with the business language.
+       
+       TestFileIter = TestFile.BusinessLanguageList.find(2);
+       ASSERT_NE(TestFile.BusinessLanguageList.end(), TestFileIter);
+       ASSERT_EQ("cy", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessLanguageListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessLanguageListAltID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessLanguageListPID.find(2);
+       ASSERT_NE(TestFile.BusinessLanguageListPID.end(), TestFileIter);
+       ASSERT_EQ("15", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessLanguageListPref.find(2);
+       ASSERT_NE(TestFile.BusinessLanguageListPref.end(), TestFileIntIter);
+       ASSERT_EQ(20, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessLanguageListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessLanguageListTokens.end(), TestFileIter);
+       ASSERT_EQ("FFENSTRI=ie", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, GeographicTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+       
+       // Start with the general Geoposition.
+       
+       TestFileIter = TestFile.GeneralGeographyList.find(0);
+       ASSERT_NE(TestFile.GeneralGeographyList.end(), TestFileIter);
+       ASSERT_EQ("3.5,3.5", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralGeographyListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralGeographyListAltID.end(), TestFileIter);
+       ASSERT_EQ("13", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralGeographyListPID.find(0);
+       ASSERT_NE(TestFile.GeneralGeographyListPID.end(), TestFileIter);
+       ASSERT_EQ("26", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.GeneralGeographyListMediatype.find(0);
+       ASSERT_NE(TestFile.GeneralGeographyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/plain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralGeographyListPref.find(0);
+       ASSERT_NE(TestFile.GeneralGeographyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(39, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralGeographyListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralGeographyListTokens.end(), TestFileIter);
+       ASSERT_EQ("POS=Yep", TestFileIter->second);
+
+       // Start with the home Geoposition.
+       
+       TestFileIter = TestFile.HomeGeographyList.find(1);
+       ASSERT_NE(TestFile.HomeGeographyList.end(), TestFileIter);
+       ASSERT_EQ("7.0,7.0", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeGeographyListAltID.find(1);
+       ASSERT_NE(TestFile.HomeGeographyListAltID.end(), TestFileIter);
+       ASSERT_EQ("140", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeGeographyListPID.find(1);
+       ASSERT_NE(TestFile.HomeGeographyListPID.end(), TestFileIter);
+       ASSERT_EQ("70", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.HomeGeographyListMediatype.find(1);
+       ASSERT_NE(TestFile.HomeGeographyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/ratherplain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeGeographyListPref.find(1);
+       ASSERT_NE(TestFile.HomeGeographyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(1, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeGeographyListTokens.find(1);
+       ASSERT_NE(TestFile.HomeGeographyListTokens.end(), TestFileIter);
+       ASSERT_EQ("POS=Nope", TestFileIter->second);
+
+       // Start with the business Geoposition.
+       
+       TestFileIter = TestFile.BusinessGeographyList.find(2);
+       ASSERT_NE(TestFile.BusinessGeographyList.end(), TestFileIter);
+       ASSERT_EQ("14.0,14.0", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessGeographyListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessGeographyListAltID.end(), TestFileIter);
+       ASSERT_EQ("75", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessGeographyListPID.find(2);
+       ASSERT_NE(TestFile.BusinessGeographyListPID.end(), TestFileIter);
+       ASSERT_EQ("32", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.BusinessGeographyListMediatype.find(2);
+       ASSERT_NE(TestFile.BusinessGeographyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/greenplain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessGeographyListPref.find(2);
+       ASSERT_NE(TestFile.BusinessGeographyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(4, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessGeographyListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessGeographyListTokens.end(), TestFileIter);
+       ASSERT_EQ("POS=Money", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, RelatedTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+       
+       // Start with the first relation.
+       
+       TestFileIter = TestFile.GeneralRelatedList.find(0);
+       ASSERT_NE(TestFile.GeneralRelatedList.end(), TestFileIter);
+       ASSERT_EQ("Friend Test", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.GeneralRelatedListType.find(0);
+       ASSERT_NE(TestFile.GeneralRelatedListType.end(), TestFileIter);
+       ASSERT_EQ("Kin", TestFileIter->second);
+
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralRelatedListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralRelatedListAltID.end(), TestFileIter);
+       ASSERT_EQ("5", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralRelatedListPID.find(0);
+       ASSERT_NE(TestFile.GeneralRelatedListPID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+               
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralRelatedListPref.find(0);
+       ASSERT_NE(TestFile.GeneralRelatedListPref.end(), TestFileIntIter);
+       ASSERT_EQ(20, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralRelatedListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralRelatedListTokens.end(), TestFileIter);
+       ASSERT_EQ("OPTION=Yes", TestFileIter->second);
+
+       // Start with the second relation.
+       
+       TestFileIter = TestFile.GeneralRelatedList.find(1);
+       ASSERT_NE(TestFile.GeneralRelatedList.end(), TestFileIter);
+       ASSERT_EQ("Friend Test Two", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.GeneralRelatedListType.find(1);
+       ASSERT_NE(TestFile.GeneralRelatedListType.end(), TestFileIter);
+       ASSERT_EQ("Spouse", TestFileIter->second);
+
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralRelatedListAltID.find(1);
+       ASSERT_NE(TestFile.GeneralRelatedListAltID.end(), TestFileIter);
+       ASSERT_EQ("1", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralRelatedListPID.find(1);
+       ASSERT_NE(TestFile.GeneralRelatedListPID.end(), TestFileIter);
+       ASSERT_EQ("2", TestFileIter->second);
+               
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralRelatedListPref.find(1);
+       ASSERT_NE(TestFile.GeneralRelatedListPref.end(), TestFileIntIter);
+       ASSERT_EQ(3, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralRelatedListTokens.find(1);
+       ASSERT_NE(TestFile.GeneralRelatedListTokens.end(), TestFileIter);
+       ASSERT_EQ("OPTION=No", TestFileIter->second);
+       
+       // Start with the second relation.
+       
+       TestFileIter = TestFile.GeneralRelatedList.find(2);
+       ASSERT_NE(TestFile.GeneralRelatedList.end(), TestFileIter);
+       ASSERT_EQ("Friend Test Three", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.GeneralRelatedListType.find(2);
+       ASSERT_NE(TestFile.GeneralRelatedListType.end(), TestFileIter);
+       ASSERT_EQ("Muse", TestFileIter->second);
+
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralRelatedListAltID.find(2);
+       ASSERT_NE(TestFile.GeneralRelatedListAltID.end(), TestFileIter);
+       ASSERT_EQ("4", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralRelatedListPID.find(2);
+       ASSERT_NE(TestFile.GeneralRelatedListPID.end(), TestFileIter);
+       ASSERT_EQ("5", TestFileIter->second);
+               
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralRelatedListPref.find(2);
+       ASSERT_NE(TestFile.GeneralRelatedListPref.end(), TestFileIntIter);
+       ASSERT_EQ(6, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralRelatedListTokens.find(2);
+       ASSERT_NE(TestFile.GeneralRelatedListTokens.end(), TestFileIter);
+       ASSERT_EQ("OPTION=Maybe", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, URLTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with the general URL.
+       
+       TestFileIter = TestFile.GeneralWebsiteList.find(0);
+       ASSERT_NE(TestFile.GeneralWebsiteList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralWebsiteListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralWebsiteListAltID.end(), TestFileIter);
+       ASSERT_EQ("0", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralWebsiteListPID.find(0);
+       ASSERT_NE(TestFile.GeneralWebsiteListPID.end(), TestFileIter);
+       ASSERT_EQ("1", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.GeneralWebsiteListMediatype.find(0);
+       ASSERT_NE(TestFile.GeneralWebsiteListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/plain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralWebsiteListPref.find(0);
+       ASSERT_NE(TestFile.GeneralWebsiteListPref.end(), TestFileIntIter);
+       ASSERT_EQ(2, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralWebsiteListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralWebsiteListTokens.end(), TestFileIter);
+       ASSERT_EQ("MEEP=Moo", TestFileIter->second);
+
+       // Start with the home URL.
+
+       TestFileIter = TestFile.HomeWebsiteList.find(1);
+       ASSERT_NE(TestFile.HomeWebsiteList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/home/", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeWebsiteListAltID.find(1);
+       ASSERT_NE(TestFile.HomeWebsiteListAltID.end(), TestFileIter);
+       ASSERT_EQ("10", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeWebsiteListPID.find(1);
+       ASSERT_NE(TestFile.HomeWebsiteListPID.end(), TestFileIter);
+       ASSERT_EQ("11", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.HomeWebsiteListMediatype.find(1);
+       ASSERT_NE(TestFile.HomeWebsiteListMediatype.end(), TestFileIter);
+       ASSERT_EQ("grass/soggy", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeWebsiteListPref.find(1);
+       ASSERT_NE(TestFile.HomeWebsiteListPref.end(), TestFileIntIter);
+       ASSERT_EQ(12, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeWebsiteListTokens.find(1);
+       ASSERT_NE(TestFile.HomeWebsiteListTokens.end(), TestFileIter);
+       ASSERT_EQ("BON=Bon", TestFileIter->second);
+       
+       // Start with the business URL.
+
+       TestFileIter = TestFile.BusinessWebsiteList.find(2);
+       ASSERT_NE(TestFile.BusinessWebsiteList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/business/", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessWebsiteListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessWebsiteListAltID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessWebsiteListPID.find(2);
+       ASSERT_NE(TestFile.BusinessWebsiteListPID.end(), TestFileIter);
+       ASSERT_EQ("21", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.BusinessWebsiteListMediatype.find(2);
+       ASSERT_NE(TestFile.BusinessWebsiteListMediatype.end(), TestFileIter);
+       ASSERT_EQ("chocolate/yummy", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessWebsiteListPref.find(2);
+       ASSERT_NE(TestFile.BusinessWebsiteListPref.end(), TestFileIntIter);
+       ASSERT_EQ(22, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessWebsiteListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessWebsiteListTokens.end(), TestFileIter);
+       ASSERT_EQ("YES=No", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, TitleTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with the general title.
+       
+       TestFileIter = TestFile.GeneralTitleList.find(0);
+       ASSERT_NE(TestFile.GeneralTitleList.end(), TestFileIter);
+       ASSERT_EQ("Lord of Light", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralTitleListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralTitleListAltID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralTitleListPID.find(0);
+       ASSERT_NE(TestFile.GeneralTitleListPID.end(), TestFileIter);
+       ASSERT_EQ("21", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.GeneralTitleListLanguage.find(0);
+       ASSERT_NE(TestFile.GeneralTitleListLanguage.end(), TestFileIter);
+       ASSERT_EQ("text/plain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralTitleListPref.find(0);
+       ASSERT_NE(TestFile.GeneralTitleListPref.end(), TestFileIntIter);
+       ASSERT_EQ(22, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralTitleListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralTitleListTokens.end(), TestFileIter);
+       ASSERT_EQ("EEP=LIGHT", TestFileIter->second);
+
+       // Start with the home title.
+
+       TestFileIter = TestFile.HomeTitleList.find(1);
+       ASSERT_NE(TestFile.HomeTitleList.end(), TestFileIter);
+       ASSERT_EQ("Lord of Darkness", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeTitleListAltID.find(1);
+       ASSERT_NE(TestFile.HomeTitleListAltID.end(), TestFileIter);
+       ASSERT_EQ("30", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeTitleListPID.find(1);
+       ASSERT_NE(TestFile.HomeTitleListPID.end(), TestFileIter);
+       ASSERT_EQ("31", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.HomeTitleListLanguage.find(1);
+       ASSERT_NE(TestFile.HomeTitleListLanguage.end(), TestFileIter);
+       ASSERT_EQ("grass/dry", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeTitleListPref.find(1);
+       ASSERT_NE(TestFile.HomeTitleListPref.end(), TestFileIntIter);
+       ASSERT_EQ(32, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeTitleListTokens.find(1);
+       ASSERT_NE(TestFile.HomeTitleListTokens.end(), TestFileIter);
+       ASSERT_EQ("EEP=DARK", TestFileIter->second);
+       
+       // Start with the business title.
+
+       TestFileIter = TestFile.BusinessTitleList.find(2);
+       ASSERT_NE(TestFile.BusinessTitleList.end(), TestFileIter);
+       ASSERT_EQ("Master of the Light & Darkness", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessTitleListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessTitleListAltID.end(), TestFileIter);
+       ASSERT_EQ("40", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessTitleListPID.find(2);
+       ASSERT_NE(TestFile.BusinessTitleListPID.end(), TestFileIter);
+       ASSERT_EQ("41", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.BusinessTitleListLanguage.find(2);
+       ASSERT_NE(TestFile.BusinessTitleListLanguage.end(), TestFileIter);
+       ASSERT_EQ("moths/eew", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessTitleListPref.find(2);
+       ASSERT_NE(TestFile.BusinessTitleListPref.end(), TestFileIntIter);
+       ASSERT_EQ(42, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessTitleListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessTitleListTokens.end(), TestFileIter);
+       ASSERT_EQ("EEP=BOTH", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, RoleTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with the general role.
+       
+       TestFileIter = TestFile.GeneralRoleList.find(0);
+       ASSERT_NE(TestFile.GeneralRoleList.end(), TestFileIter);
+       ASSERT_EQ("Ordinary Person", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralRoleListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralRoleListAltID.end(), TestFileIter);
+       ASSERT_EQ("50", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralRoleListPID.find(0);
+       ASSERT_NE(TestFile.GeneralRoleListPID.end(), TestFileIter);
+       ASSERT_EQ("51", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.GeneralRoleListLanguage.find(0);
+       ASSERT_NE(TestFile.GeneralRoleListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralRoleListPref.find(0);
+       ASSERT_NE(TestFile.GeneralRoleListPref.end(), TestFileIntIter);
+       ASSERT_EQ(52, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralRoleListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralRoleListTokens.end(), TestFileIter);
+       ASSERT_EQ("ASTERISK=None", TestFileIter->second);
+
+       // Start with the home role.
+
+       TestFileIter = TestFile.HomeRoleList.find(1);
+       ASSERT_NE(TestFile.HomeRoleList.end(), TestFileIter);
+       ASSERT_EQ("Ordinary Lazy Person", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeRoleListAltID.find(1);
+       ASSERT_NE(TestFile.HomeRoleListAltID.end(), TestFileIter);
+       ASSERT_EQ("60", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeRoleListPID.find(1);
+       ASSERT_NE(TestFile.HomeRoleListPID.end(), TestFileIter);
+       ASSERT_EQ("61", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.HomeRoleListLanguage.find(1);
+       ASSERT_NE(TestFile.HomeRoleListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en-GB", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeRoleListPref.find(1);
+       ASSERT_NE(TestFile.HomeRoleListPref.end(), TestFileIntIter);
+       ASSERT_EQ(62, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeRoleListTokens.find(1);
+       ASSERT_NE(TestFile.HomeRoleListTokens.end(), TestFileIter);
+       ASSERT_EQ("SOMEWHERE=There", TestFileIter->second);
+       
+       // Start with the business role.
+
+       TestFileIter = TestFile.BusinessRoleList.find(2);
+       ASSERT_NE(TestFile.BusinessRoleList.end(), TestFileIter);
+       ASSERT_EQ("Company Owner", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessRoleListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessRoleListAltID.end(), TestFileIter);
+       ASSERT_EQ("70", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessRoleListPID.find(2);
+       ASSERT_NE(TestFile.BusinessRoleListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.BusinessRoleListLanguage.find(2);
+       ASSERT_NE(TestFile.BusinessRoleListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en-AU", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessRoleListPref.find(2);
+       ASSERT_NE(TestFile.BusinessRoleListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessRoleListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessRoleListTokens.end(), TestFileIter);
+       ASSERT_EQ("HERE=Nope", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, OrganisationTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with the general organisation.
+       
+       TestFileIter = TestFile.GeneralOrganisationsList.find(0);
+       ASSERT_NE(TestFile.GeneralOrganisationsList.end(), TestFileIter);
+       ASSERT_EQ("Ordinary Organisation", TestFileIter->second);
+       
+       // Check the SORT-AS section.
+
+       TestFileIter = TestFile.GeneralOrganisationsListSortAs.find(0);
+       ASSERT_NE(TestFile.GeneralOrganisationsListSortAs.end(), TestFileIter);
+       ASSERT_EQ("Organisation, Ordinary", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralOrganisationsListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralOrganisationsListAltID.end(), TestFileIter);
+       ASSERT_EQ("50", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralOrganisationsListPID.find(0);
+       ASSERT_NE(TestFile.GeneralOrganisationsListPID.end(), TestFileIter);
+       ASSERT_EQ("51", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.GeneralOrganisationsListLanguage.find(0);
+       ASSERT_NE(TestFile.GeneralOrganisationsListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralOrganisationsListPref.find(0);
+       ASSERT_NE(TestFile.GeneralOrganisationsListPref.end(), TestFileIntIter);
+       ASSERT_EQ(52, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralOrganisationsListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralOrganisationsListTokens.end(), TestFileIter);
+       ASSERT_EQ("ASTERISK=None", TestFileIter->second);
+
+       // Start with the home Organisation.
+
+       TestFileIter = TestFile.HomeOrganisationsList.find(1);
+       ASSERT_NE(TestFile.HomeOrganisationsList.end(), TestFileIter);
+       ASSERT_EQ("Ordinary Lazy Person", TestFileIter->second);
+       
+       // Check the SORT-AS section.
+       
+       TestFileIter = TestFile.HomeOrganisationsListSortAs.find(1);
+       ASSERT_NE(TestFile.HomeOrganisationsListSortAs.end(), TestFileIter);
+       ASSERT_EQ("Person, Ordinary Lazy", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeOrganisationsListAltID.find(1);
+       ASSERT_NE(TestFile.HomeOrganisationsListAltID.end(), TestFileIter);
+       ASSERT_EQ("60", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeOrganisationsListPID.find(1);
+       ASSERT_NE(TestFile.HomeOrganisationsListPID.end(), TestFileIter);
+       ASSERT_EQ("61", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.HomeOrganisationsListLanguage.find(1);
+       ASSERT_NE(TestFile.HomeOrganisationsListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en-GB", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeOrganisationsListPref.find(1);
+       ASSERT_NE(TestFile.HomeOrganisationsListPref.end(), TestFileIntIter);
+       ASSERT_EQ(62, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeOrganisationsListTokens.find(1);
+       ASSERT_NE(TestFile.HomeOrganisationsListTokens.end(), TestFileIter);
+       ASSERT_EQ("SOMEWHERE=There", TestFileIter->second);
+       
+       // Start with the business Organisation.
+
+       TestFileIter = TestFile.BusinessOrganisationsList.find(2);
+       ASSERT_NE(TestFile.BusinessOrganisationsList.end(), TestFileIter);
+       ASSERT_EQ("Company Owner", TestFileIter->second);
+       
+       // Check the SORT-AS section.
+       
+       TestFileIter = TestFile.BusinessOrganisationsListSortAs.find(2);
+       ASSERT_NE(TestFile.BusinessOrganisationsListSortAs.end(), TestFileIter);
+       ASSERT_EQ("Owner, Company", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessOrganisationsListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessOrganisationsListAltID.end(), TestFileIter);
+       ASSERT_EQ("70", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessOrganisationsListPID.find(2);
+       ASSERT_NE(TestFile.BusinessOrganisationsListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.BusinessOrganisationsListLanguage.find(2);
+       ASSERT_NE(TestFile.BusinessOrganisationsListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en-AU", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessOrganisationsListPref.find(2);
+       ASSERT_NE(TestFile.BusinessOrganisationsListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessOrganisationsListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessOrganisationsListTokens.end(), TestFileIter);
+       ASSERT_EQ("HERE=Nope", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, NoteTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+       
+       // Start with the general note.
+       
+       TestFileIter = TestFile.GeneralNoteList.find(0);
+       ASSERT_NE(TestFile.GeneralNoteList.end(), TestFileIter);
+       ASSERT_EQ("Note\n\nLine 3\nLine 4\nLine 5", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.GeneralNoteListAltID.find(0);
+       ASSERT_NE(TestFile.GeneralNoteListAltID.end(), TestFileIter);
+       ASSERT_EQ("90", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.GeneralNoteListPID.find(0);
+       ASSERT_NE(TestFile.GeneralNoteListPID.end(), TestFileIter);
+       ASSERT_EQ("91", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.GeneralNoteListLanguage.find(0);
+       ASSERT_NE(TestFile.GeneralNoteListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.GeneralNoteListPref.find(0);
+       ASSERT_NE(TestFile.GeneralNoteListPref.end(), TestFileIntIter);
+       ASSERT_EQ(92, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.GeneralNoteListTokens.find(0);
+       ASSERT_NE(TestFile.GeneralNoteListTokens.end(), TestFileIter);
+       ASSERT_EQ("WOO=WOOP", TestFileIter->second);
+
+       // Start with the home note.
+       
+       TestFileIter = TestFile.HomeNoteList.find(1);
+       ASSERT_NE(TestFile.HomeNoteList.end(), TestFileIter);
+       ASSERT_EQ("Note\n\n\n\nLine 5\nLine 6\nLine 7", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.HomeNoteListAltID.find(1);
+       ASSERT_NE(TestFile.HomeNoteListAltID.end(), TestFileIter);
+       ASSERT_EQ("80", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.HomeNoteListPID.find(1);
+       ASSERT_NE(TestFile.HomeNoteListPID.end(), TestFileIter);
+       ASSERT_EQ("81", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.HomeNoteListLanguage.find(1);
+       ASSERT_NE(TestFile.HomeNoteListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.HomeNoteListPref.find(1);
+       ASSERT_NE(TestFile.HomeNoteListPref.end(), TestFileIntIter);
+       ASSERT_EQ(82, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.HomeNoteListTokens.find(1);
+       ASSERT_NE(TestFile.HomeNoteListTokens.end(), TestFileIter);
+       ASSERT_EQ("MOO=MEEP", TestFileIter->second);
+
+       // Start with the business note.
+       
+       TestFileIter = TestFile.BusinessNoteList.find(2);
+       ASSERT_NE(TestFile.BusinessNoteList.end(), TestFileIter);
+       ASSERT_EQ("Note\n\n\n\nLine 8\nLine 9\nLine 10", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.BusinessNoteListAltID.find(2);
+       ASSERT_NE(TestFile.BusinessNoteListAltID.end(), TestFileIter);
+       ASSERT_EQ("70", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.BusinessNoteListPID.find(2);
+       ASSERT_NE(TestFile.BusinessNoteListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.BusinessNoteListLanguage.find(2);
+       ASSERT_NE(TestFile.BusinessNoteListLanguage.end(), TestFileIter);
+       ASSERT_EQ("fr", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.BusinessNoteListPref.find(2);
+       ASSERT_NE(TestFile.BusinessNoteListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.BusinessNoteListTokens.find(2);
+       ASSERT_NE(TestFile.BusinessNoteListTokens.end(), TestFileIter);
+       ASSERT_EQ("BOING=BOOP", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, CategoryTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;    
+
+       // Start with the first category.
+       
+       TestFileIter = TestFile.CategoriesList.find(0);
+       ASSERT_NE(TestFile.CategoriesList.end(), TestFileIter);
+       ASSERT_EQ("Category One", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.CategoriesListType.find(0);
+       ASSERT_EQ(TestFile.CategoriesListType.end(), TestFileIter);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.CategoriesListAltID.find(0);
+       ASSERT_NE(TestFile.CategoriesListAltID.end(), TestFileIter);
+       ASSERT_EQ("40", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.CategoriesListPID.find(0);
+       ASSERT_NE(TestFile.CategoriesListPID.end(), TestFileIter);
+       ASSERT_EQ("41", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.CategoriesListLanguage.find(0);
+       ASSERT_NE(TestFile.CategoriesListLanguage.end(), TestFileIter);
+       ASSERT_EQ("en", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.CategoriesListPref.find(0);
+       ASSERT_NE(TestFile.CategoriesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(42, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.CategoriesListTokens.find(0);
+       ASSERT_NE(TestFile.CategoriesListTokens.end(), TestFileIter);
+       ASSERT_EQ("CAT=TAC", TestFileIter->second);
+       
+       // Start with the second & third category.
+       // (Category Two, Category Three).
+       
+       TestFileIter = TestFile.CategoriesList.find(1);
+       ASSERT_NE(TestFile.CategoriesList.end(), TestFileIter);
+       ASSERT_EQ("Category Two", TestFileIter->second);
+       
+       TestFileIter = TestFile.CategoriesList.find(2);
+       ASSERT_NE(TestFile.CategoriesList.end(), TestFileIter);
+       ASSERT_EQ("Category Three", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.CategoriesListType.find(1);
+       ASSERT_NE(TestFile.CategoriesListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListType.find(2);
+       ASSERT_NE(TestFile.CategoriesListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.CategoriesListAltID.find(1);
+       ASSERT_NE(TestFile.CategoriesListAltID.end(), TestFileIter);
+       ASSERT_EQ("44", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListAltID.find(2);
+       ASSERT_NE(TestFile.CategoriesListAltID.end(), TestFileIter);
+       ASSERT_EQ("44", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.CategoriesListPID.find(1);
+       ASSERT_NE(TestFile.CategoriesListPID.end(), TestFileIter);
+       ASSERT_EQ("46", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListPID.find(2);
+       ASSERT_NE(TestFile.CategoriesListPID.end(), TestFileIter);
+       ASSERT_EQ("46", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.CategoriesListLanguage.find(1);
+       ASSERT_NE(TestFile.CategoriesListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       TestFileIter = TestFile.CategoriesListLanguage.find(2);
+       ASSERT_NE(TestFile.CategoriesListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.CategoriesListPref.find(1);
+       ASSERT_NE(TestFile.CategoriesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(48, TestFileIntIter->second);
+       
+       TestFileIntIter = TestFile.CategoriesListPref.find(2);
+       ASSERT_NE(TestFile.CategoriesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(48, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.CategoriesListTokens.find(1);
+       ASSERT_NE(TestFile.CategoriesListTokens.end(), TestFileIter);
+       ASSERT_EQ("TAC=CAT", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListTokens.find(2);
+       ASSERT_NE(TestFile.CategoriesListTokens.end(), TestFileIter);
+       ASSERT_EQ("TAC=CAT", TestFileIter->second);
+
+       // Start with the third, fourth & fifth category.
+       // (Category Three,Category Four,Category Five).
+       
+       TestFileIter = TestFile.CategoriesList.find(3);
+       ASSERT_NE(TestFile.CategoriesList.end(), TestFileIter);
+       ASSERT_EQ("Category Four", TestFileIter->second.ToStdString());
+       
+       TestFileIter = TestFile.CategoriesList.find(4);
+       ASSERT_NE(TestFile.CategoriesList.end(), TestFileIter);
+       ASSERT_EQ("Category Five", TestFileIter->second.ToStdString());
+
+       TestFileIter = TestFile.CategoriesList.find(5);
+       ASSERT_NE(TestFile.CategoriesList.end(), TestFileIter);
+       ASSERT_EQ("Category Six", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.CategoriesListType.find(3);
+       ASSERT_NE(TestFile.CategoriesListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListType.find(4);
+       ASSERT_NE(TestFile.CategoriesListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
+       TestFileIter = TestFile.CategoriesListType.find(5);
+       ASSERT_NE(TestFile.CategoriesListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.CategoriesListAltID.find(3);
+       ASSERT_NE(TestFile.CategoriesListAltID.end(), TestFileIter);
+       ASSERT_EQ("84", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListAltID.find(4);
+       ASSERT_NE(TestFile.CategoriesListAltID.end(), TestFileIter);
+       ASSERT_EQ("84", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListAltID.find(5);
+       ASSERT_NE(TestFile.CategoriesListAltID.end(), TestFileIter);
+       ASSERT_EQ("84", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.CategoriesListPID.find(3);
+       ASSERT_NE(TestFile.CategoriesListPID.end(), TestFileIter);
+       ASSERT_EQ("86", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListPID.find(4);
+       ASSERT_NE(TestFile.CategoriesListPID.end(), TestFileIter);
+       ASSERT_EQ("86", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListPID.find(5);
+       ASSERT_NE(TestFile.CategoriesListPID.end(), TestFileIter);
+       ASSERT_EQ("86", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.CategoriesListLanguage.find(3);
+       ASSERT_NE(TestFile.CategoriesListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       TestFileIter = TestFile.CategoriesListLanguage.find(4);
+       ASSERT_NE(TestFile.CategoriesListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       TestFileIter = TestFile.CategoriesListLanguage.find(5);
+       ASSERT_NE(TestFile.CategoriesListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.CategoriesListPref.find(3);
+       ASSERT_NE(TestFile.CategoriesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(88, TestFileIntIter->second);
+       
+       TestFileIntIter = TestFile.CategoriesListPref.find(4);
+       ASSERT_NE(TestFile.CategoriesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(88, TestFileIntIter->second);
+       
+       TestFileIntIter = TestFile.CategoriesListPref.find(5);
+       ASSERT_NE(TestFile.CategoriesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(88, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.CategoriesListTokens.find(3);
+       ASSERT_NE(TestFile.CategoriesListTokens.end(), TestFileIter);
+       ASSERT_EQ("AAA=BBB", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListTokens.find(4);
+       ASSERT_NE(TestFile.CategoriesListTokens.end(), TestFileIter);
+       ASSERT_EQ("AAA=BBB", TestFileIter->second);
+
+       TestFileIter = TestFile.CategoriesListTokens.find(4);
+       ASSERT_NE(TestFile.CategoriesListTokens.end(), TestFileIter);
+       ASSERT_EQ("AAA=BBB", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, PhotoTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,std::string>::iterator TestStrIter;
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;    
+
+       // Start with the first photo.
+       
+       TestStrIter = TestFile.PicturesList.find(0);
+       ASSERT_NE(TestFile.PicturesList.end(), TestStrIter);
+       ASSERT_EQ("iVBORw0KGgoAAAANSUhEUgAAABEAAAAKCAIAAADdHiL1AAAAJUlEQVQoz2NkwAb+//8PYTAyMmLKMjGQDuilhxHudBrbM8zCDQCxHQkPeaUvawAAAABJRU5ErkJggg==", 
+               TestStrIter->second);
+
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.PicturesListPicEncType.find(0);
+       ASSERT_NE(TestFile.PicturesListPicEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.PicturesListPictureType.find(0);
+       ASSERT_NE(TestFile.PicturesListPictureType.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.PicturesListAltID.find(0);
+       ASSERT_NE(TestFile.PicturesListAltID.end(), TestFileIter);
+       ASSERT_EQ("70", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.PicturesListPID.find(0);
+       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);
+       ASSERT_NE(TestFile.PicturesListMediatype.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.PicturesListPref.find(0);
+       ASSERT_NE(TestFile.PicturesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.PicturesListTokens.find(0);
+       ASSERT_NE(TestFile.PicturesListTokens.end(), TestFileIter);
+       ASSERT_EQ("MEEP=MOO", TestFileIter->second);
+       
+       // Start with the second photo.
+       
+       TestStrIter = TestFile.PicturesList.find(1);
+       ASSERT_NE(TestFile.PicturesList.end(), TestStrIter);
+       ASSERT_EQ("iVBORw0KGgoAAAANSUhEUgAAABEAAAAKCAIAAADdHiL1AAAAHklEQVQoz2NkYPjPgAr+owkwMqIpYGIgHYzqGdx6AAKNAxMN5P6+AAAAAElFTkSuQmCC", 
+               TestStrIter->second);
+
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.PicturesListPicEncType.find(1);
+       ASSERT_NE(TestFile.PicturesListPicEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.PicturesListPictureType.find(1);
+       ASSERT_NE(TestFile.PicturesListPictureType.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.PicturesListAltID.find(1);
+       ASSERT_NE(TestFile.PicturesListAltID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.PicturesListPID.find(1);
+       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);
+       ASSERT_NE(TestFile.PicturesListMediatype.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.PicturesListPref.find(1);
+       ASSERT_NE(TestFile.PicturesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(22, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.PicturesListTokens.find(1);
+       ASSERT_NE(TestFile.PicturesListTokens.end(), TestFileIter);
+       ASSERT_EQ("BEEP=BOOP", TestFileIter->second);
+
+       // Start with the second photo.
+       
+       TestStrIter = TestFile.PicturesList.find(2);
+       ASSERT_NE(TestFile.PicturesList.end(), TestStrIter);
+       ASSERT_EQ("iVBORw0KGgoAAAANSUhEUgAAABEAAAAKCAIAAADdHiL1AAAAIElEQVQoz2MUm53EgApepsxF4XfaoylgYiAdjOoZ3HoAeuQD2WdxRzcAAAAASUVORK5CYII=", 
+               TestStrIter->second);
+
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.PicturesListPicEncType.find(2);
+       ASSERT_NE(TestFile.PicturesListPicEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.PicturesListPictureType.find(2);
+       ASSERT_NE(TestFile.PicturesListPictureType.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.PicturesListAltID.find(2);
+       ASSERT_NE(TestFile.PicturesListAltID.end(), TestFileIter);
+       ASSERT_EQ("90", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.PicturesListPID.find(2);
+       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);
+       ASSERT_NE(TestFile.PicturesListMediatype.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.PicturesListPref.find(2);
+       ASSERT_NE(TestFile.PicturesListPref.end(), TestFileIntIter);
+       ASSERT_EQ(92, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.PicturesListTokens.find(2);
+       ASSERT_NE(TestFile.PicturesListTokens.end(), TestFileIter);
+       ASSERT_EQ("PHOTO=YUP", TestFileIter->second);
+       
+}
+
+TEST(ContactLoad, LogoTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,std::string>::iterator TestStrIter;
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;    
+
+       // Start with the first photo.
+       
+       TestStrIter = TestFile.LogosList.find(0);
+       ASSERT_NE(TestFile.LogosList.end(), TestStrIter);
+       ASSERT_EQ("iVBORw0KGgoAAAANSUhEUgAAABEAAAAKCAIAAADdHiL1AAAAJUlEQVQoz2NkwAb+//8PYTAyMmLKMjGQDuilhxHudBrbM8zCDQCxHQkPeaUvawAAAABJRU5ErkJggg==", 
+               TestStrIter->second);
+
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.LogosListPicEncType.find(0);
+       ASSERT_NE(TestFile.LogosListPicEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.LogosListPictureType.find(0);
+       ASSERT_NE(TestFile.LogosListPictureType.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.LogosListAltID.find(0);
+       ASSERT_NE(TestFile.LogosListAltID.end(), TestFileIter);
+       ASSERT_EQ("70", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.LogosListPID.find(0);
+       ASSERT_NE(TestFile.LogosListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
+       
+       // Check the TYPE section.
+               
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.LogosListMediatype.find(0);
+       ASSERT_NE(TestFile.LogosListMediatype.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.LogosListPref.find(0);
+       ASSERT_NE(TestFile.LogosListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.LogosListTokens.find(0);
+       ASSERT_NE(TestFile.LogosListTokens.end(), TestFileIter);
+       ASSERT_EQ("MEEP=MOO", TestFileIter->second);
+       
+       // Start with the second photo.
+       
+       TestStrIter = TestFile.LogosList.find(1);
+       ASSERT_NE(TestFile.LogosList.end(), TestStrIter);
+       ASSERT_EQ("iVBORw0KGgoAAAANSUhEUgAAABEAAAAKCAIAAADdHiL1AAAAHklEQVQoz2NkYPjPgAr+owkwMqIpYGIgHYzqGdx6AAKNAxMN5P6+AAAAAElFTkSuQmCC", 
+               TestStrIter->second);
+
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.LogosListPicEncType.find(1);
+       ASSERT_NE(TestFile.LogosListPicEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.LogosListPictureType.find(1);
+       ASSERT_NE(TestFile.LogosListPictureType.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.LogosListAltID.find(1);
+       ASSERT_NE(TestFile.LogosListAltID.end(), TestFileIter);
+       ASSERT_EQ("20", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       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.
+       
+       TestFileIter = TestFile.LogosListMediatype.find(1);
+       ASSERT_NE(TestFile.LogosListMediatype.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.LogosListPref.find(1);
+       ASSERT_NE(TestFile.LogosListPref.end(), TestFileIntIter);
+       ASSERT_EQ(22, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.LogosListTokens.find(1);
+       ASSERT_NE(TestFile.LogosListTokens.end(), TestFileIter);
+       ASSERT_EQ("BEEP=BOOP", TestFileIter->second);
+
+       // Start with the second photo.
+       
+       TestStrIter = TestFile.LogosList.find(2);
+       ASSERT_NE(TestFile.LogosList.end(), TestStrIter);
+       ASSERT_EQ("iVBORw0KGgoAAAANSUhEUgAAABEAAAAKCAIAAADdHiL1AAAAIElEQVQoz2MUm53EgApepsxF4XfaoylgYiAdjOoZ3HoAeuQD2WdxRzcAAAAASUVORK5CYII=", 
+               TestStrIter->second);
+
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.LogosListPicEncType.find(2);
+       ASSERT_NE(TestFile.LogosListPicEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.LogosListPictureType.find(2);
+       ASSERT_NE(TestFile.LogosListPictureType.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.LogosListAltID.find(2);
+       ASSERT_NE(TestFile.LogosListAltID.end(), TestFileIter);
+       ASSERT_EQ("90", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.LogosListPID.find(2);
+       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);
+       ASSERT_NE(TestFile.LogosListMediatype.end(), TestFileIter);
+       ASSERT_EQ("image/png", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.LogosListPref.find(2);
+       ASSERT_NE(TestFile.LogosListPref.end(), TestFileIntIter);
+       ASSERT_EQ(92, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.LogosListTokens.find(2);
+       ASSERT_NE(TestFile.LogosListTokens.end(), TestFileIter);
+       ASSERT_EQ("LOGO=YUP", TestFileIter->second);
+       
+}
+
+TEST(ContactLoad, SoundTests){
+
+       // Setup the sound files first.
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,std::string>::iterator TestStrIter;
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+
+       // Sound File A: Morse code X.
+
+       std::string SoundA = "T2dnUwACAAAAAAAAAAAqlr5kAAAAAPjSH5UBHgF2b3"
+ "JiaXMAAAAAAUSsAAAAAAAAgLsAAAAAAAC4AU9nZ1MAAAAAAAAAAAAAKpa+ZAEAAAAJVIuhDzz//"
+ "///////////////MgN2b3JiaXMsAAAAWGlwaC5PcmcgbGliVm9yYmlzIEkgMjAxNTAxMDUgKOKb"
+ "hOKbhOKbhOKbhCkAAAAAAQV2b3JiaXMfQkNWAQAAAQAYY1QpRplS0kqJGXOUMUaZYpJKiaWEFkJ"
+ "InXMUU6k515xrrLm1IIQQGlNQKQWZUo5SaRljkCkFmVIQS0kldBI6J51jEFtJwdaYa4tBthyEDZ"
+ "pSTCnElFKKQggZU4wpxZRSSkIHJXQOOuYcU45KKEG4nHOrtZaWY4updJJK5yRkTEJIKYWSSgelU"
+ "05CSDWW1lIpHXNSUmpB6CCEEEK2IIQNgtCQVQAAAQDAQBAasgoAUAAAEIqhGIoChIasAgAyAAAE"
+ "oCiO4iiOIzmSY0kWEBqyCgAAAgAQAADAcBRJkRTJsSRL0ixL00RRVX3VNlVV9nVd13Vd13UgNGQ"
+ "VAAABAEBIp5mlGiDCDGQYCA1ZBQAgAAAARijCEANCQ1YBAAABAABiKDmIJrTmfHOOg2Y5aCrF5n"
+ "RwItXmSW4q5uacc845J5tzxjjnnHOKcmYxaCa05pxzEoNmKWgmtOacc57E5kFrqrTmnHPGOaeDc"
+ "UYY55xzmrTmQWo21uaccxa0pjlqLsXmnHMi5eZJbS7V5pxzzjnnnHPOOeecc6oXp3NwTjjnnHOi"
+ "9uZabkIX55xzPhmne3NCOOecc84555xzzjnnnHOC0JBVAAAQAABBGDaGcacgSJ+jgRhFiGnIpAf"
+ "do8MkaAxyCqlHo6ORUuoglFTGSSmdIDRkFQAACAAAIYQUUkghhRRSSCGFFFKIIYYYYsgpp5yCCi"
+ "qppKKKMsoss8wyyyyzzDLrsLPOOuwwxBBDDK20EktNtdVYY62555xrDtJaaa211koppZRSSikID"
+ "VkFAIAAABAIGWSQQUYhhRRSiCGmnHLKKaigAkJDVgEAgAAAAgAAADzJc0RHdERHdERHdERHdETH"
+ "czxHlERJlERJtEzL1ExPFVXVlV1b1mXd9m1hF3bd93Xf93Xj14VhWZZlWZZlWZZlWZZlWZZlWYL"
+ "QkFUAAAgAAIAQQgghhRRSSCGlGGPMMeegk1BCIDRkFQAACAAgAAAAwFEcxXEkR3IkyZIsSZM0S7"
+ "M8zdM8TfREURRN01RFV3RF3bRF2ZRN13RN2XRVWbVdWbZt2dZtX5Zt3/d93/d93/d93/d93/d1H"
+ "QgNWQUASAAA6EiOpEiKpEiO4ziSJAGhIasAABkAAAEAKIqjOI7jSJIkSZakSZ7lWaJmaqZneqqo"
+ "AqEhqwAAQAAAAQAAAAAAKJriKabiKaLiOaIjSqJlWqKmaq4om7Lruq7ruq7ruq7ruq7ruq7ruq7"
+ "ruq7ruq7ruq7ruq7ruq7rui4QGrIKAJAAANCRHMmRHEmRFEmRHMkBQkNWAQAyAAACAHAMx5AUyb"
+ "EsS9M8zdM8TfRET/RMTxVd0QVCQ1YBAIAAAAIAAAAAADAkw1IsR3M0SZRUS7VUTbVUSxVVT1VVV"
+ "VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVTVN0zRNIDRkJQAABADAYo3B5SAhJSXl3hDC"
+ "EJOeMSYhtV4hBJGS3jEGFYOeMqIMct5C4xCDHggNWREARAEAAMYgxxBzyDlHqZMSOeeodJQa5xy"
+ "ljlJnKcWYYs0oldhSrI1zjlJHraOUYiwtdpRSjanGAgAAAhwAAAIshEJDVgQAUQAAhDFIKaQUYo"
+ "w5p5xDjCnnmHOGMeYcc44556B0UirnnHROSsQYc445p5xzUjonlXNOSiehAACAAAcAgAALodCQF"
+ "QFAnACAQZI8T/I0UZQ0TxRFU3RdUTRd1/I81fRMU1U90VRVU1Vt2VRVWZY8zzQ901RVzzRV1VRV"
+ "WTZVVZZFVdVt03V123RV3ZZt2/ddWxZ2UVVt3VRd2zdV1/Zd2fZ9WdZ1Y/I8VfVM03U903Rl1XV"
+ "tW3VdXfdMU5ZN15Vl03Vt25VlXXdl2fc103Rd01Vl2XRd2XZlV7ddWfZ903WF35VlX1dlWRh2Xf"
+ "eFW9eV5XRd3VdlVzdWWfZ9W9eF4dZ1YZk8T1U903RdzzRdV3VdX1dd19Y105Rl03Vt2VRdWXZl2"
+ "fddV9Z1zzRl2XRd2zZdV5ZdWfZ9V5Z13XRdX1dlWfhVV/Z1WdeV4dZt4Tdd1/dVWfaFV5Z14dZ1"
+ "Ybl1XRg+VfV9U3aF4XRl39eF31luXTiW0XV9YZVt4VhlWTl+4ViW3feVZXRdX1ht2RhWWRaGX/i"
+ "d5fZ943h1XRlu3efMuu8Mx++k+8rT1W1jmX3dWWZfd47hGDq/8OOpqq+brisMpywLv+3rxrP7vr"
+ "KMruv7qiwLvyrbwrHrvvP8vrAso+z6wmrLwrDatjHcvm4sv3Acy2vryjHrvlG2dXxfeArD83R1X"
+ "XlmXcf2dXTjRzh+ygAAgAEHAIAAE8pAoSErAoA4AQCPJImiZFmiKFmWKIqm6LqiaLqupGmmqWme"
+ "aVqaZ5qmaaqyKZquLGmaaVqeZpqap5mmaJqua5qmrIqmKcumasqyaZqy7LqybbuubNuiacqyaZq"
+ "ybJqmLLuyq9uu7Oq6pFmmqXmeaWqeZ5qmasqyaZquq3meanqeaKqeKKqqaqqqraqqLFueZ5qa6K"
+ "mmJ4qqaqqmrZqqKsumqtqyaaq2bKqqbbuq7Pqybeu6aaqybaqmLZuqatuu7OqyLNu6L2maaWqeZ"
+ "5qa55mmaZqybJqqK1uep5qeKKqq5ommaqqqLJumqsqW55mqJ4qq6omea5qqKsumatqqaZq2bKqq"
+ "LZumKsuubfu+68qybqqqbJuqauumasqybMu+78qq7oqmKcumqtqyaaqyLduy78uyrPuiacqyaaq"
+ "ybaqqLsuybRuzbPu6aJqybaqmLZuqKtuyLfu6LNu678qub6uqrOuyLfu67vqucOu6MLyybPuqrP"
+ "q6K9u6b+sy2/Z9RNOUZVM1bdtUVVl2Zdn2Zdv2fdE0bVtVVVs2TdW2ZVn2fVm2bWE0Tdk2VVXWT"
+ "dW0bVmWbWG2ZeF2Zdm3ZVv2ddeVdV/XfePXZd3murLty7Kt+6qr+rbu+8Jw667wCgAAGHAAAAgw"
+ "oQwUGrISAIgCAACMYYwxCI1SzjkHoVHKOecgZM5BCCGVzDkIIZSSOQehlJQy5yCUklIIoZSUWgs"
+ "hlJRSawUAABQ4AAAE2KApsThAoSErAYBUAACD41iW55miatqyY0meJ4qqqaq27UiW54miaaqqbV"
+ "ueJ4qmqaqu6+ua54miaaqq6+q6aJqmqaqu67q6Lpqiqaqq67qyrpumqqquK7uy7Oumqqqq68quL"
+ "PvCqrquK8uybevCsKqu68qybNu2b9y6ruu+7/vCka3rui78wjEMRwEA4AkOAEAFNqyOcFI0Flho"
+ "yEoAIAMAgDAGIYMQQgYhhJBSSiGllBIAADDgAAAQYEIZKDRkRQAQJwAAGEMppJRSSimllFJKKaW"
+ "UUkoppZRSSimllFJKKaWUUkgppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllF"
+ "JKKaWUUkqppJRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSS"
+ "imllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkop"
+ "pZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaW"
+ "UUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllF"
+ "JKKaWUUkoplVJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKK"
+ "aWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSCgCQinAAkHowoQwUGrISAEgF"
+ "AACMUUopxpyDEDHmGGPQSSgpYsw5xhyUklLlHIQQUmktt8o5CCGk1FJtmXNSWosx5hgz56SkFFv"
+ "NOYdSUoux5ppr7qS0VmuuNedaWqs115xzzbm0FmuuOdecc8sx15xzzjnnGHPOOeecc84FAOA0OA"
+ "CAHtiwOsJJ0VhgoSErAYBUAAACGaUYc8456BBSjDnnHIQQIoUYc845CCFUjDnnHHQQQqgYc8w5C"
+ "CGEkDnnHIQQQgghcw466CCEEEIHHYQQQgihlM5BCCGEEEooIYQQQgghhBA6CCGEEEIIIYQQQggh"
+ "hFJKCCGEEEIJoZRQAABggQMAQIANqyOcFI0FFhqyEgAAAgCAHJagUs6EQY5Bjw1BylEzDUJMOdG"
+ "ZYk5qMxVTkDkQnXQSGWpB2V4yCwAAgCAAIMAEEBggKPhCCIgxAABBiMwQCYVVsMCgDBoc5gHAA0"
+ "SERACQmKBIu7iALgNc0MVdB0IIQhCCWBxAAQk4OOGGJ97whBucoFNU6iAAAAAAAAwA4AEA4KAAI"
+ "iKaq7C4wMjQ2ODo8AgAAAAAABYA+AAAOD6AiIjmKiwuMDI0Njg6PAIAAAAAAAAAAICAgAAAAAAA"
+ "QAAAAICAT2dnUwAAQIkAAAAAAAAqlr5kAgAAADGopCE+GQ8UFhsYGRoeHXZwbHNsbG55a3B1fkM"
+ "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";
+
+       // Sound B: Morse Code S.
+       
+       std::string SoundB = "T2dnUwACAAAAAAAAAAAoPAxpAAAAAER0X7"
+ "YBHgF2b3JiaXMAAAAAAUSsAAAAAAAAgLsAAAAAAAC4AU9nZ1MAAAAAAAAAAAAAKDwMaQEAAAA2m"
+ "nO/Dzz/////////////////MgN2b3JiaXMsAAAAWGlwaC5PcmcgbGliVm9yYmlzIEkgMjAxNTAx"
+ "MDUgKOKbhOKbhOKbhOKbhCkAAAAAAQV2b3JiaXMfQkNWAQAAAQAYY1QpRplS0kqJGXOUMUaZYpJ"
+ "KiaWEFkJInXMUU6k515xrrLm1IIQQGlNQKQWZUo5SaRljkCkFmVIQS0kldBI6J51jEFtJwdaYa4"
+ "tBthyEDZpSTCnElFKKQggZU4wpxZRSSkIHJXQOOuYcU45KKEG4nHOrtZaWY4updJJK5yRkTEJIK"
+ "YWSSgelU05CSDWW1lIpHXNSUmpB6CCEEEK2IIQNgtCQVQAAAQDAQBAasgoAUAAAEIqhGIoChIas"
+ "AgAyAAAEoCiO4iiOIzmSY0kWEBqyCgAAAgAQAADAcBRJkRTJsSRL0ixL00RRVX3VNlVV9nVd13V"
+ "d13UgNGQVAAABAEBIp5mlGiDCDGQYCA1ZBQAgAAAARijCEANCQ1YBAAABAABiKDmIJrTmfHOOg2"
+ "Y5aCrF5nRwItXmSW4q5uacc845J5tzxjjnnHOKcmYxaCa05pxzEoNmKWgmtOacc57E5kFrqrTmn"
+ "HPGOaeDcUYY55xzmrTmQWo21uaccxa0pjlqLsXmnHMi5eZJbS7V5pxzzjnnnHPOOeecc6oXp3Nw"
+ "TjjnnHOi9uZabkIX55xzPhmne3NCOOecc84555xzzjnnnHOC0JBVAAAQAABBGDaGcacgSJ+jgRh"
+ "FiGnIpAfdo8MkaAxyCqlHo6ORUuoglFTGSSmdIDRkFQAACAAAIYQUUkghhRRSSCGFFFKIIYYYYs"
+ "gpp5yCCiqppKKKMsoss8wyyyyzzDLrsLPOOuwwxBBDDK20EktNtdVYY62555xrDtJaaa211kopp"
+ "ZRSSikIDVkFAIAAABAIGWSQQUYhhRRSiCGmnHLKKaigAkJDVgEAgAAAAgAAADzJc0RHdERHdERH"
+ "dERHdETHczxHlERJlERJtEzL1ExPFVXVlV1b1mXd9m1hF3bd93Xf93Xj14VhWZZlWZZlWZZlWZZ"
+ "lWZZlWYLQkFUAAAgAAIAQQgghhRRSSCGlGGPMMeegk1BCIDRkFQAACAAgAAAAwFEcxXEkR3IkyZ"
+ "IsSZM0S7M8zdM8TfREURRN01RFV3RF3bRF2ZRN13RN2XRVWbVdWbZt2dZtX5Zt3/d93/d93/d93"
+ "/d93/d1HQgNWQUASAAA6EiOpEiKpEiO4ziSJAGhIasAABkAAAEAKIqjOI7jSJIkSZakSZ7lWaJm"
+ "aqZneqqoAqEhqwAAQAAAAQAAAAAAKJriKabiKaLiOaIjSqJlWqKmaq4om7Lruq7ruq7ruq7ruq7"
+ "ruq7ruq7ruq7ruq7ruq7ruq7ruq7rui4QGrIKAJAAANCRHMmRHEmRFEmRHMkBQkNWAQAyAAACAH"
+ "AMx5AUybEsS9M8zdM8TfRET/RMTxVd0QVCQ1YBAIAAAAIAAAAAADAkw1IsR3M0SZRUS7VUTbVUS"
+ "xVVT1VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVTVN0zRNIDRkJQAABADAYo3B5SAh"
+ "JSXl3hDCEJOeMSYhtV4hBJGS3jEGFYOeMqIMct5C4xCDHggNWREARAEAAMYgxxBzyDlHqZMSOee"
+ "odJQa5xyljlJnKcWYYs0oldhSrI1zjlJHraOUYiwtdpRSjanGAgAAAhwAAAIshEJDVgQAUQAAhD"
+ "FIKaQUYow5p5xDjCnnmHOGMeYcc44556B0UirnnHROSsQYc445p5xzUjonlXNOSiehAACAAAcAg"
+ "AALodCQFQFAnACAQZI8T/I0UZQ0TxRFU3RdUTRd1/I81fRMU1U90VRVU1Vt2VRVWZY8zzQ901RV"
+ "zzRV1VRVWTZVVZZFVdVt03V123RV3ZZt2/ddWxZ2UVVt3VRd2zdV1/Zd2fZ9WdZ1Y/I8VfVM03U"
+ "903Rl1XVtW3VdXfdMU5ZN15Vl03Vt25VlXXdl2fc103Rd01Vl2XRd2XZlV7ddWfZ903WF35VlX1"
+ "dlWRh2XfeFW9eV5XRd3VdlVzdWWfZ9W9eF4dZ1YZk8T1U903RdzzRdV3VdX1dd19Y105Rl03Vt2"
+ "VRdWXZl2fddV9Z1zzRl2XRd2zZdV5ZdWfZ9V5Z13XRdX1dlWfhVV/Z1WdeV4dZt4Tdd1/dVWfaF"
+ "V5Z14dZ1Ybl1XRg+VfV9U3aF4XRl39eF31luXTiW0XV9YZVt4VhlWTl+4ViW3feVZXRdX1ht2Rh"
+ "WWRaGX/id5fZ943h1XRlu3efMuu8Mx++k+8rT1W1jmX3dWWZfd47hGDq/8OOpqq+brisMpywLv+"
+ "3rxrP7vrKMruv7qiwLvyrbwrHrvvP8vrAso+z6wmrLwrDatjHcvm4sv3Acy2vryjHrvlG2dXxfe"
+ "ArD83R1XXlmXcf2dXTjRzh+ygAAgAEHAIAAE8pAoSErAoA4AQCPJImiZFmiKFmWKIqm6LqiaLqu"
+ "pGmmqWmeaVqaZ5qmaaqyKZquLGmaaVqeZpqap5mmaJqua5qmrIqmKcumasqyaZqy7LqybbuubNu"
+ "iacqyaZqybJqmLLuyq9uu7Oq6pFmmqXmeaWqeZ5qmasqyaZquq3meanqeaKqeKKqqaqqqraqqLF"
+ "ueZ5qa6KmmJ4qqaqqmrZqqKsumqtqyaaq2bKqqbbuq7Pqybeu6aaqybaqmLZuqatuu7OqyLNu6L"
+ "2maaWqeZ5qa55mmaZqybJqqK1uep5qeKKqq5ommaqqqLJumqsqW55mqJ4qq6omea5qqKsumatqq"
+ "aZq2bKqqLZumKsuubfu+68qybqqqbJuqauumasqybMu+78qq7oqmKcumqtqyaaqyLduy78uyrPu"
+ "iacqyaaqybaqqLsuybRuzbPu6aJqybaqmLZuqKtuyLfu6LNu678qub6uqrOuyLfu67vqucOu6ML"
+ "yybPuqrPq6K9u6b+sy2/Z9RNOUZVM1bdtUVVl2Zdn2Zdv2fdE0bVtVVVs2TdW2ZVn2fVm2bWE0T"
+ "dk2VVXWTdW0bVmWbWG2ZeF2Zdm3ZVv2ddeVdV/XfePXZd3murLty7Kt+6qr+rbu+8Jw667wCgAA"
+ "GHAAAAgwoQwUGrISAIgCAACMYYwxCI1SzjkHoVHKOecgZM5BCCGVzDkIIZSSOQehlJQy5yCUklI"
+ "IoZSUWgshlJRSawUAABQ4AAAE2KApsThAoSErAYBUAACD41iW55miatqyY0meJ4qqqaq27UiW54"
+ "miaaqqbVueJ4qmqaqu6+ua54miaaqq6+q6aJqmqaqu67q6Lpqiqaqq67qyrpumqqquK7uy7Oumq"
+ "qqq68quLPvCqrquK8uybevCsKqu68qybNu2b9y6ruu+7/vCka3rui78wjEMRwEA4AkOAEAFNqyO"
+ "cFI0FlhoyEoAIAMAgDAGIYMQQgYhhJBSSiGllBIAADDgAAAQYEIZKDRkRQAQJwAAGEMppJRSSim"
+ "llFJKKaWUUkoppZRSSimllFJKKaWUUkgppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZ"
+ "RSSimllFJKKaWUUkqppJRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUU"
+ "koppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJK"
+ "KaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSim"
+ "llFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZ"
+ "RSSimllFJKKaWUUkoplVJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSS"
+ "imllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSCgCQinAAkHowoQwU"
+ "GrISAEgFAACMUUopxpyDEDHmGGPQSSgpYsw5xhyUklLlHIQQUmktt8o5CCGk1FJtmXNSWosx5hg"
+ "z56SkFFvNOYdSUoux5ppr7qS0VmuuNedaWqs115xzzbm0FmuuOdecc8sx15xzzjnnGHPOOeecc8"
+ "4FAOA0OACAHtiwOsJJ0VhgoSErAYBUAAACGaUYc8456BBSjDnnHIQQIoUYc845CCFUjDnnHHQQQ"
+ "qgYc8w5CCGEkDnnHIQQQgghcw466CCEEEIHHYQQQgihlM5BCCGEEEooIYQQQgghhBA6CCGEEEII"
+ "IYQQQgghhFJKCCGEEEIJoZRQAABggQMAQIANqyOcFI0FFhqyEgAAAgCAHJagUs6EQY5Bjw1BylE"
+ "zDUJMOdGZYk5qMxVTkDkQnXQSGWpB2V4yCwAAgCAAIMAEEBggKPhCCIgxAABBiMwQCYVVsMCgDB"
+ "oc5gHAA0SERACQmKBIu7iALgNc0MVdB0IIQhCCWBxAAQk4OOGGJ97whBucoFNU6iAAAAAAAAwA4"
+ "AEA4KAAIiKaq7C4wMjQ2ODo8AgAAAAAABYA+AAAOD6AiIjmKiwuMDI0Njg6PAIAAAAAAAAAAICA"
+ "gAAAAAAAQAAAAICAT2dnUwAEskwAAAAAAAAoPAxpAgAAACExbzQkFh0ebXZzdoRAFRUWFhgdHRx"
+ "8bWtwfRQWFxgYHSAdfXFrcnoBtM5A84YAQuvVmDyVmrjgS8xvXul0ALRM2cNmZ5CCHjEGoc8m/l"
+ "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"
+ "YHAM4XAAAO";
+       
+       // Sound C: Morse Code D.
+       
+       std::string SoundC = "T2dnUwACAAAAAAAAAABJz/4JAAAAAOq2RJ"
+ "UBHgF2b3JiaXMAAAAAAUSsAAAAAAAAgLsAAAAAAAC4AU9nZ1MAAAAAAAAAAAAASc/+CQEAAACmG"
+ "2vbDzz/////////////////MgN2b3JiaXMsAAAAWGlwaC5PcmcgbGliVm9yYmlzIEkgMjAxNTAx"
+ "MDUgKOKbhOKbhOKbhOKbhCkAAAAAAQV2b3JiaXMfQkNWAQAAAQAYY1QpRplS0kqJGXOUMUaZYpJ"
+ "KiaWEFkJInXMUU6k515xrrLm1IIQQGlNQKQWZUo5SaRljkCkFmVIQS0kldBI6J51jEFtJwdaYa4"
+ "tBthyEDZpSTCnElFKKQggZU4wpxZRSSkIHJXQOOuYcU45KKEG4nHOrtZaWY4updJJK5yRkTEJIK"
+ "YWSSgelU05CSDWW1lIpHXNSUmpB6CCEEEK2IIQNgtCQVQAAAQDAQBAasgoAUAAAEIqhGIoChIas"
+ "AgAyAAAEoCiO4iiOIzmSY0kWEBqyCgAAAgAQAADAcBRJkRTJsSRL0ixL00RRVX3VNlVV9nVd13V"
+ "d13UgNGQVAAABAEBIp5mlGiDCDGQYCA1ZBQAgAAAARijCEANCQ1YBAAABAABiKDmIJrTmfHOOg2"
+ "Y5aCrF5nRwItXmSW4q5uacc845J5tzxjjnnHOKcmYxaCa05pxzEoNmKWgmtOacc57E5kFrqrTmn"
+ "HPGOaeDcUYY55xzmrTmQWo21uaccxa0pjlqLsXmnHMi5eZJbS7V5pxzzjnnnHPOOeecc6oXp3Nw"
+ "TjjnnHOi9uZabkIX55xzPhmne3NCOOecc84555xzzjnnnHOC0JBVAAAQAABBGDaGcacgSJ+jgRh"
+ "FiGnIpAfdo8MkaAxyCqlHo6ORUuoglFTGSSmdIDRkFQAACAAAIYQUUkghhRRSSCGFFFKIIYYYYs"
+ "gpp5yCCiqppKKKMsoss8wyyyyzzDLrsLPOOuwwxBBDDK20EktNtdVYY62555xrDtJaaa211kopp"
+ "ZRSSikIDVkFAIAAABAIGWSQQUYhhRRSiCGmnHLKKaigAkJDVgEAgAAAAgAAADzJc0RHdERHdERH"
+ "dERHdETHczxHlERJlERJtEzL1ExPFVXVlV1b1mXd9m1hF3bd93Xf93Xj14VhWZZlWZZlWZZlWZZ"
+ "lWZZlWYLQkFUAAAgAAIAQQgghhRRSSCGlGGPMMeegk1BCIDRkFQAACAAgAAAAwFEcxXEkR3IkyZ"
+ "IsSZM0S7M8zdM8TfREURRN01RFV3RF3bRF2ZRN13RN2XRVWbVdWbZt2dZtX5Zt3/d93/d93/d93"
+ "/d93/d1HQgNWQUASAAA6EiOpEiKpEiO4ziSJAGhIasAABkAAAEAKIqjOI7jSJIkSZakSZ7lWaJm"
+ "aqZneqqoAqEhqwAAQAAAAQAAAAAAKJriKabiKaLiOaIjSqJlWqKmaq4om7Lruq7ruq7ruq7ruq7"
+ "ruq7ruq7ruq7ruq7ruq7ruq7ruq7rui4QGrIKAJAAANCRHMmRHEmRFEmRHMkBQkNWAQAyAAACAH"
+ "AMx5AUybEsS9M8zdM8TfRET/RMTxVd0QVCQ1YBAIAAAAIAAAAAADAkw1IsR3M0SZRUS7VUTbVUS"
+ "xVVT1VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVTVN0zRNIDRkJQAABADAYo3B5SAh"
+ "JSXl3hDCEJOeMSYhtV4hBJGS3jEGFYOeMqIMct5C4xCDHggNWREARAEAAMYgxxBzyDlHqZMSOee"
+ "odJQa5xyljlJnKcWYYs0oldhSrI1zjlJHraOUYiwtdpRSjanGAgAAAhwAAAIshEJDVgQAUQAAhD"
+ "FIKaQUYow5p5xDjCnnmHOGMeYcc44556B0UirnnHROSsQYc445p5xzUjonlXNOSiehAACAAAcAg"
+ "AALodCQFQFAnACAQZI8T/I0UZQ0TxRFU3RdUTRd1/I81fRMU1U90VRVU1Vt2VRVWZY8zzQ901RV"
+ "zzRV1VRVWTZVVZZFVdVt03V123RV3ZZt2/ddWxZ2UVVt3VRd2zdV1/Zd2fZ9WdZ1Y/I8VfVM03U"
+ "903Rl1XVtW3VdXfdMU5ZN15Vl03Vt25VlXXdl2fc103Rd01Vl2XRd2XZlV7ddWfZ903WF35VlX1"
+ "dlWRh2XfeFW9eV5XRd3VdlVzdWWfZ9W9eF4dZ1YZk8T1U903RdzzRdV3VdX1dd19Y105Rl03Vt2"
+ "VRdWXZl2fddV9Z1zzRl2XRd2zZdV5ZdWfZ9V5Z13XRdX1dlWfhVV/Z1WdeV4dZt4Tdd1/dVWfaF"
+ "V5Z14dZ1Ybl1XRg+VfV9U3aF4XRl39eF31luXTiW0XV9YZVt4VhlWTl+4ViW3feVZXRdX1ht2Rh"
+ "WWRaGX/id5fZ943h1XRlu3efMuu8Mx++k+8rT1W1jmX3dWWZfd47hGDq/8OOpqq+brisMpywLv+"
+ "3rxrP7vrKMruv7qiwLvyrbwrHrvvP8vrAso+z6wmrLwrDatjHcvm4sv3Acy2vryjHrvlG2dXxfe"
+ "ArD83R1XXlmXcf2dXTjRzh+ygAAgAEHAIAAE8pAoSErAoA4AQCPJImiZFmiKFmWKIqm6LqiaLqu"
+ "pGmmqWmeaVqaZ5qmaaqyKZquLGmaaVqeZpqap5mmaJqua5qmrIqmKcumasqyaZqy7LqybbuubNu"
+ "iacqyaZqybJqmLLuyq9uu7Oq6pFmmqXmeaWqeZ5qmasqyaZquq3meanqeaKqeKKqqaqqqraqqLF"
+ "ueZ5qa6KmmJ4qqaqqmrZqqKsumqtqyaaq2bKqqbbuq7Pqybeu6aaqybaqmLZuqatuu7OqyLNu6L"
+ "2maaWqeZ5qa55mmaZqybJqqK1uep5qeKKqq5ommaqqqLJumqsqW55mqJ4qq6omea5qqKsumatqq"
+ "aZq2bKqqLZumKsuubfu+68qybqqqbJuqauumasqybMu+78qq7oqmKcumqtqyaaqyLduy78uyrPu"
+ "iacqyaaqybaqqLsuybRuzbPu6aJqybaqmLZuqKtuyLfu6LNu678qub6uqrOuyLfu67vqucOu6ML"
+ "yybPuqrPq6K9u6b+sy2/Z9RNOUZVM1bdtUVVl2Zdn2Zdv2fdE0bVtVVVs2TdW2ZVn2fVm2bWE0T"
+ "dk2VVXWTdW0bVmWbWG2ZeF2Zdm3ZVv2ddeVdV/XfePXZd3murLty7Kt+6qr+rbu+8Jw667wCgAA"
+ "GHAAAAgwoQwUGrISAIgCAACMYYwxCI1SzjkHoVHKOecgZM5BCCGVzDkIIZSSOQehlJQy5yCUklI"
+ "IoZSUWgshlJRSawUAABQ4AAAE2KApsThAoSErAYBUAACD41iW55miatqyY0meJ4qqqaq27UiW54"
+ "miaaqqbVueJ4qmqaqu6+ua54miaaqq6+q6aJqmqaqu67q6Lpqiqaqq67qyrpumqqquK7uy7Oumq"
+ "qqq68quLPvCqrquK8uybevCsKqu68qybNu2b9y6ruu+7/vCka3rui78wjEMRwEA4AkOAEAFNqyO"
+ "cFI0FlhoyEoAIAMAgDAGIYMQQgYhhJBSSiGllBIAADDgAAAQYEIZKDRkRQAQJwAAGEMppJRSSim"
+ "llFJKKaWUUkoppZRSSimllFJKKaWUUkgppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZ"
+ "RSSimllFJKKaWUUkqppJRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUU"
+ "koppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJK"
+ "KaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSim"
+ "llFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZ"
+ "RSSimllFJKKaWUUkoplVJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSS"
+ "imllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSCgCQinAAkHowoQwU"
+ "GrISAEgFAACMUUopxpyDEDHmGGPQSSgpYsw5xhyUklLlHIQQUmktt8o5CCGk1FJtmXNSWosx5hg"
+ "z56SkFFvNOYdSUoux5ppr7qS0VmuuNedaWqs115xzzbm0FmuuOdecc8sx15xzzjnnGHPOOeecc8"
+ "4FAOA0OACAHtiwOsJJ0VhgoSErAYBUAAACGaUYc8456BBSjDnnHIQQIoUYc845CCFUjDnnHHQQQ"
+ "qgYc8w5CCGEkDnnHIQQQgghcw466CCEEEIHHYQQQgihlM5BCCGEEEooIYQQQgghhBA6CCGEEEII"
+ "IYQQQgghhFJKCCGEEEIJoZRQAABggQMAQIANqyOcFI0FFhqyEgAAAgCAHJagUs6EQY5Bjw1BylE"
+ "zDUJMOdGZYk5qMxVTkDkQnXQSGWpB2V4yCwAAgCAAIMAEEBggKPhCCIgxAABBiMwQCYVVsMCgDB"
+ "oc5gHAA0SERACQmKBIu7iALgNc0MVdB0IIQhCCWBxAAQk4OOGGJ97whBucoFNU6iAAAAAAAAwA4"
+ "AEA4KAAIiKaq7C4wMjQ2ODo8AgAAAAAABYA+AAAOD6AiIjmKiwuMDI0Njg6PAIAAAAAAAAAAICA"
+ "gAAAAAAAQAAAAICAT2dnUwAEVG0AAAAAAABJz/4JAgAAAK7vGfAvERYXFhYeHnZybGx0bXBwb2V"
+ "xhRwREhQXHx55aWtthy8WFhkXGB4gHoh2dnR8AQG01oq4BmHTs2rWN12BOBhVLKzS6V5yRvbdnX"
+ "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"
+ "FjNEAGMJtbcK5WgAODg==";
+       
+       // Start with Sound A.
+       
+       TestStrIter = TestFile.SoundsList.find(0);
+       ASSERT_NE(TestFile.SoundsList.end(), TestStrIter);
+       ASSERT_EQ(SoundA, TestStrIter->second);
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.SoundsListAudioEncType.find(0);
+       ASSERT_NE(TestFile.SoundsListAudioEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.SoundsListAudioType.find(0);
+       ASSERT_NE(TestFile.SoundsListAudioType.end(), TestFileIter);
+       ASSERT_EQ("application/ogg", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.SoundsListAltID.find(0);
+       ASSERT_NE(TestFile.SoundsListAltID.end(), TestFileIter);
+       ASSERT_EQ("4", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.SoundsListPID.find(0);
+       ASSERT_NE(TestFile.SoundsListPID.end(), TestFileIter);
+       ASSERT_EQ("1", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.SoundsListMediatype.find(0);
+       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);
+       ASSERT_NE(TestFile.SoundsListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.SoundsListPref.find(0);
+       ASSERT_NE(TestFile.SoundsListPref.end(), TestFileIntIter);
+       ASSERT_EQ(2, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.SoundsListTokens.find(0);
+       ASSERT_NE(TestFile.SoundsListTokens.end(), TestFileIter);
+       ASSERT_EQ("MEEP=MOO", TestFileIter->second);
+
+       // Start with Sound B.
+       
+       TestStrIter = TestFile.SoundsList.find(1);
+       ASSERT_NE(TestFile.SoundsList.end(), TestStrIter);
+       ASSERT_EQ(SoundB, TestStrIter->second);
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.SoundsListAudioEncType.find(1);
+       ASSERT_NE(TestFile.SoundsListAudioEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.SoundsListAudioType.find(1);
+       ASSERT_NE(TestFile.SoundsListAudioType.end(), TestFileIter);
+       ASSERT_EQ("application/ogg", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.SoundsListType.find(1);
+       ASSERT_NE(TestFile.SoundsListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.SoundsListAltID.find(1);
+       ASSERT_NE(TestFile.SoundsListAltID.end(), TestFileIter);
+       ASSERT_EQ("24", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.SoundsListPID.find(1);
+       ASSERT_NE(TestFile.SoundsListPID.end(), TestFileIter);
+       ASSERT_EQ("21", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.SoundsListMediatype.find(1);
+       ASSERT_NE(TestFile.SoundsListMediatype.end(), TestFileIter);
+       ASSERT_EQ("application/ogg", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.SoundsListLanguage.find(1);
+       ASSERT_NE(TestFile.SoundsListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.SoundsListPref.find(1);
+       ASSERT_NE(TestFile.SoundsListPref.end(), TestFileIntIter);
+       ASSERT_EQ(22, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.SoundsListTokens.find(1);
+       ASSERT_NE(TestFile.SoundsListTokens.end(), TestFileIter);
+       ASSERT_EQ("SOUND=WAVE", TestFileIter->second);
+
+       // Start with Sound C.
+       
+       TestStrIter = TestFile.SoundsList.find(2);
+       ASSERT_NE(TestFile.SoundsList.end(), TestStrIter);
+       ASSERT_EQ(SoundC, TestStrIter->second);
+       // Check that it has the correct encoding.
+       
+       TestFileIter = TestFile.SoundsListAudioEncType.find(2);
+       ASSERT_NE(TestFile.SoundsListAudioEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second);
+       
+       // Check that it has the correct image type.
+
+       TestFileIter = TestFile.SoundsListAudioType.find(2);
+       ASSERT_NE(TestFile.SoundsListAudioType.end(), TestFileIter);
+       ASSERT_EQ("application/ogg", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.SoundsListType.find(2);
+       ASSERT_NE(TestFile.SoundsListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.SoundsListAltID.find(2);
+       ASSERT_NE(TestFile.SoundsListAltID.end(), TestFileIter);
+       ASSERT_EQ("44", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.SoundsListPID.find(2);
+       ASSERT_NE(TestFile.SoundsListPID.end(), TestFileIter);
+       ASSERT_EQ("41", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.SoundsListMediatype.find(2);
+       ASSERT_NE(TestFile.SoundsListMediatype.end(), TestFileIter);
+       ASSERT_EQ("application/ogg", TestFileIter->second);
+       
+       // Check the LANGUAGE section.
+       
+       TestFileIter = TestFile.SoundsListLanguage.find(2);
+       ASSERT_NE(TestFile.SoundsListLanguage.end(), TestFileIter);
+       ASSERT_EQ("kw", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.SoundsListPref.find(2);
+       ASSERT_NE(TestFile.SoundsListPref.end(), TestFileIntIter);
+       ASSERT_EQ(42, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.SoundsListTokens.find(2);
+       ASSERT_NE(TestFile.SoundsListTokens.end(), TestFileIter);
+       ASSERT_EQ("WAVE=SOUND", TestFileIter->second);
+
+}
+
+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<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::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;
 
@@ -777,100 +4083,135 @@ TEST(ContactLoad, EmailTests){
 
        std::map<int,wxString>::iterator TestFileIter;
        std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with a general calendar request address.
        
-       // Start with the general email.
+       TestFileIter = TestFile.CalendarRequestList.find(0);
+       ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/request", TestFileIter->second);
        
-       TestFileIter = TestFile.GeneralEmailList.find(0);
-       ASSERT_NE(TestFile.GeneralEmailList.end(), TestFileIter);
-       ASSERT_EQ("moo@example.com", TestFileIter->second);
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.CalendarRequestListType.find(0);
+       ASSERT_EQ(TestFile.CalendarRequestListType.end(), TestFileIter);
        
        // Check the ALTID section.
        
-       TestFileIter = TestFile.GeneralEmailListAltID.find(0);
-       ASSERT_NE(TestFile.GeneralEmailListAltID.end(), TestFileIter);
-       ASSERT_EQ("10", TestFileIter->second);
+       TestFileIter = TestFile.CalendarRequestListAltID.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+       ASSERT_EQ("14", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.GeneralEmailListPID.find(0);
-       ASSERT_NE(TestFile.GeneralEmailListPID.end(), TestFileIter);
-       ASSERT_EQ("20", TestFileIter->second);
+       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.GeneralEmailListPref.find(0);
-       ASSERT_NE(TestFile.GeneralEmailListPref.end(), TestFileIntIter);
-       ASSERT_EQ(40, TestFileIntIter->second);
+       TestFileIntIter = TestFile.CalendarRequestListPref.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+       ASSERT_EQ(12, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.GeneralEmailListTokens.find(0);
-       ASSERT_NE(TestFile.GeneralEmailListTokens.end(), TestFileIter);
-       ASSERT_EQ("WONDERFUL=Colour", TestFileIter->second);
+       TestFileIter = TestFile.CalendarRequestListTokens.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+       ASSERT_EQ("REQUEST=YES", TestFileIter->second);
 
-       // Start with the home email.
+       // Start with a home calendar request address.
        
-       TestFileIter = TestFile.HomeEmailList.find(1);
-       ASSERT_NE(TestFile.HomeEmailList.end(), TestFileIter);
-       ASSERT_EQ("moo.home@example.com", TestFileIter->second);
+       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.HomeEmailListAltID.find(1);
-       ASSERT_NE(TestFile.HomeEmailListAltID.end(), TestFileIter);
-       ASSERT_EQ("5", TestFileIter->second);
+       TestFileIter = TestFile.CalendarRequestListAltID.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+       ASSERT_EQ("24", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.HomeEmailListPID.find(1);
-       ASSERT_NE(TestFile.HomeEmailListPID.end(), TestFileIter);
-       ASSERT_EQ("10", TestFileIter->second);
+       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.HomeEmailListPref.find(1);
-       ASSERT_NE(TestFile.HomeEmailListPref.end(), TestFileIntIter);
-       ASSERT_EQ(20, TestFileIntIter->second);
+       TestFileIntIter = TestFile.CalendarRequestListPref.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+       ASSERT_EQ(22, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.HomeEmailListTokens.find(1);
-       ASSERT_NE(TestFile.HomeEmailListTokens.end(), TestFileIter);
-       ASSERT_EQ("PEACE=quiet", TestFileIter->second);
+       TestFileIter = TestFile.CalendarRequestListTokens.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+       ASSERT_EQ("REQUEST=MAYBE", TestFileIter->second);
 
-       // Start with the business email.
+       // Start with a business calendar request address.
        
-       TestFileIter = TestFile.BusinessEmailList.find(2);
-       ASSERT_NE(TestFile.BusinessEmailList.end(), TestFileIter);
-       ASSERT_EQ("moo.business@example.com", TestFileIter->second);
+       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.BusinessEmailListAltID.find(2);
-       ASSERT_NE(TestFile.BusinessEmailListAltID.end(), TestFileIter);
-       ASSERT_EQ("1", TestFileIter->second);
+       TestFileIter = TestFile.CalendarRequestListAltID.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+       ASSERT_EQ("34", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.BusinessEmailListPID.find(2);
-       ASSERT_NE(TestFile.BusinessEmailListPID.end(), TestFileIter);
-       ASSERT_EQ("2", TestFileIter->second);
+       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.BusinessEmailListPref.find(2);
-       ASSERT_NE(TestFile.BusinessEmailListPref.end(), TestFileIntIter);
-       ASSERT_EQ(3, TestFileIntIter->second);
+       TestFileIntIter = TestFile.CalendarRequestListPref.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+       ASSERT_EQ(32, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.BusinessEmailListTokens.find(2);
-       ASSERT_NE(TestFile.BusinessEmailListTokens.end(), TestFileIter);
-       ASSERT_EQ("BUSINESS=Money", TestFileIter->second);
-
+       TestFileIter = TestFile.CalendarRequestListTokens.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+       ASSERT_EQ("REQUEST=NO", TestFileIter->second);
+       
 }
 
-TEST(ContactLoad, IMTests){
+TEST(ContactLoad, FreeBusyTests){
 
        ContactDataObject TestFile;
 
@@ -880,240 +4221,546 @@ TEST(ContactLoad, IMTests){
 
        std::map<int,wxString>::iterator TestFileIter;
        std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with a general calendar free busy address.
        
-       // Start with the general IM.
+       TestFileIter = TestFile.FreeBusyList.find(0);
+       ASSERT_NE(TestFile.FreeBusyList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/freebusy", TestFileIter->second);
        
-       TestFileIter = TestFile.GeneralIMList.find(0);
-       ASSERT_NE(TestFile.GeneralIMList.end(), TestFileIter);
-       ASSERT_EQ("moo@example.com", TestFileIter->second);
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.FreeBusyListType.find(0);
+       ASSERT_EQ(TestFile.FreeBusyListType.end(), TestFileIter);
        
        // Check the ALTID section.
        
-       TestFileIter = TestFile.GeneralIMListAltID.find(0);
-       ASSERT_NE(TestFile.GeneralIMListAltID.end(), TestFileIter);
-       ASSERT_EQ("10", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListAltID.find(0);
+       ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter);
+       ASSERT_EQ("74", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.GeneralIMListPID.find(0);
-       ASSERT_NE(TestFile.GeneralIMListPID.end(), TestFileIter);
-       ASSERT_EQ("20", TestFileIter->second);
-
+       TestFileIter = TestFile.FreeBusyListPID.find(0);
+       ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
+       
        // Check the MEDIATYPE section.
        
-       TestFileIter = TestFile.GeneralIMListMediatype.find(0);
-       ASSERT_NE(TestFile.GeneralIMListMediatype.end(), TestFileIter);
+       TestFileIter = TestFile.FreeBusyListMediatype.find(0);
+       ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter);
        ASSERT_EQ("text/plain", TestFileIter->second);
        
        // Check the PREF section.
        
-       TestFileIntIter = TestFile.GeneralIMListPref.find(0);
-       ASSERT_NE(TestFile.GeneralIMListPref.end(), TestFileIntIter);
-       ASSERT_EQ(40, TestFileIntIter->second);
+       TestFileIntIter = TestFile.FreeBusyListPref.find(0);
+       ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.GeneralIMListTokens.find(0);
-       ASSERT_NE(TestFile.GeneralIMListTokens.end(), TestFileIter);
-       ASSERT_EQ("WONDERFUL=Colour", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListTokens.find(0);
+       ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter);
+       ASSERT_EQ("STATUS=OUT", TestFileIter->second);
 
-       // Start with the home IM.
+       // Start with a home calendar free busy address.
        
-       TestFileIter = TestFile.HomeIMList.find(1);
-       ASSERT_NE(TestFile.HomeIMList.end(), TestFileIter);
-       ASSERT_EQ("moo.home@example.com", TestFileIter->second);
+       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.HomeIMListAltID.find(1);
-       ASSERT_NE(TestFile.HomeIMListAltID.end(), TestFileIter);
-       ASSERT_EQ("20", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListAltID.find(1);
+       ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter);
+       ASSERT_EQ("84", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.HomeIMListPID.find(1);
-       ASSERT_NE(TestFile.HomeIMListPID.end(), TestFileIter);
-       ASSERT_EQ("40", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListPID.find(1);
+       ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter);
+       ASSERT_EQ("81", TestFileIter->second);
        
        // Check the MEDIATYPE section.
        
-       TestFileIter = TestFile.HomeIMListMediatype.find(1);
-       ASSERT_NE(TestFile.HomeIMListMediatype.end(), TestFileIter);
-       ASSERT_EQ("text/reallyplain", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListMediatype.find(1);
+       ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/dryplain", TestFileIter->second);
        
        // Check the PREF section.
        
-       TestFileIntIter = TestFile.HomeIMListPref.find(1);
-       ASSERT_NE(TestFile.HomeIMListPref.end(), TestFileIntIter);
-       ASSERT_EQ(80, TestFileIntIter->second);
+       TestFileIntIter = TestFile.FreeBusyListPref.find(1);
+       ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(82, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.HomeIMListTokens.find(1);
-       ASSERT_NE(TestFile.HomeIMListTokens.end(), TestFileIter);
-       ASSERT_EQ("PEACE=quiet", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListTokens.find(1);
+       ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter);
+       ASSERT_EQ("STATUS=FREE", TestFileIter->second);
 
-       // Start with the business IM.
+       // Start with a business calendar free busy address.
        
-       TestFileIter = TestFile.BusinessIMList.find(2);
-       ASSERT_NE(TestFile.BusinessIMList.end(), TestFileIter);
-       ASSERT_EQ("moo.business@example.com", TestFileIter->second);
+       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.BusinessIMListAltID.find(2);
-       ASSERT_NE(TestFile.BusinessIMListAltID.end(), TestFileIter);
-       ASSERT_EQ("98", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListAltID.find(2);
+       ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter);
+       ASSERT_EQ("94", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.BusinessIMListPID.find(2);
-       ASSERT_NE(TestFile.BusinessIMListPID.end(), TestFileIter);
-       ASSERT_EQ("99", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListPID.find(2);
+       ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter);
+       ASSERT_EQ("91", TestFileIter->second);
        
        // Check the MEDIATYPE section.
        
-       TestFileIter = TestFile.BusinessIMListMediatype.find(2);
-       ASSERT_NE(TestFile.BusinessIMListMediatype.end(), TestFileIter);
-       ASSERT_EQ("text/superplain", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListMediatype.find(2);
+       ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/stillwetink", TestFileIter->second);
        
        // Check the PREF section.
        
-       TestFileIntIter = TestFile.BusinessIMListPref.find(2);
-       ASSERT_NE(TestFile.BusinessIMListPref.end(), TestFileIntIter);
-       ASSERT_EQ(50, TestFileIntIter->second);
+       TestFileIntIter = TestFile.FreeBusyListPref.find(2);
+       ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(92, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.BusinessIMListTokens.find(2);
-       ASSERT_NE(TestFile.BusinessIMListTokens.end(), TestFileIter);
-       ASSERT_EQ("BUSINESS=Money", TestFileIter->second);
+       TestFileIter = TestFile.FreeBusyListTokens.find(2);
+       ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter);
+       ASSERT_EQ("STATUS=BUSY", TestFileIter->second);
 
 }
 
-TEST(ContactLoad, TelephoneTests){
+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<int,wxString>::iterator TestFileIter;
        std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with a general key.
        
-       // Start with the general Telephone.
+       TestFileIter = TestFile.KeyList.find(0);
+       ASSERT_NE(TestFile.KeyList.end(), TestFileIter);
+       ASSERT_EQ(KeyA, TestFileIter->second);
        
-       TestFileIter = TestFile.GeneralTelephoneList.find(0);
-       ASSERT_NE(TestFile.GeneralTelephoneList.end(), TestFileIter);
-       ASSERT_EQ("tel:00000000", TestFileIter->second);
+       // Check the encoding type.
        
-       // Check the type section.
+       TestFileIter = TestFile.KeyListDataEncType.find(0);
+       ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second.ToStdString());
        
-       TestFileIter = TestFile.GeneralTelephoneListTypeInfo.find(0);
-       ASSERT_NE(TestFile.GeneralTelephoneListTypeInfo.end(), TestFileIter);
-       ASSERT_EQ("fax,mobile", TestFileIter->second);  
+       // 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.GeneralTelephoneListAltID.find(0);
-       ASSERT_NE(TestFile.GeneralTelephoneListAltID.end(), TestFileIter);
-       ASSERT_EQ("10", TestFileIter->second);
+       TestFileIter = TestFile.KeyListAltID.find(0);
+       ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter);
+       ASSERT_EQ("54", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.GeneralTelephoneListPID.find(0);
-       ASSERT_NE(TestFile.GeneralTelephoneListPID.end(), TestFileIter);
-       ASSERT_EQ("20", TestFileIter->second);
+       TestFileIter = TestFile.KeyListPID.find(0);
+       ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter);
+       ASSERT_EQ("51", TestFileIter->second);
        
        // Check the PREF section.
        
-       TestFileIntIter = TestFile.GeneralTelephoneListPref.find(0);
-       ASSERT_NE(TestFile.GeneralTelephoneListPref.end(), TestFileIntIter);
-       ASSERT_EQ(40, TestFileIntIter->second);
+       TestFileIntIter = TestFile.KeyListPref.find(0);
+       ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(52, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.GeneralTelephoneListTokens.find(0);
-       ASSERT_NE(TestFile.GeneralTelephoneListTokens.end(), TestFileIter);
-       ASSERT_EQ("WONDERFUL=Colour", TestFileIter->second);
+       TestFileIter = TestFile.KeyListTokens.find(0);
+       ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter);
+       ASSERT_EQ("KEYS=JUSTONE", TestFileIter->second);
+
+       // Start with a work key.
        
-       // Start with the home Telephone.
+       TestFileIter = TestFile.KeyList.find(1);
+       ASSERT_NE(TestFile.KeyList.end(), TestFileIter);
+       ASSERT_EQ(KeyB, TestFileIter->second);
        
-       TestFileIter = TestFile.HomeTelephoneList.find(1);
-       ASSERT_NE(TestFile.HomeTelephoneList.end(), TestFileIter);
-       ASSERT_EQ("tel:00001111", TestFileIter->second);
+       // Check the encoding type.
        
-       // Check the type section.
+       TestFileIter = TestFile.KeyListDataEncType.find(1);
+       ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second.ToStdString());
        
-       TestFileIter = TestFile.HomeTelephoneListTypeInfo.find(1);
-       ASSERT_NE(TestFile.HomeTelephoneListTypeInfo.end(), TestFileIter);
-       ASSERT_EQ("fax", TestFileIter->second); 
+       // 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.HomeTelephoneListAltID.find(1);
-       ASSERT_NE(TestFile.HomeTelephoneListAltID.end(), TestFileIter);
-       ASSERT_EQ("10", TestFileIter->second);
+       TestFileIter = TestFile.KeyListAltID.find(1);
+       ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter);
+       ASSERT_EQ("64", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.HomeTelephoneListPID.find(1);
-       ASSERT_NE(TestFile.HomeTelephoneListPID.end(), TestFileIter);
-       ASSERT_EQ("20", TestFileIter->second);
+       TestFileIter = TestFile.KeyListPID.find(1);
+       ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter);
+       ASSERT_EQ("61", TestFileIter->second);
        
        // Check the PREF section.
        
-       TestFileIntIter = TestFile.HomeTelephoneListPref.find(1);
-       ASSERT_NE(TestFile.HomeTelephoneListPref.end(), TestFileIntIter);
-       ASSERT_EQ(40, TestFileIntIter->second);
+       TestFileIntIter = TestFile.KeyListPref.find(1);
+       ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(62, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.HomeTelephoneListTokens.find(1);
-       ASSERT_NE(TestFile.HomeTelephoneListTokens.end(), TestFileIter);
-       ASSERT_EQ("BUSINESS=Money", TestFileIter->second);
+       TestFileIter = TestFile.KeyListTokens.find(1);
+       ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter);
+       ASSERT_EQ("KEYS=NONE", TestFileIter->second);
 
-       // Start with the business Telephone.
+       // Start with a business key.
        
-       TestFileIter = TestFile.BusinessTelephoneList.find(2);
-       ASSERT_NE(TestFile.BusinessTelephoneList.end(), TestFileIter);
-       ASSERT_EQ("tel:22221111", TestFileIter->second);
+       TestFileIter = TestFile.KeyList.find(2);
+       ASSERT_NE(TestFile.KeyList.end(), TestFileIter);
+       ASSERT_EQ(KeyC, TestFileIter->second);
        
-       // Check the type section.
+       // Check the encoding type.
        
-       TestFileIter = TestFile.BusinessTelephoneListTypeInfo.find(2);
-       ASSERT_NE(TestFile.BusinessTelephoneListTypeInfo.end(), TestFileIter);
-       ASSERT_EQ("voice", TestFileIter->second);       
+       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.BusinessTelephoneListAltID.find(2);
-       ASSERT_NE(TestFile.BusinessTelephoneListAltID.end(), TestFileIter);
-       ASSERT_EQ("25", TestFileIter->second);
+       TestFileIter = TestFile.KeyListAltID.find(2);
+       ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter);
+       ASSERT_EQ("74", TestFileIter->second);
        
        // Check the PID section.
        
-       TestFileIter = TestFile.BusinessTelephoneListPID.find(2);
-       ASSERT_NE(TestFile.BusinessTelephoneListPID.end(), TestFileIter);
-       ASSERT_EQ("50", TestFileIter->second);
+       TestFileIter = TestFile.KeyListPID.find(2);
+       ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
        
        // Check the PREF section.
        
-       TestFileIntIter = TestFile.BusinessTelephoneListPref.find(2);
-       ASSERT_NE(TestFile.BusinessTelephoneListPref.end(), TestFileIntIter);
-       ASSERT_EQ(75, TestFileIntIter->second);
+       TestFileIntIter = TestFile.KeyListPref.find(2);
+       ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
        
        // Check the extra tokens.
        
-       TestFileIter = TestFile.BusinessTelephoneListTokens.find(2);
-       ASSERT_NE(TestFile.BusinessTelephoneListTokens.end(), TestFileIter);
-       ASSERT_EQ("BEEP=Boop", TestFileIter->second);
+       TestFileIter = TestFile.KeyListTokens.find(2);
+       ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter);
+       ASSERT_EQ("KEYS=MISSING", TestFileIter->second);
 
 }
 
-TEST(ContactLoad, TelephoneTests){
+TEST(ContactLoad, VendorTests){
+
+       ContactDataObject TestFile;
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::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);
 
 }
 
-// TODO: Add tests for the Contact Loading process.
\ No newline at end of file
+TEST(ContactLoad, XTokenTest){
+
+       ContactDataObject TestFile;
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::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
Xestia Software Development
Yn Maystri
© 2006 - 2019 Xestia Software Development
Software

Xestia Address Book
Xestia Calendar
Development

Xestia Gelforn
Everything else

About
News
Privacy Policy