X-Git-Url: http://Server1/repobrowser/?a=blobdiff_plain;f=source%2Ftests%2Fxestiaab_contactload.h;h=64678168122799f6da7fd6d00eaff09f7937127f;hb=316e255b6797f8b7a63ccd62e50e39cfcc474c11;hp=3886d4c52efc20ba58508a82fdd80a7c24018ce6;hpb=a45c3a46e4e37da415a8b8da2aaabe6a4abc4551;p=xestiaab%2F.git
diff --git a/source/tests/xestiaab_contactload.h b/source/tests/xestiaab_contactload.h
index 3886d4c..6467816 100644
--- a/source/tests/xestiaab_contactload.h
+++ b/source/tests/xestiaab_contactload.h
@@ -1,6 +1,6 @@
// xestiaab_contactload.h - Xestia Address Book Contact Load Unit Tests.
//
-// (c) 2012-2015 Xestia Software Development.
+// (c) 2012-2017 Xestia Software Development.
//
// This file is part of Xestia Address Book.
//
@@ -17,143 +17,822 @@
// with Xestia Address Book. If not, see
#include
-#include "../contacteditor/ContactDataObject.h"
+#include "../contacteditor/cdo/ContactDataObject.h"
-TEST(ContactLoad, ContactLoadTests){
+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithMissingFileThenReturnFileMissingError)
+{
- ContactDataObject TestFile;
+ // Given
- // Check that the file given is not missing.
+ ContactDataObject testFile;
- ASSERT_EQ(CONTACTLOAD_FILEMISSING, TestFile.LoadFile("MissingFile.vcf"));
+ // When
+
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("MissingFile.vcf");
- // Check that the file given does not have an error when attempting to
- // open it.
+ // Then
+
+ ASSERT_EQ(CONTACTLOAD_FILEMISSING, testFileLoadStatus);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithInvalidPermissionsSetThenReturnInvalidPermissionsError)
+{
+
+ // Given
- ASSERT_EQ(CONTACTLOAD_FILEERROR, TestFile.LoadFile("InvalidPermissions.vcf"));
+ ContactDataObject testFile;
- // Check that the file is a valid vCard 4.0 file.
+ // When
+
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("InvalidPermissions.vcf");
- ASSERT_EQ(CONTACTLOAD_FILEINVALIDFORMAT, TestFile.LoadFile("LoadCheck-Load1-v3.vcf"));
+ // Then
+
+ ASSERT_EQ(CONTACTLOAD_FILEERROR, testFileLoadStatus);
+
+}
- // Check that the vCard 4.0 file meets the base specification.
+TEST(ContactLoad, GivenContactDataObjectWhenLoadFileIsCalledWithInvalidFormatThenReturnInvalidFormatError)
+{
+
+ // Given
+
+ ContactDataObject testFile;
- ASSERT_EQ(CONTACTLOAD_FILEBASESPECFAIL, TestFile.LoadFile("LoadCheck-Load3.vcf"));
+ // When
- // Check that the vCard 4.0 file loads OK.
+ ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL;
+ testFileLoadStatus = testFile.LoadFile("LoadCheck-Load1-v3.vcf");
+
+ // Then
- ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+ 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, TestFile.ContactKind);
- ASSERT_EQ(CONTACTKIND_INDIVIDUAL, TestFile.ContactKind);
+ ASSERT_NE(CONTACTKIND_NONE, testFileContactKindStatus);
+ ASSERT_EQ(CONTACTKIND_INDIVIDUAL, testFileContactKindStatus);
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListForFirstGroupThenOnlyFirstGroupIsReturned)
+{
+
// Check that the groups have been read (MEMBER).
+
+ std::map::iterator testFileIter;
+
+ // Given
+
+ ContactDataObject testFile;
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- std::map::iterator TestFileIter;
- std::map::iterator TestFileIntIter;
+ // When
+
+ testFileIter = testFile.GroupsList.find(0);
- TestFileIter = TestFile.GroupsList.find(0);
+ // Then
- ASSERT_NE(TestFile.GroupsList.end(), TestFileIter);
- ASSERT_EQ("7a2af44d-6431-4797-a55f-d86d56304fda", TestFileIter->second);
+ ASSERT_NE(testFile.GroupsList.end(), testFileIter);
+ ASSERT_EQ("7a2af44d-6431-4797-a55f-d86d56304fda", testFileIter->second);
- // Check the ALTID parameter.
+}
- TestFileIter = TestFile.GroupsListAltID.find(0);
- ASSERT_NE(TestFile.GroupsListAltID.end(), TestFileIter);
- ASSERT_EQ("35", TestFileIter->second);
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListAltIDForFirstGroupThenOnlyFirstGroupAltIDIsReturned)
+{
- // Check the PID parameter.
+ // Check the ALTID parameter for MEMBER.
+
+ std::map::iterator testFileIter;
+
+ // Given
- TestFileIter = TestFile.GroupsListPID.find(0);
- ASSERT_NE(TestFile.GroupsListPID.end(), TestFileIter);
- ASSERT_EQ("40", TestFileIter->second);
+ ContactDataObject testFile;
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- // Check the PREF parameter.
+ // When
- TestFileIntIter = TestFile.GroupsListPref.find(0);
- ASSERT_NE(TestFile.GroupsListPref.end(), TestFileIntIter);
- ASSERT_EQ(45, TestFileIntIter->second);
+ testFileIter = testFile.GroupsListAltID.find(0);
- // Check the MEDIATYPE parameter.
+ // Then
+
+ ASSERT_NE(testFile.GroupsListAltID.end(), testFileIter);
+ ASSERT_EQ("35", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnGroupsListPIDForFirstGroupThenOnlyFirstGroupPIDIsReturned)
+{
+
+ // Check the PID parameter for MEMBER.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
- TestFileIter = TestFile.GroupsListMediaType.find(0);
- ASSERT_NE(TestFile.GroupsListMediaType.end(), TestFileIter);
- ASSERT_EQ("text/plain", TestFileIter->second);
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- // Check the extra tokens parameter.
+ // 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::iterator testFileIter;
+ std::map::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::iterator testFileIter;
+ std::map::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::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
- TestFileIter = TestFile.GroupsListTokens.find(0);
- ASSERT_NE(TestFile.GroupsListTokens.end(), TestFileIter);
- ASSERT_EQ("EXAMPLE=Meep", TestFileIter->second);
+ 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::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- TestFileIter = TestFile.FullNamesList.find(0);
- ASSERT_NE(TestFile.FullNamesList.end(), TestFileIter);
- ASSERT_EQ("Test Contact", TestFileIter->second);
+ // When
- // Check the TYPE parameter.
+ testFileIter = testFile.FullNamesList.find(0);
- TestFileIter = TestFile.FullNamesListType.find(0);
- ASSERT_NE(TestFile.FullNamesListType.end(), TestFileIter);
- ASSERT_EQ("work", TestFileIter->second);
+ // Then
+
+ ASSERT_NE(testFile.FullNamesList.end(), testFileIter);
+ ASSERT_EQ("Test Contact", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameTypeForFirstFullNameThenOnlyFirstFullNameTypeIsReturned)
+{
+
+ // Check the TYPE parameter for FN.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
+
+ testFileIter = testFile.FullNamesListType.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.FullNamesListType.end(), testFileIter);
+ ASSERT_EQ("work", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameLanguageForFirstFullNameThenOnlyFirstFullNameLanguageIsReturned)
+{
+
+ // Check the LANGUAGE parameter for FN.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- // Check the LANGUAGE parameter.
+ // When
+
+ testFileIter = testFile.FullNamesListLanguage.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.FullNamesListLanguage.end(), testFileIter);
+ ASSERT_EQ("kw", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameAltIDForFirstFullNameThenOnlyFirstFullNameAltIDIsReturned)
+{
+
+ // Check the ALTID parameter for FN.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- TestFileIter = TestFile.FullNamesListLanguage.find(0);
- ASSERT_NE(TestFile.FullNamesListLanguage.end(), TestFileIter);
- ASSERT_EQ("kw", TestFileIter->second);
+ // When
- // Check the ALTID parameter.
+ testFileIter = testFile.FullNamesListAltID.find(0);
+
+ // Then
- TestFileIter = TestFile.FullNamesListAltID.find(0);
- ASSERT_NE(TestFile.FullNamesListAltID.end(), TestFileIter);
- ASSERT_EQ("500", TestFileIter->second);
+ ASSERT_NE(testFile.FullNamesListAltID.end(), testFileIter);
+ ASSERT_EQ("500", testFileIter->second);
- // Check the PID parameter.
+}
- TestFileIter = TestFile.FullNamesListPID.find(0);
- ASSERT_NE(TestFile.FullNamesListPID.end(), TestFileIter);
- ASSERT_EQ("40", TestFileIter->second);
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNamePIDForFirstFullNameThenOnlyFirstFullNamePIDIsReturned)
+{
+
+ // Check the PID parameter for FN.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- // Check the PREF parameter.
+ // When
- TestFileIntIter = TestFile.FullNamesListPref.find(0);
- ASSERT_NE(TestFile.FullNamesListPref.end(), TestFileIntIter);
- ASSERT_EQ(45, TestFileIntIter->second);
+ testFileIter = testFile.FullNamesListPID.find(0);
+
+ // Then
+
+ ASSERT_NE(testFile.FullNamesListPID.end(), testFileIter);
+ ASSERT_EQ("40", testFileIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNamePrefForFirstFullNameThenOnlyFirstFullNamePrefIsReturned)
+{
+
+ // Check the PREF parameter for FN.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- // Check for the extra tokens parameter.
+ // When
+
+ testFileIntIter = testFile.FullNamesListPref.find(0);
- TestFileIter = TestFile.FullNamesListTokens.find(0);
- ASSERT_NE(TestFile.FullNamesListTokens.end(), TestFileIter);
- ASSERT_EQ("EXAMPLE=Baaa", TestFileIter->second);
+ // Then
+
+ ASSERT_NE(testFile.FullNamesListPref.end(), testFileIntIter);
+ ASSERT_EQ(45, testFileIntIter->second);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenFindIsCalledOnFullNameExtraTokensForFirstFullNameThenOnlyFirstFullNameExtraTokensIsReturned)
+{
+
+ // Check for the extra tokens parameter for FN.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- // Check that the name has been read (N).
+ // When
- 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);
+ testFileIter = testFile.FullNamesListTokens.find(0);
- // Check the ALTID parameter.
+ // 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::iterator testFileIter;
+ std::map::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("3", TestFile.NameAltID);
+ ASSERT_EQ("Contact", nameSurname);
+ ASSERT_EQ("Test", nameForename);
+ ASSERT_EQ("Example", nameOtherNames);
+ ASSERT_EQ("Robot", nameTitle);
+ ASSERT_EQ("LOONY", nameSuffix);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenNameAltIDIsRetrievedThenValueforNameAltIDIsReturned)
+{
+
+ // Check the ALTID parameter for N.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
- // Check the LANGUAGE parameter.
+ // When
+
+ wxString nameAltID = testFile.NameAltID;
- ASSERT_EQ("kw", TestFile.NameLanguage);
+ // Then
- // Check the SORT-AS parameter.
+ ASSERT_EQ("3", nameAltID);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenNameLanguageIsRetrievedThenValueforNameLanguageIsReturned)
+{
+
+ // Check the LANGUAGE parameter for N.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
+
+ wxString nameLanguage = testFile.NameLanguage;
+
+ // Then
+
+ ASSERT_EQ("kw", nameLanguage);
+
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenNameDisplayAsIsRetrievedThenValueforNameDisplayAsIsReturned)
+{
+
+ // Check the SORT-AS parameter for N.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
+
+ wxString nameDisplayAs = testFile.NameDisplayAs;
+
+ // Then
- ASSERT_EQ("Contact,Test", TestFile.NameDisplayAs);
+ ASSERT_EQ("Contact,Test", nameDisplayAs);
- // Check the extra tokens parameter.
+}
+
+TEST(ContactLoad, GivenContactDataObjectWhenNameExtraTokensIsRetrievedThenValueforNameExtraTokensIsReturned)
+{
+
+ // Check the extra tokens parameter for N.
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
+
+ wxString nameTokens = testFile.NameTokens;
+
+ // Then
+
+ ASSERT_EQ("TEST=Yes", nameTokens);
+
+}
+
+/* TEMPLATE: PLEASE COPY BEFORE USING IT. */
+
+TEST(ContactLoad, GivenWhenThen)
+{
+
+ std::map::iterator testFileIter;
+ std::map::iterator testFileIntIter;
+ ContactDataObject testFile;
+
+ // Given
+
+ ContactLoadStatus testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf");
+ ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus);
+
+ // When
+
+ // Then
+
+}
+
+/* END OF TEMPLATE: LOOK UP */
+
+TEST(ContactLoad, UIDTest){
+
+ ContactDataObject TestFile;
+
+ // Check that the vCard 4.0 file loads OK.
+
+ ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+ ASSERT_EQ("903588-9082374-989120310-AAFECDBCDF", TestFile.UIDToken);
+
+}
+
+TEST(ContactLoad, ClientPIDMapTests){
+
+ ContactDataObject TestFile;
+
+ ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+ std::map::iterator TestFileIter;
+
+ // 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("TEST=Yes", TestFile.NameTokens);
+ ASSERT_EQ("20151227T033000Z", TestFile.Revision);
+ ASSERT_EQ("TEST=YES;DATA=NO;MORE=MAYBE", TestFile.RevisionTokens);
+
+}
+
+TEST(ContactLoad, SourceTests){
+
+ ContactDataObject TestFile;
+
+ // Check that the vCard 4.0 file loads OK.
+
+ ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+ std::map::iterator TestFileIter;
+ std::map::iterator TestFileIntIter;
+
+ // Start with a general source address.
+
+ TestFileIter = TestFile.SourceList.find(0);
+ ASSERT_NE(TestFile.SourceList.end(), TestFileIter);
+ ASSERT_EQ("http://example.com/source/sourcea.vcf", TestFileIter->second);
+
+ // Check the TYPE section.
+
+ TestFileIter = TestFile.SourceListType.find(0);
+ ASSERT_EQ(TestFile.SourceListType.end(), TestFileIter);
+
+ // Check the ALTID section.
+
+ 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.
+
+ TestFileIter = TestFile.SourceList.find(1);
+ ASSERT_NE(TestFile.SourceList.end(), TestFileIter);
+ ASSERT_EQ("http://example.com/source/sourceb.vcf", TestFileIter->second);
+
+ // Check the TYPE section.
+
+ TestFileIter = TestFile.SourceListType.find(1);
+ ASSERT_NE(TestFile.SourceListType.end(), TestFileIter);
+ ASSERT_EQ("home", TestFileIter->second);
+
+ // 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);
+
+ // Check the extra tokens.
+
+ TestFileIter = TestFile.SourceListTokens.find(1);
+ ASSERT_NE(TestFile.SourceListTokens.end(), TestFileIter);
+ ASSERT_EQ("STATUS=ONLINE", TestFileIter->second);
+
+ // 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;
+
+ // Check that the vCard 4.0 file loads OK.
+
+ ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+ std::map::iterator TestFileIter;
+ std::map::iterator TestFileIntIter;
+
+ // Start with the first XML property.
+
+ // Start with a general source address.
+
+ TestFileIter = TestFile.XMLList.find(0);
+ ASSERT_NE(TestFile.XMLList.end(), TestFileIter);
+ ASSERT_EQ("Example Page 1", TestFileIter->second);
+
+ TestFileIter = TestFile.XMLList.find(1);
+ ASSERT_NE(TestFile.XMLList.end(), TestFileIter);
+ ASSERT_EQ("Example Page 2", TestFileIter->second);
+
+ TestFileIter = TestFile.XMLList.find(2);
+ ASSERT_NE(TestFile.XMLList.end(), TestFileIter);
+ ASSERT_EQ("Example Page 3", TestFileIter->second);
}
@@ -566,7 +1245,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 +1331,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 +1417,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 +1685,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 +1727,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 +1769,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 +1927,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 +1963,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 +1999,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 +3044,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 +3098,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 +3153,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 +3222,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 +3272,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 +3328,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);
@@ -3896,4 +4624,144 @@ TEST(ContactLoad, KeyTests){
}
-// TODO: Add tests for the Contact Loading process.
\ No newline at end of file
+TEST(ContactLoad, VendorTests){
+
+ ContactDataObject TestFile;
+
+ ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+ std::map::iterator TestFileIter;
+ std::map::iterator TestFileIntIter;
+
+ // Start with the first vendor namespace.
+
+ TestFileIter = TestFile.VendorList.find(0);
+ ASSERT_NE(TestFile.VendorList.end(), TestFileIter);
+ ASSERT_EQ("Lemon", TestFileIter->second);
+
+ TestFileIter = TestFile.VendorListPEN.find(0);
+ ASSERT_NE(TestFile.VendorListPEN.end(), TestFileIter);
+ ASSERT_EQ("696", TestFileIter->second);
+
+ TestFileIter = TestFile.VendorListElement.find(0);
+ ASSERT_NE(TestFile.VendorListElement.end(), TestFileIter);
+ ASSERT_EQ("CAKE", TestFileIter->second);
+
+ // Start with the second vendor namespace.
+
+ TestFileIter = TestFile.VendorList.find(1);
+ ASSERT_NE(TestFile.VendorList.end(), TestFileIter);
+ ASSERT_EQ("Orange", TestFileIter->second);
+
+ TestFileIter = TestFile.VendorListPEN.find(1);
+ ASSERT_NE(TestFile.VendorListPEN.end(), TestFileIter);
+ ASSERT_EQ("696", TestFileIter->second);
+
+ TestFileIter = TestFile.VendorListElement.find(1);
+ ASSERT_NE(TestFile.VendorListElement.end(), TestFileIter);
+ ASSERT_EQ("DRINK", TestFileIter->second);
+
+ // Start with the third vendor namespace.
+
+ TestFileIter = TestFile.VendorList.find(2);
+ ASSERT_NE(TestFile.VendorList.end(), TestFileIter);
+ ASSERT_EQ("Shiena Nishizawa", TestFileIter->second);
+
+ TestFileIter = TestFile.VendorListPEN.find(2);
+ ASSERT_NE(TestFile.VendorListPEN.end(), TestFileIter);
+ ASSERT_EQ("696", TestFileIter->second);
+
+ TestFileIter = TestFile.VendorListElement.find(2);
+ ASSERT_NE(TestFile.VendorListElement.end(), TestFileIter);
+ ASSERT_EQ("MUSIC", TestFileIter->second);
+
+}
+
+TEST(ContactLoad, XTokenTest){
+
+ ContactDataObject TestFile;
+
+ ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+ std::map::iterator TestFileIter;
+ std::map::iterator TestFileIntIter;
+
+ // Three X-FARM variables.
+
+ TestFileIter = TestFile.XTokenList.find(0);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("Yard", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(0);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("FARM", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenList.find(1);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("Animals", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(1);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("FARM", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenList.find(2);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("Shed", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(2);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("FARM;LOCATION=Back;TYPE=Vehicles", TestFileIter->second.ToStdString());
+
+ // Three X-DISKSERIAL variables.
+
+ TestFileIter = TestFile.XTokenList.find(3);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("14444", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(3);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("DISKSERIAL", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenList.find(4);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("7555", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(4);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("DISKSERIAL", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenList.find(5);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("3250539032590", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(5);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("DISKSERIAL;STATUS=DESTROYED;TYPE=FLASH", TestFileIter->second.ToStdString());
+
+ // Three X-FOODS variables.
+
+ TestFileIter = TestFile.XTokenList.find(6);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("Lemon Cake", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(6);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("FOODS;STATUS=HIGH", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenList.find(7);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("Starrey Gazey Pie", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(7);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("FOODS;STATUS=LOW", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenList.find(8);
+ ASSERT_NE(TestFile.XTokenList.end(), TestFileIter);
+ ASSERT_EQ("Cornish Pasties", TestFileIter->second);
+
+ TestFileIter = TestFile.XTokenListTokens.find(8);
+ ASSERT_NE(TestFile.XTokenListTokens.end(), TestFileIter);
+ ASSERT_EQ("FOODS;STATUS=FAVOURITE;TYPE=CHEESEANDONION", TestFileIter->second.ToStdString());
+
+}
\ No newline at end of file