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 6894fa4..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){
+TEST(ContactLoad, GivenContactDataObjectWhenNameDisplayAsIsRetrievedThenValueforNameDisplayAsIsReturned)
+{
 
-       // Check that the gender has been read.
+       // Check the SORT-AS 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 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,95 +846,312 @@ 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.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.
 
@@ -566,7 +1244,7 @@ TEST(ContactLoad, AddressTests){
        
        TestFileIter = TestFile.GeneralAddressListGeo.find(0);
        ASSERT_NE(TestFile.GeneralAddressListGeo.end(), TestFileIter);
-       ASSERT_EQ("\"geo:1.0, 1.0\"", TestFileIter->second);
+       ASSERT_EQ("geo:1.0, 1.0", TestFileIter->second);
 
        // Check the TZ section.
        
@@ -652,7 +1330,7 @@ TEST(ContactLoad, AddressTests){
        
        TestFileIter = TestFile.HomeAddressListGeo.find(1);
        ASSERT_NE(TestFile.HomeAddressListGeo.end(), TestFileIter);
-       ASSERT_EQ("\"geo:4.0, 4.0\"", TestFileIter->second);
+       ASSERT_EQ("geo:4.0, 4.0", TestFileIter->second);
 
        // Check the TZ section.
        
@@ -738,7 +1416,7 @@ TEST(ContactLoad, AddressTests){
        
        TestFileIter = TestFile.BusinessAddressListGeo.find(2);
        ASSERT_NE(TestFile.BusinessAddressListGeo.end(), TestFileIter);
-       ASSERT_EQ("\"geo:7.0, 7.0\"", TestFileIter->second);
+       ASSERT_EQ("geo:7.0, 7.0", TestFileIter->second);
 
        // Check the TZ section.
        
@@ -1006,13 +1684,19 @@ TEST(ContactLoad, TelephoneTests){
        
        TestFileIter = TestFile.GeneralTelephoneList.find(0);
        ASSERT_NE(TestFile.GeneralTelephoneList.end(), TestFileIter);
-       ASSERT_EQ("tel:00000000", TestFileIter->second);
+       ASSERT_EQ("00000000", TestFileIter->second);
+       
+       // Check the data type section.
+
+       TestFileIter = TestFile.GeneralTelephoneListDataType.find(0);
+       ASSERT_NE(TestFile.GeneralTelephoneListDataType.end(), TestFileIter);
+       ASSERT_EQ("tel", TestFileIter->second); 
        
        // Check the type section.
        
        TestFileIter = TestFile.GeneralTelephoneListTypeInfo.find(0);
        ASSERT_NE(TestFile.GeneralTelephoneListTypeInfo.end(), TestFileIter);
-       ASSERT_EQ("fax,mobile", TestFileIter->second);  
+       ASSERT_EQ("fax,cell", TestFileIter->second.ToStdString());      
        
        // Check the ALTID section.
        
@@ -1042,7 +1726,13 @@ TEST(ContactLoad, TelephoneTests){
        
        TestFileIter = TestFile.HomeTelephoneList.find(1);
        ASSERT_NE(TestFile.HomeTelephoneList.end(), TestFileIter);
-       ASSERT_EQ("tel:00001111", TestFileIter->second);
+       ASSERT_EQ("00001111", TestFileIter->second);
+       
+       // Check the data type section.
+
+       TestFileIter = TestFile.HomeTelephoneListDataType.find(1);
+       ASSERT_NE(TestFile.HomeTelephoneListDataType.end(), TestFileIter);
+       ASSERT_EQ("tel", TestFileIter->second); 
        
        // Check the type section.
        
@@ -1078,7 +1768,13 @@ TEST(ContactLoad, TelephoneTests){
        
        TestFileIter = TestFile.BusinessTelephoneList.find(2);
        ASSERT_NE(TestFile.BusinessTelephoneList.end(), TestFileIter);
-       ASSERT_EQ("tel:22221111", TestFileIter->second);
+       ASSERT_EQ("22221111", TestFileIter->second);
+       
+       // Check the data type section.
+
+       TestFileIter = TestFile.BusinessTelephoneListDataType.find(2);
+       ASSERT_NE(TestFile.BusinessTelephoneListDataType.end(), TestFileIter);
+       ASSERT_EQ("tel", TestFileIter->second);
        
        // Check the type section.
        
@@ -1230,7 +1926,7 @@ TEST(ContactLoad, GeographicTests){
        
        TestFileIter = TestFile.GeneralGeographyList.find(0);
        ASSERT_NE(TestFile.GeneralGeographyList.end(), TestFileIter);
-       ASSERT_EQ("geo:3.5,3.5", TestFileIter->second);
+       ASSERT_EQ("3.5,3.5", TestFileIter->second);
        
        // Check the ALTID section.
        
@@ -1266,7 +1962,7 @@ TEST(ContactLoad, GeographicTests){
        
        TestFileIter = TestFile.HomeGeographyList.find(1);
        ASSERT_NE(TestFile.HomeGeographyList.end(), TestFileIter);
-       ASSERT_EQ("geo:7.0,7.0", TestFileIter->second);
+       ASSERT_EQ("7.0,7.0", TestFileIter->second);
        
        // Check the ALTID section.
        
@@ -1302,7 +1998,7 @@ TEST(ContactLoad, GeographicTests){
        
        TestFileIter = TestFile.BusinessGeographyList.find(2);
        ASSERT_NE(TestFile.BusinessGeographyList.end(), TestFileIter);
-       ASSERT_EQ("geo:14.0,14.0", TestFileIter->second);
+       ASSERT_EQ("14.0,14.0", TestFileIter->second);
        
        // Check the ALTID section.
        
@@ -2347,6 +3043,11 @@ TEST(ContactLoad, PhotoTests){
        ASSERT_NE(TestFile.PicturesListPID.end(), TestFileIter);
        ASSERT_EQ("71", TestFileIter->second);
        
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.PicturesListType.find(0);
+       ASSERT_EQ(TestFile.PicturesListType.end(), TestFileIter);
+       
        // Check the MEDIATYPE section.
        
        TestFileIter = TestFile.PicturesListMediatype.find(0);
@@ -2396,6 +3097,12 @@ TEST(ContactLoad, PhotoTests){
        ASSERT_NE(TestFile.PicturesListPID.end(), TestFileIter);
        ASSERT_EQ("21", TestFileIter->second);
        
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.PicturesListType.find(1);
+       ASSERT_NE(TestFile.PicturesListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
+       
        // Check the MEDIATYPE section.
        
        TestFileIter = TestFile.PicturesListMediatype.find(1);
@@ -2445,6 +3152,12 @@ TEST(ContactLoad, PhotoTests){
        ASSERT_NE(TestFile.PicturesListPID.end(), TestFileIter);
        ASSERT_EQ("91", TestFileIter->second);
        
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.PicturesListType.find(2);
+       ASSERT_NE(TestFile.PicturesListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
        // Check the MEDIATYPE section.
        
        TestFileIter = TestFile.PicturesListMediatype.find(2);
@@ -2508,6 +3221,8 @@ TEST(ContactLoad, LogoTests){
        ASSERT_NE(TestFile.LogosListPID.end(), TestFileIter);
        ASSERT_EQ("71", TestFileIter->second);
        
+       // Check the TYPE section.
+               
        // Check the MEDIATYPE section.
        
        TestFileIter = TestFile.LogosListMediatype.find(0);
@@ -2556,6 +3271,12 @@ TEST(ContactLoad, LogoTests){
        TestFileIter = TestFile.LogosListPID.find(1);
        ASSERT_NE(TestFile.LogosListPID.end(), TestFileIter);
        ASSERT_EQ("21", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.LogosListType.find(1);
+       ASSERT_NE(TestFile.LogosListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
        
        // Check the MEDIATYPE section.
        
@@ -2606,6 +3327,12 @@ TEST(ContactLoad, LogoTests){
        ASSERT_NE(TestFile.LogosListPID.end(), TestFileIter);
        ASSERT_EQ("91", TestFileIter->second);
        
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.LogosListType.find(2);
+       ASSERT_NE(TestFile.LogosListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
        // Check the MEDIATYPE section.
        
        TestFileIter = TestFile.LogosListMediatype.find(2);
@@ -3063,6 +3790,11 @@ TEST(ContactLoad, SoundTests){
        ASSERT_NE(TestFile.SoundsListMediatype.end(), TestFileIter);
        ASSERT_EQ("application/ogg", TestFileIter->second);
        
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.SoundsListType.find(0);
+       ASSERT_EQ(TestFile.SoundsListType.end(), TestFileIter);
+       
        // Check the LANGUAGE section.
        
        TestFileIter = TestFile.SoundsListLanguage.find(0);
@@ -3203,4 +3935,832 @@ TEST(ContactLoad, SoundTests){
 
 }
 
-// TODO: Add tests for the Contact Loading process.
\ No newline at end of file
+TEST(ContactLoad, CalendarURITests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<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;
+
+       // 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 request address.
+       
+       TestFileIter = TestFile.CalendarRequestList.find(0);
+       ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/request", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.CalendarRequestListType.find(0);
+       ASSERT_EQ(TestFile.CalendarRequestListType.end(), TestFileIter);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.CalendarRequestListAltID.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+       ASSERT_EQ("14", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.CalendarRequestListPID.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter);
+       ASSERT_EQ("11", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.CalendarRequestListMediatype.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/plain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.CalendarRequestListPref.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+       ASSERT_EQ(12, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.CalendarRequestListTokens.find(0);
+       ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+       ASSERT_EQ("REQUEST=YES", TestFileIter->second);
+
+       // Start with a home calendar request address.
+       
+       TestFileIter = TestFile.CalendarRequestList.find(1);
+       ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/home/request", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.CalendarRequestListType.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.CalendarRequestListAltID.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+       ASSERT_EQ("24", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.CalendarRequestListPID.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter);
+       ASSERT_EQ("21", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.CalendarRequestListMediatype.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/dryplain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.CalendarRequestListPref.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+       ASSERT_EQ(22, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.CalendarRequestListTokens.find(1);
+       ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+       ASSERT_EQ("REQUEST=MAYBE", TestFileIter->second);
+
+       // Start with a business calendar request address.
+       
+       TestFileIter = TestFile.CalendarRequestList.find(2);
+       ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/business/request", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.CalendarRequestListType.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.CalendarRequestListAltID.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+       ASSERT_EQ("34", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.CalendarRequestListPID.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter);
+       ASSERT_EQ("31", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.CalendarRequestListMediatype.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/stillwetink", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.CalendarRequestListPref.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+       ASSERT_EQ(32, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.CalendarRequestListTokens.find(2);
+       ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+       ASSERT_EQ("REQUEST=NO", TestFileIter->second);
+       
+}
+
+TEST(ContactLoad, FreeBusyTests){
+
+       ContactDataObject TestFile;
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with a general calendar free busy address.
+       
+       TestFileIter = TestFile.FreeBusyList.find(0);
+       ASSERT_NE(TestFile.FreeBusyList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/freebusy", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.FreeBusyListType.find(0);
+       ASSERT_EQ(TestFile.FreeBusyListType.end(), TestFileIter);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.FreeBusyListAltID.find(0);
+       ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter);
+       ASSERT_EQ("74", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.FreeBusyListPID.find(0);
+       ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.FreeBusyListMediatype.find(0);
+       ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/plain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.FreeBusyListPref.find(0);
+       ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.FreeBusyListTokens.find(0);
+       ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter);
+       ASSERT_EQ("STATUS=OUT", TestFileIter->second);
+
+       // Start with a home calendar free busy address.
+       
+       TestFileIter = TestFile.FreeBusyList.find(1);
+       ASSERT_NE(TestFile.FreeBusyList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/home/freebusy", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.FreeBusyListType.find(1);
+       ASSERT_NE(TestFile.FreeBusyListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.FreeBusyListAltID.find(1);
+       ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter);
+       ASSERT_EQ("84", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.FreeBusyListPID.find(1);
+       ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter);
+       ASSERT_EQ("81", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.FreeBusyListMediatype.find(1);
+       ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/dryplain", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.FreeBusyListPref.find(1);
+       ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(82, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.FreeBusyListTokens.find(1);
+       ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter);
+       ASSERT_EQ("STATUS=FREE", TestFileIter->second);
+
+       // Start with a business calendar free busy address.
+       
+       TestFileIter = TestFile.FreeBusyList.find(2);
+       ASSERT_NE(TestFile.FreeBusyList.end(), TestFileIter);
+       ASSERT_EQ("http://example.com/business/freebusy", TestFileIter->second);
+       
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.FreeBusyListType.find(2);
+       ASSERT_NE(TestFile.FreeBusyListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.FreeBusyListAltID.find(2);
+       ASSERT_NE(TestFile.FreeBusyListAltID.end(), TestFileIter);
+       ASSERT_EQ("94", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.FreeBusyListPID.find(2);
+       ASSERT_NE(TestFile.FreeBusyListPID.end(), TestFileIter);
+       ASSERT_EQ("91", TestFileIter->second);
+       
+       // Check the MEDIATYPE section.
+       
+       TestFileIter = TestFile.FreeBusyListMediatype.find(2);
+       ASSERT_NE(TestFile.FreeBusyListMediatype.end(), TestFileIter);
+       ASSERT_EQ("text/stillwetink", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.FreeBusyListPref.find(2);
+       ASSERT_NE(TestFile.FreeBusyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(92, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.FreeBusyListTokens.find(2);
+       ASSERT_NE(TestFile.FreeBusyListTokens.end(), TestFileIter);
+       ASSERT_EQ("STATUS=BUSY", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, KeyTests){
+
+       ContactDataObject TestFile;
+
+       wxString KeyA = "LS0tLS1CRUdJTiBQR1AgUFVCTElDIEtFWSBCTE9DSy0tLS0tClZlcnNpb246IEdudVBHIHYyCgpt"
+ "UU11QkZaL0JyWVJDQUN2cTNueUl4dXJPOFovMHcwQWdkeUdhN1d2cWRpdk5OWVdEM3dmZkgrSi83"
+ "R2o1dkNOClJwWFQ5TVI4SEdmR0Jwai9hc0NsajltbjhnRENMcVZJaXFybXZXK3dHbnhBVWxFU05V"
+ "T201cEx6NTRwTzBzOW0KYzJ5SDRkYWVYR3pRTXFLUit2TDZaTWpDc0pSRk1UWVAzSDlTMlBFaHFF"
+ "MXl4TnBpRi9ZTS9jNGNOYmU5bEZsTgpKMnJ2QzA2bzZuMFlzYWtuZTk3bWlndGNyTUpZVDljVDF4"
+ "cjB5YUhDekcrVXZqOG1RMnlGT0tpVEpxeGlCVEdhClRMWjJjTFBVZVFFbnpjSWNwNnhVTitQZlZY"
+ "ZzNNVllHWUZQakk0aUg0anNCQUFDc1BEMmpYSExnYVVzLzJ5VHUKNVF4M1RKSHljVTArOXZidC85"
+ "VDJKdGt3c1R5SXlqQnJ0eGd6QVFERENaaFZoNU5oOFJuSWlSRDFzMzNmN1RoZgp4eENUMU0yWHI3"
+ "dWh1WVFTZ1FmNUFRYkFscDZpUk9xTms5VVlBeHNSWVdPelRFd3RWMGlCLzBJamwyZFBUTm1YClJx"
+ "NW9FN0JOT3JYZjEzMmM4NlFpNWdPbGVHbWNoNFEvUUZTbUYwT05FZCs4aVNWemMvaVdFTUh4SzRO"
+ "Z1ZMN0kKc0FMMDVweGZhdWxpWlRlWVVGcGM1ajZnWHFpUExyNy93ODB4Q05vOWZsWmZXQkZzYVhM"
+ "Zm10Z3I1MU9kYXhJNQpLZnFjRjg1cnVQSkZkZjJWb1hxRU81YXpHZ1VsS0xoZDg5NkZUR21tZEF0"
+ "SUp5b0RtTldyVFgwS1VqQ05ELzM4Ck5UZDZrK3h6bW1NcTJCRy9VRy9NVGtlTUl1T3BEenZGQjBi"
+ "R2NRZnlGSC9iVnRjQzBOS2lnT0crMStPZ1dMMGUKQzZqcGRyYXU3THNKeXcrbU9VSjdHWHFTN2pK"
+ "WnU2ZjBZcWxLbEZrUllBZi9VekVUL3lBU2VhQUV2a1BqMnF5Lwo4b1ZIQWdrVGFZSWUvSHF1UEN4"
+ "RVc4bmgzWEp2emIxaWVlOHMrT2lZaE1wWVFIdFVTYTdESWR1eTgzZllTS2REClZzUnNNWExiMFly"
+ "Z1IvamhxdVZhYzR3TXFvZ3JJTGRoK3lhcDdtUEhwdUVrOCtLcGROUldJNkZMS0srekpxcVYKZWh6"
+ "ckNDc1QzL09URUd6bnpTSllXOXdQWkhlbEViMVhjQjIvbXJZSWlaZkZvUUI5K1ozNkYzS051UDR5"
+ "cTdGcQpacWV5L0NLRFN4OTl4ckJwaTlLVENJUTl6UE5QS0xiSk0xUWFSVlNMNEhIcmh6dFJQc2Jt"
+ "bzlOS01lVHliSkE5ClpvY0JZRno1d1Q1RWRuZEdRUG51eWhESHY4UHZrbStWQXJnRVpkdUdFL0tI"
+ "T1N6amlOVFE0QUtzaWc2OThFWGYKb0xRc1JYaGhiWEJzWlNCVmMyVnlJQ2hKYm5aaGJHbGtLU0E4"
+ "WlhoaGJYQnNaVUJsZUdGdGNHeGxMbU52YlQ2SQpnUVFURVFnQUtRVUNWbjhHdGdJYkF3VUpBREJD"
+ "Q2djTENRZ0hBd0lCQmhVSUFna0tDd1FXQWdNQkFoNEJBaGVBCkFBb0pFSWJ1TXE0ZVZZTFY0L01B"
+ "L2lSUG41cUttdC9MK0doWVlIcCtlNmRiTHdxRFpCRkI3WGRlTTNZNlVScC8KQVFDZ21NSGM4d21Y"
+ "S0M0QTJUMURPTHdhMUNVVzFLWHBaWm9xWEEwLzFhcHBHcmtCalFSV2Z3YTJFQVlBbnZYZgp0OWg1"
+ "QnYyWTdvckp2UGQvTXNYTlZMc0E1UTh3TTc2TytrRjdWMktsNzBjZitJVDM5UUpWRGtKSk15NjFG"
+ "UEQvClFoME5WNm05VjVsZ0E0U2psamo0SzIvc0ExUlhkRHVtaWFrWk1naUN4eXBveEhjM09uOEdX"
+ "di9kZXl0WExpU2YKQnRrVHpiZEZmMDVHdGk1NXc1cnREQmxEM1o2YmR6U0ZtRS8rK2VFYXR4Uzh5"
+ "NXJBNTM2WmpoSm5RQm43dm1aSQpwb3FUeTR0SEQ3aU5oWjN5eXFjZlpBd3BzSmNpZy9RdGVhZWNF"
+ "UVgvSVlvL01wQllMTkp1V1VSRVpqeERBQU1GCkJmOUxmVlZJakhBdWt3NzUxeHFsQmhaUTRCVVV5"
+ "eHE4UTVicjZXVjJzeVppNnhWSW5OS2h3Q2NGYkZNVjV4TUIKczg3eGFzc1UrVzlaZktuODdScDRp"
+ "a3JxOEVvV3FPZTVMQW93SUF6bHYxVUlzMWRpOENHeStlU1lhYVMzVGd0Ywo2REhGS004Vk5KUU8w"
+ "VWZkUXNwS2FuNUVLL1ZUNy9QQVJONGFKcFZxdjNtYkVFWkdJdDJHMStpUm15VW5LbFd4CkxoaUky"
+ "REs5Rm9CajhucXlJVG1KMTBVTmRib2lmeUtFNTFwU2VlYjN3Rm8yNGhNNlVkbEVwVitQVGJvU0dG"
+ "ZXAKNGQrSVp3UVlFUWdBRHdVQ1ZuOEd0Z0liREFVSkFEQkNDZ0FLQ1JDRzdqS3VIbFdDMVlJT0FR"
+ "Q0FyWXRSZDBqSQpFYWNPbUxRWUNNUzNGVUNQRDc3dFlxd1VqM3NjSGVYWTdBRDhEKzAvMWdDdlZX"
+ "elJuZ1dBSFZidXZxSkhmUEFpCm1HVFVHa1ZHOGNZdlBlUT0KPWtxclcKLS0tLS1FTkQgUEdQIFBV"
+ "QkxJQyBLRVkgQkxPQ0stLS0tLQo=";
+       wxString KeyB = "LS0tLS1CRUdJTiBQR1AgUFVCTElDIEtFWSBCTE9DSy0tLS0tClZlcnNpb246IEdudVBHIHYyCgpt"
+ "UU11QkZaL0tiWVJDQUNqTDdwMDZEVTJaQTZwdmJkZ1BVQU5hd1dwTGt3ZlFnZHdWdkVNcFQvRnZu"
+ "QjNGbDV4CnFFL2dMRFJDZlhLTVF4UEF1NWRBWUVpZVhxN01KN0ZtVXVYbDhJSjZiY3pKRUNmWUF6"
+ "RFJ0VmJlMm5ReXMyUDcKaXBFcnREK1dOZFM5MEVPbFVYb2lhOGR3NmpXczl5QUIvb3BubXBDV21w"
+ "QjI2UVBKNDlNWTBVNWZ1NzhwamJ2MAppMWxmUXIyaWp4QzRDWHZlOGxld05Uak1pOU5UNkt6R1lw"
+ "UXc1MHpXUng0Zk9teENselE5c3lQUWFuZ1htaTVECmk5MytNYXBaSlZpY3UyT3I1VkdqUlRXYWov"
+ "UDNqN1p2REdtNGNwaUhqMURsNTFVam5ZM09xOXE4VnczMkEvK2YKbW9SWWxiY3dtWU1LeVMzMHJx"
+ "SjVCOE0xcTdsenJ3TTBGQXczQVFEN3FnOE9pR2E1emR1UnlYdGlQMFFNSVZBOApDZUxuR25xYUJQ"
+ "dytEYkhDUndmK05ZelJiNUxBUXZQTXpsNlkrUTczb3N4VXhMYzBHOUt5K2tNWVRNSFg5S2xzCmV2"
+ "UThoQkFEc3Y5WDhVeklBRXpLUUJVQ2tWT0JQT2xLMnJiaHdrRzZGendDdzJDemxmU0NXSzBxaWhP"
+ "bGFQVEsKL0c1SVJEQWg2SkFXTitjM1c5SHp1TUN1T1Vhb3didENhU2cxcFdocWNEY2hoWFZtNGdP"
+ "Z3F6cDNkWXdKU3FEQwpCWGV4KzRsWk84TzZSa3BPMVhmTHlkSWpxSlQrQUNMdkFjek8zbW90c2J6"
+ "OEZNWWZzVTQ2ZWsvd05DczZJdlFDCjJQcFFJbHFHU3NmZXFLUGpsUXVGbkRQNHEvNUNlVU5odmZr"
+ "Mm5VeTcwTzc4Z2hFdEViUU44MXNxWUpROHBTdTcKRExjVS8zQ1oyYXJ0RWxkVGJ5a0p1RTJ6a3BV"
+ "MjA1WTJvU0lDMkI1eXFnZjlIeWZOemYxU3lsRVV5d3ZzZ3F2LwpuNUNzbDdobDNML3BSQ1A0dEF0"
+ "NTA5TFFiejNDRk8vSGk3Umg1V3luOFVXZ1EzU0dYdThWQjNrUGhmRkFDNFZPCjJBUVdnMFlDeEth"
+ "SSs1dUljUWRGSDR6b0s0cWNidmxZN0xWNXozOWIza2JGWUgzVytEZjJkNkhJRzZaZUF2aXQKZXhZ"
+ "ZWNlMGNpS0l6dklqVUJydUI0R3BRREhZbGN5QmpxcWtOVE5zTzU4aEsvQisvangxMGdLUVJTa0lw"
+ "c0VJVgpLa0dBRk5sVnlMTGthck1hYnRNWUlzZnBidWtoSjF3d09aTXJITGJwSGxQSFFzSDJJczNI"
+ "dmlkQ2RBdUdRMWQyCjE2U3lEMGFUMHFIMnlkY1V2WFAyUnIwRnFzR3BLY2dWeThMOTcyQWpCTmRT"
+ "RWU0YXVQVGhWRXE5RWtScENSVGIKQUxRdlJYaGhiWEJzWlNCVmMyVnlJRElnS0VsdWRtRnNhV1Fw"
+ "SUR4bGVHRnRjR3hsTWtCbGVHRnRjR3hsTG1OdgpiVDZJZ1FRVEVRZ0FLUVVDVm44cHRnSWJBd1VK"
+ "QUNnMkNnY0xDUWdIQXdJQkJoVUlBZ2tLQ3dRV0FnTUJBaDRCCkFoZUFBQW9KRUFBdVBvS2h3WmFq"
+ "VmFFQkFMN01saU5wLzR0cy9QWkQwdlRCcTYySjBUV0hvTjBDcHpqUXJKQUwKblNZeUFQMGJYY0Y4"
+ "UHRFejNlUkJkazBkTlNFeU1EMkVWVGQ0K3hhZTRRNUx4Q3gxU0xrQmpRUldmeW0yRUFZQQp4eWs4"
+ "dUQ4MnZTZ2xORFA0UlQ3ZzExSjdnTXROV1g0SjBEbmdocVZVc0svY2xFQm4yenZYN080eElpQnlu"
+ "VG9wCmRKeDZaeE5pdFBKVG0zZzI4alRLUElKeXlDVGVHLzJiaWtFc0hUYlFpMStpaXBkcEpjZm9E"
+ "cTlJMVBMVk41Mm8KaFVMaUJhdXdwNHFIeTFyTys3ajhtbWVlL1M5ckpzM2NmQnZHR09acmpFK3g4"
+ "TTRMdjJDeGlEWnJzRUFkdHNPUgpnMHgxMFFqNjJwOExuTHg2TzQ4ZWh0cGZTV1JnRmZOdU9vSEJV"
+ "U3RwSW5pMHRrajJSQitGaUgwZWxkc1VyRndMCkFBTUdCZ0NPYzk5bjB3OWEvelRDL0VxSnRjU2ll"
+ "RkNtckMvODYrcW12OEJ3aW5zdU1STUtVSG1UdFFkR1RRQkcKL0ZXa2pKYm9YMEhZckp0d1JBaC9t"
+ "M2N6UnNMZjZkT3QxL2hEUVF2ZGVIcVhuZ1JleitWNzAyY0pUVVdwVGg5RgpjYnZ3NFpjMk93Yzhz"
+ "am13L3dYc2NMK0ZNU09mT3l6eC8xWmxBUDVoSkQ5TTNnV1dEL0ZLSk0weUxSZDI5OW92CkpoNDZV"
+ "VkIvaHdxelEyYnlEUzV2QXhXUlFsT0FHaEdXVzNOcjlQRE82N2dsSWRPM2o5VzN4bENUNjJ4cmEv"
+ "VmMKbDVDTU9qU0lad1FZRVFnQUR3VUNWbjhwdGdJYkRBVUpBQ2cyQ2dBS0NSQUFMajZDb2NHV296"
+ "aThBUUNqc09YbQpGdEFCcEU4b0EzVmtPT1o4b28wMFZTcUhKVFkxRzhpNXgvNmtZQUVBMC9kR0Jm"
+ "RHVhMDBxL2Z1Z3dYTmlPREJXCjh2a2hlMEVIOWFlYzJQaUd3VTg9Cj1ZWmZuCi0tLS0tRU5EIFBH"
+ "UCBQVUJMSUMgS0VZIEJMT0NLLS0tLS0K";
+
+       wxString KeyC = "LS0tLS1CRUdJTiBQR1AgUFVCTElDIEtFWSBCTE9DSy0tLS0tClZlcnNpb246IEdudVB"
+ "HIHYyCgptUU11QkZaL0x3d1JDQUN0cVNJa3hYN2NBWkJHNFlIUmRldkRudndvM1V4dEQ0ZmxmaW"
+ "1NQmdTemUwbHJTMHNjCmEyaDRmMzJ1eklpR2Q1S0plT0psV3AwSUFBOXNCUW5lQVpXVm9XUjZaO"
+ "TlZZnNtUjhoSENZVERqTGpVRUFnMTYKYzNsbUpWbkRqTDF4bmhSR2RjUGJxS2VQOGVuZ0hQWE4w"
+ "M0tuSkVYcUNZSnFNc3NySFNlN3crMFNMeVJPQkJkeQprSE5Lb1B1bUdOUWIvakhLd0QzNFg1SEJ"
+ "MbUVkbXczR1gzNXVwbm9pVnNqSGJzcHY3bVBQRVJxdlNGMUtlTmVHCkhnSllHdlZiNUJZenpMQ3"
+ "dRRXU0VFNVMFRLQytMeUZUUFpPZE9pVzU2RG5qbktrNk1Od2xCWTFDZXRzZFpwR2QKUXFWZmNYd"
+ "FRnNG1SNGZzVVJaQ0JXR0w3OFMrQ2tDUFh4NTRIQVFDbEhVbUFzK3hnV0ExbU11SzVva2FadDYz"
+ "eQoyb09CSXBseXZkcDhreCtVY3dmL2FWUGQ1dGZ2S3JPVTV0VVZDdlpMN0syVnlkNUNSckFTUG9"
+ "3VkwrWmxjYXNDCloyaDEvRGJKQ1FYOVVPTU5LNXVVMUZYNFErLy83OWR3ZlZVOEZYZUpzM1NKeD"
+ "hHQlB3Z0s4RStmait2MWVNSmMKTkhCMlV2eGtrU050akErUHB1dW5sYXhGYWpBRTU2ckt6N2U0N"
+ "GI5NUNjVldkUTAxbTByeGptSGhTUmtXeDlWNQp4cExsbUZ2Q1ZLMXFsMlV5eCtzZU9RQXJpMjBG"
+ "cUUzbktQMU9BNWt2QTd3b2NpZ1JVakVVWk1XOEFxL1daV2xnCnk2YW9pVTFPSlp6Q2tkeStPcWV"
+ "xL0djeWRIYmcwdUZ0N3UvSTROTWFLVlZMREhWdStSWXZlcGlzNy93TVMvclMKQTVwVk56NURRMX"
+ "R3cTlJTWV0NGNGRnBjOFdIeTVnR0pUNEFRVk1UYU5RZ0FuR1JqKytBTEpObCtsc1AzaDBjbwpTa"
+ "0xqOElWbjlkaXRFUGMxRGVRbllUb092WStLSDA3a09MekJmbXcvdmRlTVdkZzd6VDZhQTRza2hB"
+ "L2VHNWdDCm1sL25IQmM1TS9pV2htRE9FUzFXZTRVYWMzbVNWeG9iSS9oYzNlM3pVcTlkQ0F5OFc"
+ "4eUxvUThxMVArTnlScFkKd250bUxuZ2RVek00VTFLbEdMTWx3aGF1V3liQlBHTnlqYy9KUWtvdk"
+ "dVa1g5dHU0cGdzaVlOb2F1MjV5NUs3OQo0Z1MxQUtlQjgya3lteWlQaGQvdnZpK3VhRXIzdFQ5Z"
+ "2x0WjRiaW1YR3ZQZG1xRnV1MkVYTXhmQXJGL21NSzJoClN5Z1BIUG5jVW9kc3NNV0ZxZjEvNWo1"
+ "MkwrTzlUK1RLVXhxQ2RHMVFSOVZDU0NoUDY0c0NFaGpqeis5R1g1eHAKZGJRdlJYaGhiWEJzWlN"
+ "CVmMyVnlJRE1nS0VsdWRtRnNhV1FwSUR4bGVHRnRjR3hsTTBCbGVHRnRjR3hsTG1OdgpiVDZJZ1"
+ "FRVEVRZ0FLUVVDVm44dkRBSWJBd1VKQUFuZU5BY0xDUWdIQXdJQkJoVUlBZ2tLQ3dRV0FnTUJBa"
+ "DRCCkFoZUFBQW9KRU1IakNSbG51dzVEOVFrQS9qWGFUTjJSVEhKSytMWEs1dXJEVDBLTElBTUVW"
+ "ak1lT1dQWmlyVXkKcldnRkFQd09XSi80eDVBT3dvZFVPTnh6Rk5NRXJBV2o5N3Y1bm5ZaURJcm1"
+ "jUjl1ZzdrQmpRUldmeThNRUFZQQorVFBWcit3VGk2U0RxN25pd3pNZUo2c05QMHlwaXVJaTB3c2"
+ "pXRDVndnJROGZqVE41STdtL3hldEhtcXdvbDdiCnhEL09iUE1GRm9Tdm1kRERlVlR5cnl0cDI3U"
+ "05QNVgzUFlxTldKbW9XN09mUTBQRlIvbmprdVNGdmN0NkZDNTMKVjhvU0JPcVVuRWlZckRGSU1z"
+ "REdOQ25UZ1VUeG9GaFZ1MEVESFRhWVFxV2tYMWxldTJFQTlZTjJub3FFVVh2bgpEOE92TXZaWGx"
+ "QcTFzdDVmc2IyODB1RGJYMWRvWVpNK0pPRWo3bHp4bEtzUjJNZFlOallKci9RZUwwaEMxVlpmCk"
+ "FBTUZCZjR0bWdvRmt4a0Y4N2Z4ejB4eU9sYXhGclUzYnhVZXJiYTZPUGZJTjV3cXZmOEFsNGdwZ"
+ "XRRRitNQysKUnBlR01rYk5iaTRwV3MvV1BUbmhIN2R3UTI4a0c3VXFkSjdiMDdYUkpVbTJrenRu"
+ "NGRucFJpTGJBU1Z0MFVlRApxeWpNY1hRa21KTTFjVlNDMWpzY0ROUTl1anNjMXBQUi9iK2xPa0F"
+ "2ZGJtK0x3RHZNMmVJa25LWDZsdkZsa0RlCng1dU82ZXpKTktLZEdMSW53c2hpVHdzSjZoTS9OL3"
+ "JjbGFZeWpsSlBwY216VFhuaks5SmN1SU9MVHVsVXFwQUwKbHQyWXh1aUlad1FZRVFnQUR3VUNWb"
+ "jh2REFJYkRBVUpBQW5lTkFBS0NSREI0d2taWjdzT1E1Uk5BUUNUSHVjOQpjM1dORURZY1hhV2N6"
+ "S3ZwN2R4aWJ1YS9FanNxRC85eHNUOHRZUUQrT2VqRndvRmVrbnpZa2RFMmdJb2ZuaDk0CjdKeUh"
+ "aNDUyTERkamZXQ1BZWFU9Cj16T3NxCi0tLS0tRU5EIFBHUCBQVUJMSUMgS0VZIEJMT0NLLS0tLS"
+ "0K";
+
+       // Check that the vCard 4.0 file loads OK.
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<int,wxString>::iterator TestFileIter;
+       std::map<int,int>::iterator TestFileIntIter;
+
+       // Start with a general key.
+       
+       TestFileIter = TestFile.KeyList.find(0);
+       ASSERT_NE(TestFile.KeyList.end(), TestFileIter);
+       ASSERT_EQ(KeyA, TestFileIter->second);
+       
+       // Check the encoding type.
+       
+       TestFileIter = TestFile.KeyListDataEncType.find(0);
+       ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second.ToStdString());
+       
+       // Check the file type.
+       
+       TestFileIter = TestFile.KeyListDataType.find(0);
+       ASSERT_NE(TestFile.KeyListDataType.end(), TestFileIter);
+       ASSERT_EQ("application/pgp-keys", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.KeyListType.find(0);
+       ASSERT_EQ(TestFile.KeyListType.end(), TestFileIter);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.KeyListAltID.find(0);
+       ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter);
+       ASSERT_EQ("54", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.KeyListPID.find(0);
+       ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter);
+       ASSERT_EQ("51", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.KeyListPref.find(0);
+       ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(52, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.KeyListTokens.find(0);
+       ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter);
+       ASSERT_EQ("KEYS=JUSTONE", TestFileIter->second);
+
+       // Start with a work key.
+       
+       TestFileIter = TestFile.KeyList.find(1);
+       ASSERT_NE(TestFile.KeyList.end(), TestFileIter);
+       ASSERT_EQ(KeyB, TestFileIter->second);
+       
+       // Check the encoding type.
+       
+       TestFileIter = TestFile.KeyListDataEncType.find(1);
+       ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second.ToStdString());
+       
+       // Check the file type.
+       
+       TestFileIter = TestFile.KeyListDataType.find(1);
+       ASSERT_NE(TestFile.KeyListDataType.end(), TestFileIter);
+       ASSERT_EQ("application/pgp-keys", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.KeyListType.find(1);
+       ASSERT_NE(TestFile.KeyListType.end(), TestFileIter);
+       ASSERT_EQ("home", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.KeyListAltID.find(1);
+       ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter);
+       ASSERT_EQ("64", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.KeyListPID.find(1);
+       ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter);
+       ASSERT_EQ("61", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.KeyListPref.find(1);
+       ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(62, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.KeyListTokens.find(1);
+       ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter);
+       ASSERT_EQ("KEYS=NONE", TestFileIter->second);
+
+       // Start with a business key.
+       
+       TestFileIter = TestFile.KeyList.find(2);
+       ASSERT_NE(TestFile.KeyList.end(), TestFileIter);
+       ASSERT_EQ(KeyC, TestFileIter->second);
+       
+       // Check the encoding type.
+       
+       TestFileIter = TestFile.KeyListDataEncType.find(2);
+       ASSERT_NE(TestFile.KeyListDataEncType.end(), TestFileIter);
+       ASSERT_EQ("base64", TestFileIter->second.ToStdString());
+       
+       // Check the file type.
+       
+       TestFileIter = TestFile.KeyListDataType.find(2);
+       ASSERT_NE(TestFile.KeyListDataType.end(), TestFileIter);
+       ASSERT_EQ("application/pgp-keys", TestFileIter->second);
+
+       // Check the TYPE section.
+       
+       TestFileIter = TestFile.KeyListType.find(2);
+       ASSERT_NE(TestFile.KeyListType.end(), TestFileIter);
+       ASSERT_EQ("work", TestFileIter->second);
+       
+       // Check the ALTID section.
+       
+       TestFileIter = TestFile.KeyListAltID.find(2);
+       ASSERT_NE(TestFile.KeyListAltID.end(), TestFileIter);
+       ASSERT_EQ("74", TestFileIter->second);
+       
+       // Check the PID section.
+       
+       TestFileIter = TestFile.KeyListPID.find(2);
+       ASSERT_NE(TestFile.KeyListPID.end(), TestFileIter);
+       ASSERT_EQ("71", TestFileIter->second);
+       
+       // Check the PREF section.
+       
+       TestFileIntIter = TestFile.KeyListPref.find(2);
+       ASSERT_NE(TestFile.KeyListPref.end(), TestFileIntIter);
+       ASSERT_EQ(72, TestFileIntIter->second);
+       
+       // Check the extra tokens.
+       
+       TestFileIter = TestFile.KeyListTokens.find(2);
+       ASSERT_NE(TestFile.KeyListTokens.end(), TestFileIter);
+       ASSERT_EQ("KEYS=MISSING", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, VendorTests){
+
+       ContactDataObject TestFile;
+
+       ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+       std::map<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);
+
+}
+
+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