X-Git-Url: http://Server1/repobrowser/?p=xestiaab%2F.git;a=blobdiff_plain;f=source%2Ftests%2Fxestiaab_contactload.h;h=cb625bbe7dae3d3d24b1d49f9120d31c52be7a54;hp=3886d4c52efc20ba58508a82fdd80a7c24018ce6;hb=03eae8e47936b7a7a1c395d971df33d47bcf9ae7;hpb=a45c3a46e4e37da415a8b8da2aaabe6a4abc4551 diff --git a/source/tests/xestiaab_contactload.h b/source/tests/xestiaab_contactload.h index 3886d4c..cb625bb 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,28 +17,104 @@ // 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; + 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 + + ContactDataObject testFile; + + // When + + ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL; + testFileLoadStatus = testFile.LoadFile("InvalidPermissions.vcf"); - ASSERT_EQ(CONTACTLOAD_FILEERROR, 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; - // Check that the file is a valid vCard 4.0 file. + // When + + ContactLoadStatus testFileLoadStatus = CONTACTLOAD_UNITTESTFAIL; + testFileLoadStatus = testFile.LoadFile("LoadCheck-Load4.vcf"); - ASSERT_EQ(CONTACTLOAD_FILEINVALIDFORMAT, TestFile.LoadFile("LoadCheck-Load1-v3.vcf")); + // Then - // Check that the vCard 4.0 file meets the base specification. + ASSERT_EQ(CONTACTLOAD_OK, testFileLoadStatus); + +} + +TEST(ContactLoad, ContactLoadTests){ + + ContactDataObject TestFile; - ASSERT_EQ(CONTACTLOAD_FILEBASESPECFAIL, TestFile.LoadFile("LoadCheck-Load3.vcf")); + // Check that the file given does not have an error when attempting to + // open it. // Check that the vCard 4.0 file loads OK. @@ -157,6 +233,237 @@ TEST(ContactLoad, ContactLoadTests){ } +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("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); + +} + TEST(ContactLoad, NicknameTests){ ContactDataObject TestFile; @@ -566,7 +873,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 +959,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 +1045,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 +1313,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 +1355,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 +1397,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 +1555,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 +1591,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 +1627,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 +2672,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 +2726,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 +2781,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 +2850,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 +2900,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 +2956,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 +4252,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