- Author:
- David Nickerson <david.nickerson@gmail.com>
- Date:
- 2021-09-16 00:41:19+12:00
- Desc:
- Updating Noble 1962 model:
* Exposing the membrane potential to the top-level model;
* adding SED-ML for the paced and pacemaker variants of the model.
Using OpenCOR Snapshot release 2021-09-14.
- Permanent Source URI:
- https://models.fieldml.org/workspace/a1/rawfile/f954e59183314cd37f86c8832dc81317d01c8ec5/dojo-presentation/js/dojo/dojox/lang/tests/array.js
dojo.provide("dojox.lang.tests.array");
dojo.require("dojox.lang.functional");
dojo.require("dojox.lang.functional.fold");
dojo.require("dojox.lang.functional.reversed");
(function(){
var df = dojox.lang.functional, v, isOdd = "%2", x = {a: 1, b: 2, c: 3};
var revArrayIter = function(array){
this.array = array;
this.position = array.length - 1;
};
dojo.extend(revArrayIter, {
hasNext: df.lambda("this.position >= 0"),
next: df.lambda("this.array[this.position--]")
});
tests.register("dojox.lang.tests.array", [
function testFilter1(t){ t.assertEqual(df.filter([1, 2, 3], isOdd), [1, 3]); },
function testFilter2(t){ t.assertEqual(df.filter([1, 2, 3], "%2==0"), [2]); },
function testFilterIter(t){
var iter = new revArrayIter([1, 2, 3]);
t.assertEqual(df.filter(iter, isOdd), [3, 1]);
},
function testFilterRev(t){
var iter = new revArrayIter([1, 2, 3]);
t.assertEqual(df.filter(iter, isOdd), df.filterRev([1, 2, 3], isOdd));
},
function testForEach(t){
t.assertEqual((v = [], df.forEach([1, 2, 3], function(x){ v.push(x); }), v), [1, 2, 3]);
},
function testForEachIter(t){
var iter = new revArrayIter([1, 2, 3]);
t.assertEqual((v = [], df.forEach(iter, function(x){ v.push(x); }), v), [3, 2, 1]);
},
function testForEachRev(t){
t.assertEqual((v = [], df.forEachRev([1, 2, 3], function(x){ v.push(x); }), v), [3, 2, 1]);
},
function testMap(t){ t.assertEqual(df.map([1, 2, 3], "+3"), [4, 5, 6]); },
function testMapIter(t){
var iter = new revArrayIter([1, 2, 3]);
t.assertEqual(df.map(iter, "+3"), [6, 5, 4]);
},
function testMapRev(t){
var iter = new revArrayIter([1, 2, 3]);
t.assertEqual(df.map(iter, "+3"), df.mapRev([1, 2, 3], "+3"));
},
function testEvery1(t){ t.assertFalse(df.every([1, 2, 3], isOdd)); },
function testEvery2(t){ t.assertTrue(df.every([1, 3, 5], isOdd)); },
function testEveryIter(t){
var iter = new revArrayIter([1, 3, 5]);
t.assertTrue(df.every(iter, isOdd));
},
function testEveryObj(t){ t.assertFalse(df.every(x, "%2")); },
function testEveryRev1(t){ t.assertFalse(df.everyRev([1, 2, 3], isOdd)); },
function testEveryRev2(t){ t.assertTrue(df.everyRev([1, 3, 5], isOdd)); },
function testSome1(t){ t.assertFalse(df.some([2, 4, 6], isOdd)); },
function testSome2(t){ t.assertTrue(df.some([1, 2, 3], isOdd)); },
function testSomeIter(t){
var iter = new revArrayIter([1, 2, 3]);
t.assertTrue(df.some(iter, isOdd));
},
function testSomeObj(t){ t.assertTrue(df.some(x, "%2")); },
function testSomeRev1(t){ t.assertFalse(df.someRev([2, 4, 6], isOdd)); },
function testSomeRev2(t){ t.assertTrue(df.someRev([1, 2, 3], isOdd)); },
function testReduce1(t){ t.assertEqual(df.reduce([4, 2, 1], "x-y"), 1); },
function testReduce2(t){ t.assertEqual(df.reduce([4, 2, 1], "x-y", 8), 1); },
function testReduceIter(t){
var iter = new revArrayIter([1, 2, 4]);
t.assertEqual(df.reduce(iter, "x-y"), 1);
},
function testReduceRight1(t){ t.assertEqual(df.reduceRight([4, 2, 1], "x-y"), -5); },
function testReduceRight2(t){ t.assertEqual(df.reduceRight([4, 2, 1], "x-y", 8), 1); }
]);
})();