summaryrefslogtreecommitdiffstatshomepage
path: root/includes/js/dojox/data/tests/stores/CsvStore.js
diff options
context:
space:
mode:
Diffstat (limited to 'includes/js/dojox/data/tests/stores/CsvStore.js')
-rw-r--r--includes/js/dojox/data/tests/stores/CsvStore.js1127
1 files changed, 1127 insertions, 0 deletions
diff --git a/includes/js/dojox/data/tests/stores/CsvStore.js b/includes/js/dojox/data/tests/stores/CsvStore.js
new file mode 100644
index 0000000..c1bad11
--- /dev/null
+++ b/includes/js/dojox/data/tests/stores/CsvStore.js
@@ -0,0 +1,1127 @@
+if(!dojo._hasResource["dojox.data.tests.stores.CsvStore"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
+dojo._hasResource["dojox.data.tests.stores.CsvStore"] = true;
+dojo.provide("dojox.data.tests.stores.CsvStore");
+dojo.require("dojox.data.CsvStore");
+dojo.require("dojo.data.api.Read");
+dojo.require("dojo.data.api.Identity");
+
+dojox.data.tests.stores.CsvStore.getDatasource = function(filepath){
+ // summary:
+ // A simple helper function for getting the sample data used in each of the tests.
+ // description:
+ // A simple helper function for getting the sample data used in each of the tests.
+
+ var dataSource = {};
+ if(dojo.isBrowser){
+ dataSource.url = dojo.moduleUrl("dojox.data.tests", filepath).toString();
+ }else{
+ // When running tests in Rhino, xhrGet is not available,
+ // so we have the file data in the code below.
+ switch(filepath){
+ case "stores/movies.csv":
+ var csvData = "";
+ csvData += "Title, Year, Producer\n";
+ csvData += "City of God, 2002, Katia Lund\n";
+ csvData += "Rain,, Christine Jeffs\n";
+ csvData += "2001: A Space Odyssey, 1968, Stanley Kubrick\n";
+ csvData += '"This is a ""fake"" movie title", 1957, Sidney Lumet\n';
+ csvData += "Alien, 1979 , Ridley Scott\n";
+ csvData += '"The Sequel to ""Dances With Wolves.""", 1982, Ridley Scott\n';
+ csvData += '"Caine Mutiny, The", 1954, "Dymtryk ""the King"", Edward"\n';
+ break;
+ case "stores/movies2.csv":
+ var csvData = "";
+ csvData += "Title, Year, Producer\n";
+ csvData += "City of God, 2002, Katia Lund\n";
+ csvData += "Rain,\"\", Christine Jeffs\n";
+ csvData += "2001: A Space Odyssey, 1968, Stanley Kubrick\n";
+ csvData += '"This is a ""fake"" movie title", 1957, Sidney Lumet\n';
+ csvData += "Alien, 1979 , Ridley Scott\n";
+ csvData += '"The Sequel to ""Dances With Wolves.""", 1982, Ridley Scott\n';
+ csvData += '"Caine Mutiny, The", 1954, "Dymtryk ""the King"", Edward"\n';
+ break;
+ case "stores/books.csv":
+ var csvData = "";
+ csvData += "Title, Author\n";
+ csvData += "The Transparent Society, David Brin\n";
+ csvData += "The First Measured Century, Theodore Caplow\n";
+ csvData += "Maps in a Mirror, Orson Scott Card\n";
+ csvData += "Princess Smartypants, Babette Cole\n";
+ csvData += "Carfree Cities, Crawford J.H.\n";
+ csvData += "Down and Out in the Magic Kingdom, Cory Doctorow\n";
+ csvData += "Tax Shift, Alan Thein Durning\n";
+ csvData += "The Sneetches and other stories, Dr. Seuss\n";
+ csvData += "News from Tartary, Peter Fleming\n";
+ break;
+ case "stores/patterns.csv":
+ var csvData = "";
+ csvData += "uniqueId, value\n";
+ csvData += "9, jfq4@#!$!@Rf14r14i5u\n";
+ csvData += "6, BaBaMaSaRa***Foo\n";
+ csvData += "2, bar*foo\n";
+ csvData += "8, 123abc\n";
+ csvData += "4, bit$Bite\n";
+ csvData += "3, 123abc\n";
+ csvData += "10, 123abcdefg\n";
+ csvData += "1, foo*bar\n";
+ csvData += "7, \n";
+ csvData += "5, 123abc\n"
+ break;
+ }
+ dataSource.data = csvData;
+ }
+ return dataSource; //Object
+}
+
+dojox.data.tests.stores.CsvStore.verifyItems = function(csvStore, items, attribute, compareArray){
+ // summary:
+ // A helper function for validating that the items array is ordered
+ // the same as the compareArray
+ if(items.length != compareArray.length){ return false; }
+ for(var i = 0; i < items.length; i++){
+ if(!(csvStore.getValue(items[i], attribute) === compareArray[i])){
+ return false; //Boolean
+ }
+ }
+ return true; //Boolean
+}
+
+dojox.data.tests.stores.CsvStore.error = function(t, d, errData){
+ // summary:
+ // The error callback function to be used for all of the tests.
+ for (i in errData) {
+ console.log(errData[i]);
+ }
+ d.errback(errData);
+}
+
+doh.register("dojox.data.tests.stores.CsvStore",
+ [
+ function testReadAPI_fetch_all(t){
+ // summary:
+ // Simple test of a basic fetch on CsvStore.
+ // description:
+ // Simple test of a basic fetch on CsvStore.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completedAll(items){
+ t.assertTrue((items.length === 7));
+ d.callback(true);
+ }
+
+ //Get everything...
+ csvStore.fetch({ onComplete: completedAll, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_all_withEmptyStringField(t){
+ // summary:
+ // Simple test of a basic fetch on CsvStore.
+ // description:
+ // Simple test of a basic fetch on CsvStore.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies2.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completedAll(items){
+ t.assertTrue((items.length === 7));
+ d.callback(true);
+ }
+
+ //Get everything...
+ csvStore.fetch({ onComplete: completedAll, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_one(t){
+ // summary:
+ // Simple test of a basic fetch on CsvStore of a single item.
+ // description:
+ // Simple test of a basic fetch on CsvStore of a single item.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onComplete(items, request){
+ t.is(1, items.length);
+ d.callback(true);
+ }
+ csvStore.fetch({ query: {Title: "*Sequel*"},
+ onComplete: onComplete,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)
+ });
+ return d; //Object
+ },
+ function testReadAPI_fetch_Multiple(t){
+ // summary:
+ // Simple test of a basic fetch on CsvStore of a single item.
+ // description:
+ // Simple test of a basic fetch on CsvStore of a single item.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+
+ var done = [false, false];
+
+ function onCompleteOne(items, request){
+ done[0] = true;
+ t.is(1, items.length);
+ if(done[0] && done[1]){
+ d.callback(true);
+ }
+ }
+
+ function onCompleteTwo(items, request){
+ done[1] = true;
+ t.is(1, items.length);
+ if(done[0] && done[1]){
+ d.callback(true);
+ }
+ }
+
+ try
+ {
+ csvStore.fetch({ query: {Title: "*Sequel*"},
+ onComplete: onCompleteOne,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)
+ });
+ csvStore.fetch({ query: {Title: "2001:*"},
+ onComplete: onCompleteTwo,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)
+ });
+ }
+ catch(e)
+ {
+ for (i in e) {
+ console.log(e[i]);
+ }
+ }
+
+ return d; //Object
+ },
+ function testReadAPI_fetch_MultipleMixed(t){
+ // summary:
+ // Simple test of a basic fetch on CsvStore of a single item.
+ // description:
+ // Simple test of a basic fetch on CsvStore of a single item.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+
+ var done = [false, false];
+ function onComplete(items, request){
+ done[0] = true;
+ t.is(1, items.length);
+ if(done[0] && done[1]){
+ d.callback(true);
+ }
+ }
+
+ function onItem(item){
+ done[1] = true;
+ t.assertTrue(item !== null);
+ t.is('Dymtryk "the King", Edward', csvStore.getValue(item,"Producer"));
+ t.is('Caine Mutiny, The', csvStore.getValue(item,"Title"));
+ if(done[0] && done[1]){
+ d.callback(true);
+ }
+ }
+
+ csvStore.fetch({ query: {Title: "*Sequel*"},
+ onComplete: onComplete,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)
+ });
+
+ csvStore.fetchItemByIdentity({identity: "6", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_all_streaming(t){
+ // summary:
+ // Simple test of a basic fetch on CsvStore.
+ // description:
+ // Simple test of a basic fetch on CsvStore.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ count = 0;
+
+ function onBegin(size, requestObj){
+ t.assertTrue(size === 7);
+ }
+ function onItem(item, requestObj){
+ t.assertTrue(csvStore.isItem(item));
+ count++;
+ }
+ function onComplete(items, request){
+ t.is(7, count);
+ t.is(null, items);
+ d.callback(true);
+ }
+
+ //Get everything...
+ csvStore.fetch({ onBegin: onBegin,
+ onItem: onItem,
+ onComplete: onComplete,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)
+ });
+ return d; //Object
+ },
+ function testReadAPI_fetch_paging(t){
+ // summary:
+ // Test of multiple fetches on a single result. Paging, if you will.
+ // description:
+ // Test of multiple fetches on a single result. Paging, if you will.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function dumpFirstFetch(items, request){
+ t.is(5, items.length);
+ request.start = 3;
+ request.count = 1;
+ request.onComplete = dumpSecondFetch;
+ csvStore.fetch(request);
+ }
+
+ function dumpSecondFetch(items, request){
+ t.is(1, items.length);
+ request.start = 0;
+ request.count = 5;
+ request.onComplete = dumpThirdFetch;
+ csvStore.fetch(request);
+ }
+
+ function dumpThirdFetch(items, request){
+ t.is(5, items.length);
+ request.start = 2;
+ request.count = 20;
+ request.onComplete = dumpFourthFetch;
+ csvStore.fetch(request);
+ }
+
+ function dumpFourthFetch(items, request){
+ t.is(5, items.length);
+ request.start = 9;
+ request.count = 100;
+ request.onComplete = dumpFifthFetch;
+ csvStore.fetch(request);
+ }
+
+ function dumpFifthFetch(items, request){
+ t.is(0, items.length);
+ request.start = 2;
+ request.count = 20;
+ request.onComplete = dumpSixthFetch;
+ csvStore.fetch(request);
+ }
+
+ function dumpSixthFetch(items, request){
+ t.is(5, items.length);
+ d.callback(true);
+ }
+
+ function completed(items, request){
+ t.is(7, items.length);
+ request.start = 1;
+ request.count = 5;
+ request.onComplete = dumpFirstFetch;
+ csvStore.fetch(request);
+ }
+
+ csvStore.fetch({onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+
+ },
+
+ function testReadAPI_getLabel(t){
+ // summary:
+ // Simple test of the getLabel function against a store set that has a label defined.
+ // description:
+ // Simple test of the getLabel function against a store set that has a label defined.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ args.label = "Title";
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onComplete(items, request){
+ t.assertEqual(items.length, 1);
+ var label = csvStore.getLabel(items[0]);
+ t.assertTrue(label !== null);
+ t.assertEqual("The Sequel to \"Dances With Wolves.\"", label);
+ d.callback(true);
+ }
+ csvStore.fetch({ query: {Title: "*Sequel*"},
+ onComplete: onComplete,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)
+ });
+ return d;
+ },
+ function testReadAPI_getLabelAttributes(t){
+ // summary:
+ // Simple test of the getLabelAttributes function against a store set that has a label defined.
+ // description:
+ // Simple test of the getLabelAttributes function against a store set that has a label defined.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ args.label = "Title";
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onComplete(items, request){
+ t.assertEqual(items.length, 1);
+ var labelList = csvStore.getLabelAttributes(items[0]);
+ t.assertTrue(dojo.isArray(labelList));
+ t.assertEqual("Title", labelList[0]);
+ d.callback(true);
+ }
+ csvStore.fetch({ query: {Title: "*Sequel*"},
+ onComplete: onComplete,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)
+ });
+ return d;
+ },
+ function testReadAPI_getValue(t){
+ // summary:
+ // Simple test of the getValue function of the store.
+ // description:
+ // Simple test of the getValue function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ t.is('Dymtryk "the King", Edward', csvStore.getValue(item,"Producer"));
+ t.is('Caine Mutiny, The', csvStore.getValue(item,"Title"));
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "6", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testReadAPI_getValue_2(t){
+ // summary:
+ // Simple test of the getValue function of the store.
+ // description:
+ // Simple test of the getValue function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ t.is("City of God", csvStore.getValue(item,"Title"));
+ t.is("2002", csvStore.getValue(item,"Year"));
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "0", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testReadAPI_getValue_3(t){
+ // summary:
+ // Simple test of the getValue function of the store.
+ // description:
+ // Simple test of the getValue function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ t.is("1979", csvStore.getValue(item,"Year"));
+ t.is("Alien", csvStore.getValue(item,"Title"));
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "4", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testReadAPI_getValue_4(t){
+ // summary:
+ // Simple test of the getValue function of the store.
+ // description:
+ // Simple test of the getValue function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ t.is("2001: A Space Odyssey", csvStore.getValue(item,"Title"));
+ t.is("Stanley Kubrick", csvStore.getValue(item,"Producer"));
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "2", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+
+ function testReadAPI_getValues(t){
+ // summary:
+ // Simple test of the getValues function of the store.
+ // description:
+ // Simple test of the getValues function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ var names = csvStore.getValues(item,"Title");
+ t.assertTrue(dojo.isArray(names));
+ t.is(1, names.length);
+ t.is("Rain", names[0]);
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "1", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testIdentityAPI_fetchItemByIdentity(t){
+ // summary:
+ // Simple test of the fetchItemByIdentity function of the store.
+ // description:
+ // Simple test of the fetchItemByIdentity function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "1", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+
+ function testIdentityAPI_fetchItemByIdentity_bad1(t){
+ // summary:
+ // Simple test of the fetchItemByIdentity function of the store.
+ // description:
+ // Simple test of the fetchItemByIdentity function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item === null);
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "7", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testIdentityAPI_fetchItemByIdentity_bad2(t){
+ // summary:
+ // Simple test of the fetchItemByIdentity function of the store.
+ // description:
+ // Simple test of the fetchItemByIdentity function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item === null);
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "-1", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testIdentityAPI_fetchItemByIdentity_bad3(t){
+ // summary:
+ // Simple test of the fetchItemByIdentity function of the store.
+ // description:
+ // Simple test of the fetchItemByIdentity function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item === null);
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "999999", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testIdentityAPI_getIdentity(t){
+ // summary:
+ // Simple test of the fetchItemByIdentity function of the store.
+ // description:
+ // Simple test of the fetchItemByIdentity function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.is(7, items.length);
+ var passed = true;
+ for(var i = 0; i < items.length; i++){
+ if(!(csvStore.getIdentity(items[i]) === i)){
+ passed=false;
+ break;
+ }
+ }
+ t.assertTrue(passed);
+ d.callback(true);
+ }
+
+ //Get everything...
+ csvStore.fetch({ onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testIdentityAPI_getIdentityAttributes(t){
+ // summary:
+ // Simple test of the getIdentityAttributes
+ // description:
+ // Simple test of the fetchItemByIdentity function of the store.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(csvStore.isItem(item));
+ t.assertEqual(null, csvStore.getIdentityAttributes(item));
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "1", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testReadAPI_isItem(t){
+ // summary:
+ // Simple test of the isItem function of the store
+ // description:
+ // Simple test of the isItem function of the store
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(csvStore.isItem(item));
+ t.assertTrue(!csvStore.isItem({}));
+ t.assertTrue(!csvStore.isItem({ item: "not an item" }));
+ t.assertTrue(!csvStore.isItem("not an item"));
+ t.assertTrue(!csvStore.isItem(["not an item"]));
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "1", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testReadAPI_hasAttribute(t){
+ // summary:
+ // Simple test of the hasAttribute function of the store
+ // description:
+ // Simple test of the hasAttribute function of the store
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ t.assertTrue(csvStore.hasAttribute(item, "Title"));
+ t.assertTrue(csvStore.hasAttribute(item, "Producer"));
+ t.assertTrue(!csvStore.hasAttribute(item, "Year"));
+ t.assertTrue(!csvStore.hasAttribute(item, "Nothing"));
+ t.assertTrue(!csvStore.hasAttribute(item, "title"));
+
+ //Test that null attributes throw an exception
+ var passed = false;
+ try{
+ csvStore.hasAttribute(item, null);
+ }catch (e){
+ passed = true;
+ }
+ t.assertTrue(passed);
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "1", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testReadAPI_containsValue(t){
+ // summary:
+ // Simple test of the containsValue function of the store
+ // description:
+ // Simple test of the containsValue function of the store
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ t.assertTrue(csvStore.containsValue(item, "Title", "Alien"));
+ t.assertTrue(csvStore.containsValue(item, "Year", "1979"));
+ t.assertTrue(csvStore.containsValue(item, "Producer", "Ridley Scott"));
+ t.assertTrue(!csvStore.containsValue(item, "Title", "Alien2"));
+ t.assertTrue(!csvStore.containsValue(item, "Year", "1979 "));
+ t.assertTrue(!csvStore.containsValue(item, "Title", null));
+
+ //Test that null attributes throw an exception
+ var passed = false;
+ try{
+ csvStore.containsValue(item, null, "foo");
+ }catch (e){
+ passed = true;
+ }
+ t.assertTrue(passed);
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "4", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+ function testReadAPI_getAttributes(t){
+ // summary:
+ // Simple test of the getAttributes function of the store
+ // description:
+ // Simple test of the getAttributes function of the store
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ t.assertTrue(item !== null);
+ t.assertTrue(csvStore.isItem(item));
+
+ var attributes = csvStore.getAttributes(item);
+ t.is(3, attributes.length);
+ for(var i = 0; i < attributes.length; i++){
+ t.assertTrue((attributes[i] === "Title" || attributes[i] === "Year" || attributes[i] === "Producer"));
+ }
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "4", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+
+ function testReadAPI_getAttributes_onlyTwo(t){
+ // summary:
+ // Simple test of the getAttributes function of the store
+ // description:
+ // Simple test of the getAttributes function of the store
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function onItem(item){
+ // Test an item that does not have all of the attributes
+ t.assertTrue(item !== null);
+ t.assertTrue(csvStore.isItem(item));
+
+ var attributes = csvStore.getAttributes(item);
+ t.assertTrue(attributes.length === 2);
+ t.assertTrue(attributes[0] === "Title");
+ t.assertTrue(attributes[1] === "Producer");
+ d.callback(true);
+ }
+ csvStore.fetchItemByIdentity({identity: "1", onItem: onItem, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d;
+ },
+
+ function testReadAPI_getFeatures(t){
+ // summary:
+ // Simple test of the getFeatures function of the store
+ // description:
+ // Simple test of the getFeatures function of the store
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var features = csvStore.getFeatures();
+ var count = 0;
+ for(i in features){
+ t.assertTrue((i === "dojo.data.api.Read" || i === "dojo.data.api.Identity"));
+ count++;
+ }
+ t.assertTrue(count === 2);
+ },
+ function testReadAPI_fetch_patternMatch0(t){
+ // summary:
+ // Function to test pattern matching of everything starting with lowercase e
+ // description:
+ // Function to test pattern matching of everything starting with lowercase e
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.is(2, items.length);
+ var valueArray = [ "Alien", "The Sequel to \"Dances With Wolves.\""];
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "Title", valueArray));
+ d.callback(true);
+ }
+
+ csvStore.fetch({query: {Producer: "* Scott"}, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_patternMatch1(t){
+ // summary:
+ // Function to test pattern matching of everything with $ in it.
+ // description:
+ // Function to test pattern matching of everything with $ in it.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.assertTrue(items.length === 2);
+ var valueArray = [ "jfq4@#!$!@Rf14r14i5u", "bit$Bite"];
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "value", valueArray));
+ d.callback(true);
+ }
+
+ csvStore.fetch({query: {value: "*$*"}, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_patternMatch2(t){
+ // summary:
+ // Function to test exact pattern match
+ // description:
+ // Function to test exact pattern match
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.is(1, items.length);
+ t.assertTrue(csvStore.getValue(items[0], "value") === "bar*foo");
+ d.callback(true);
+ }
+
+ csvStore.fetch({query: {value: "bar\*foo"}, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_patternMatch_caseInsensitive(t){
+ // summary:
+ // Function to test exact pattern match with case insensitivity set.
+ // description:
+ // Function to test exact pattern match with case insensitivity set.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.is(1, items.length);
+ t.assertTrue(csvStore.getValue(items[0], "value") === "bar*foo");
+ d.callback(true);
+ }
+
+ csvStore.fetch({query: {value: "BAR\\*foo"}, queryOptions: {ignoreCase: true}, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_patternMatch_caseSensitive(t){
+ // summary:
+ // Function to test exact pattern match with case insensitivity set.
+ // description:
+ // Function to test exact pattern match with case insensitivity set.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.is(0, items.length);
+ d.callback(true);
+ }
+
+ csvStore.fetch({query: {value: "BAR\\*foo"}, queryOptions: {ignoreCase: false}, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_sortNumeric(t){
+ // summary:
+ // Function to test sorting numerically.
+ // description:
+ // Function to test sorting numerically.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.assertTrue(items.length === 10);
+ // TODO: CsvStore treats everything like a string, so these numbers will be sorted lexicographically.
+ var orderedArray = [ "1", "10", "2", "3", "4", "5", "6", "7", "8", "9" ];
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "uniqueId", orderedArray));
+ d.callback(true);
+ }
+
+ var sortAttributes = [{attribute: "uniqueId"}];
+ csvStore.fetch({onComplete: completed,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d),
+ sort: sortAttributes});
+ return d; //Object
+ },
+ function testReadAPI_fetch_sortNumericDescending(t){
+ // summary:
+ // Function to test sorting numerically.
+ // description:
+ // Function to test sorting numerically.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.is(10, items.length);
+ // TODO: CsvStore treats everything like a string, so these numbers will be sorted lexicographically.
+ var orderedArray = [ "9", "8", "7", "6", "5", "4", "3", "2", "10", "1" ];
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "uniqueId", orderedArray));
+ d.callback(true);
+ }
+
+ var sortAttributes = [{attribute: "uniqueId", descending: true}];
+ csvStore.fetch({ sort: sortAttributes, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_sortNumericWithCount(t){
+ // summary:
+ // Function to test sorting numerically in descending order, returning only a specified number of them.
+ // description:
+ // Function to test sorting numerically in descending order, returning only a specified number of them.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ t.is(5, items.length);
+ // TODO: CsvStore treats everything like a string, so these numbers will be sorted lexicographically.
+ var orderedArray = [ "9", "8", "7", "6", "5" ];
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "uniqueId", orderedArray));
+ d.callback(true);
+ }
+
+ var sortAttributes = [{attribute: "uniqueId", descending: true}];
+ csvStore.fetch({sort: sortAttributes,
+ count: 5,
+ onComplete: completed,
+ onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_sortAlphabetic(t){
+ // summary:
+ // Function to test sorting alphabetic ordering.
+ // description:
+ // Function to test sorting alphabetic ordering.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ //Output should be in this order...
+ var orderedArray = [ "123abc",
+ "123abc",
+ "123abc",
+ "123abcdefg",
+ "BaBaMaSaRa***Foo",
+ "bar*foo",
+ "bit$Bite",
+ "foo*bar",
+ "jfq4@#!$!@Rf14r14i5u",
+ undefined
+ ];
+ t.is(10, items.length);
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "value", orderedArray));
+ d.callback(true);
+ }
+
+ var sortAttributes = [{attribute: "value"}];
+ csvStore.fetch({sort: sortAttributes, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_sortAlphabeticDescending(t){
+ // summary:
+ // Function to test sorting alphabetic ordering in descending mode.
+ // description:
+ // Function to test sorting alphabetic ordering in descending mode.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ //Output should be in this order...
+ var orderedArray = [ undefined,
+ "jfq4@#!$!@Rf14r14i5u",
+ "foo*bar",
+ "bit$Bite",
+ "bar*foo",
+ "BaBaMaSaRa***Foo",
+ "123abcdefg",
+ "123abc",
+ "123abc",
+ "123abc"
+ ];
+ t.is(10, items.length);
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "value", orderedArray));
+ d.callback(true);
+ }
+
+ var sortAttributes = [{attribute: "value", descending: true}];
+ csvStore.fetch({sort: sortAttributes, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_sortMultiple(t){
+ // summary:
+ // Function to test sorting on multiple attributes.
+ // description:
+ // Function to test sorting on multiple attributes.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/patterns.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ var d = new doh.Deferred();
+ function completed(items, request){
+ var orderedArray0 = [ "8", "5", "3", "10", "6", "2", "4", "1", "9", "7" ];
+ var orderedArray1 = [ "123abc",
+ "123abc",
+ "123abc",
+ "123abcdefg",
+ "BaBaMaSaRa***Foo",
+ "bar*foo",
+ "bit$Bite",
+ "foo*bar",
+ "jfq4@#!$!@Rf14r14i5u",
+ undefined
+ ];
+ t.is(10, items.length);
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "uniqueId", orderedArray0));
+ t.assertTrue(dojox.data.tests.stores.CsvStore.verifyItems(csvStore, items, "value", orderedArray1));
+ d.callback(true);
+ }
+
+ var sortAttributes = [{ attribute: "value"}, { attribute: "uniqueId", descending: true}];
+ csvStore.fetch({sort: sortAttributes, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_fetch_sortMultipleSpecialComparator(t){
+ // summary:
+ // Function to test sorting on multiple attributes with a custom comparator.
+ // description:
+ // Function to test sorting on multiple attributes with a custom comparator.
+
+ var args = dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv");
+ var csvStore = new dojox.data.CsvStore(args);
+
+ csvStore.comparatorMap = {};
+ csvStore.comparatorMap["Producer"] = function(a,b){
+ var ret = 0;
+ // We want to sort authors alphabetical by their last name
+ function lastName(name){
+ if(typeof name === "undefined"){ return undefined; }
+
+ var matches = name.match(/\s*(\S+)$/); // Grab the last word in the string.
+ return matches ? matches[1] : name; // Strings with only whitespace will not match.
+ }
+ var lastNameA = lastName(a);
+ var lastNameB = lastName(b);
+ if(lastNameA > lastNameB || typeof lastNameA === "undefined"){
+ ret = 1;
+ }else if(lastNameA < lastNameB || typeof lastNameB === "undefined"){
+ ret = -1;
+ }
+ return ret;
+ };
+
+ var sortAttributes = [{attribute: "Producer", descending: true}, { attribute: "Title", descending: true}];
+
+ var d = new doh.Deferred();
+ function completed(items, findResult){
+ var orderedArray = [5,4,0,3,2,1,6];
+ t.assertTrue(items.length === 7);
+ var passed = true;
+ for(var i = 0; i < items.length; i++){
+ if(!(csvStore.getIdentity(items[i]) === orderedArray[i])){
+ passed=false;
+ break;
+ }
+ }
+ t.assertTrue(passed);
+ d.callback(true);
+ }
+
+ csvStore.fetch({sort: sortAttributes, onComplete: completed, onError: dojo.partial(dojox.data.tests.stores.CsvStore.error, t, d)});
+ return d; //Object
+ },
+ function testReadAPI_functionConformance(t){
+ // summary:
+ // Simple test read API conformance. Checks to see all declared functions are actual functions on the instances.
+ // description:
+ // Simple test read API conformance. Checks to see all declared functions are actual functions on the instances.
+
+ var testStore = new dojox.data.CsvStore(dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv"));
+ var readApi = new dojo.data.api.Read();
+ var passed = true;
+
+ for(i in readApi){
+ if(i.toString().charAt(0) !== '_')
+ {
+ var member = readApi[i];
+ //Check that all the 'Read' defined functions exist on the test store.
+ if(typeof member === "function"){
+ console.log("Looking at function: [" + i + "]");
+ var testStoreMember = testStore[i];
+ if(!(typeof testStoreMember === "function")){
+ console.log("Problem with function: [" + i + "]. Got value: " + testStoreMember);
+ passed = false;
+ break;
+ }
+ }
+ }
+ }
+ t.assertTrue(passed);
+ },
+ function testIdentityAPI_functionConformance(t){
+ // summary:
+ // Simple test identity API conformance. Checks to see all declared functions are actual functions on the instances.
+ // description:
+ // Simple test identity API conformance. Checks to see all declared functions are actual functions on the instances.
+
+ var testStore = new dojox.data.CsvStore(dojox.data.tests.stores.CsvStore.getDatasource("stores/movies.csv"));
+ var identityApi = new dojo.data.api.Identity();
+ var passed = true;
+
+ for(i in identityApi){
+ if(i.toString().charAt(0) !== '_')
+ {
+ var member = identityApi[i];
+ //Check that all the 'Read' defined functions exist on the test store.
+ if(typeof member === "function"){
+ console.log("Looking at function: [" + i + "]");
+ var testStoreMember = testStore[i];
+ if(!(typeof testStoreMember === "function")){
+ passed = false;
+ break;
+ }
+ }
+ }
+ }
+ t.assertTrue(passed);
+ }
+ ]
+);
+
+
+}