+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithMissingFileThenReturnFileMissingError)
+{
+
+ // Given
+
+ ContactDataObject testFile;
+
+ // When
+
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("MissingFile.vcf");
+
+ // Then
+
+ ASSERT_EQ(CONTACTLOAD_FILEMISSING, testFileLoadStatus);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithInvalidPermissionsSetThenReturnInvalidPermissionsError)
+{
+
+ // Given
+
+ ContactDataObject testFile;
+
+ // When
+
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("InvalidPermissions.vcf");
+
+ // Then
+
+ ASSERT_EQ(CONTACTLOAD_FILEERROR, testFileLoadStatus);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithInvalidFormatThenReturnInvalidFormatError)
+{
+
+ // Given
+
+ ContactDataObject testFile;
+
+ // When
+
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("LoadCheck-Load1-v3.vcf");
+
+ // Then
+
+ ASSERT_EQ(CONTACTLOAD_FILEINVALIDFORMAT, testFileLoadStatus);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithNonMeetingBaseSpecificationThenReturnFileBaseSpecificationError)
+{
+
+ // Given
+
+ ContactDataObject testFile;
+
+ // When
+
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("LoadCheck-Load3.vcf");
+
+ // Then
+
+ ASSERT_EQ(CONTACTLOAD_FILEBASESPECFAIL, testFileLoadStatus);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledThenContactLoadedOK)
+{
+
+ // Given
+
+ ContactDataObject testFile;
+
+ // When
+
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+
+ // Then
+
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+}
+
+TEST(ContactLoad, GivenLoadedContactDataObjectWhenContactKindIsCheckedThenContactKindIsIndividual)
+{
+
+ // Check that the kind status has been set. (KIND).
+
+ // Given
+
+ ContactDataObject testFile;
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
+
+ ContactKindType testFileContactKindStatus = testFile.ContactKind;
+
+ // Then
+ // Check that the kind status has been set. (KIND).
+
+ ASSERT_NE(CONTACTKIND_NONE, testFileContactKindStatus);
+ ASSERT_EQ(CONTACTKIND_INDIVIDUAL, testFileContactKindStatus);
+
+}
+
+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);
+
+ // When
+
+ testFileIter = testFile.GroupsList.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.GroupsList.end(), testFileIter);
+ ASSERT_EQ("7a2af44d-6431-4797-a55f-d86d56304fda", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListAltIDForFirstGroupThenOnlyFirstGroupAltIDIsReturned)
+{
+
+ // Check the ALTID parameter for MEMBER.
+
+ std::map<int,wxString>::iterator testFileIter;
+
+ // Given
+
+ ContactDataObject testFile;
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
+
+ testFileIter = testFile.GroupsListAltID.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.GroupsListAltID.end(), testFileIter);
+ ASSERT_EQ("35", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListPIDForFirstGroupThenOnlyFirstGroupPIDIsReturned)
+{
+
+ // Check the PID 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);
+
+ // When
+
+ testFileIter = testFile.GroupsListPID.find(0);
+
+ // 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);
+
+ // When
+
+ testFileIntIter = testFile.GroupsListPref.find(0);
+
+ // 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);
+
+ // When
+
+ testFileIter = testFile.GroupsListMediaType.find(0);
+
+ // 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);
+
+ // When
+
+ testFileIter = testFile.GroupsListTokens.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.GroupsListTokens.end(), testFileIter);
+ ASSERT_EQ("EXAMPLE=Meep", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameForFirstFullNameThenOnlyFirstFullNameIsReturned)
+{
+
+ // Check that the formatted name has been read (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.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);
+
+ // 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);
+
+ // When
+
+ testFileIter = testFile.FullNamesListAltID.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.FullNamesListAltID.end(), testFileIter);
+ ASSERT_EQ("500", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNamePIDForFirstFullNameThenOnlyFirstFullNamePIDIsReturned)
+{
+
+ // 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);
+
+ // When
+
+ 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);
+
+ // When
+
+ testFileIntIter = testFile.FullNamesListPref.find(0);
+
+ // 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);
+
+ // When
+
+ testFileIter = testFile.FullNamesListTokens.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.FullNamesListTokens.end(), testFileIter);
+ ASSERT_EQ("EXAMPLE=Baaa", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenNameValuesAreRetrievedThenValuesForNameIsReturned)
+{
+
+ // Check that the name has been read 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 nameSurname = testFile.NameSurname;
+ wxString nameForename = testFile.NameForename;
+ wxString nameOtherNames = testFile.NameOtherNames;
+ wxString nameTitle = testFile.NameTitle;
+ wxString nameSuffix = testFile.NameSuffix;
+
+ // Then
+
+ 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);
+
+ // When
+
+ wxString nameAltID = testFile.NameAltID;
+
+ // Then
+
+ ASSERT_EQ("3", nameAltID);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenNameLanguageIsRetrievedThenValueforNameLanguageIsReturned)
+{
+
+ // 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);
+
+ // When
+
+ wxString nameLanguage = testFile.NameLanguage;
+
+ // Then
+
+ ASSERT_EQ("kw", nameLanguage);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenNameDisplayAsIsRetrievedThenValueforNameDisplayAsIsReturned)
+{
+
+ // 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;
+
+ // 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);
+
+ // 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, RevisionTests){
+
+ 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){