var assert = require('assert'), math = require('../../../index'), subset = math.subset, matrix = math.matrix, Range = math.type.Range, Set = math.type.Set, index = math.index; describe('subset', function() { var a = [[1,2], [3,4]]; var b = math.matrix(a); it('should get the right subset of an array', function() { assert.deepEqual(subset(a, index(new Range(0,2), 1)), [[2],[4]]); assert.deepEqual(subset(a, index(1,0)), 3); assert.deepEqual(subset([math.bignumber(2)], index(0)), math.bignumber(2)); }); it('should throw an error if trying to access an invalid subset of an array', function() { assert.throws(function () {subset(a, index(6, 0));}, RangeError); assert.throws(function () {subset(a, index(1));}, RangeError); assert.throws(function () {subset(a, index(1,0,0));}, RangeError); assert.throws(function () {subset(a, index(1.3, 0));}, TypeError); }); it('should get the right subset of an object', function() { var obj = {'foo': 'bar'}; assert.deepEqual(subset(obj, index('foo')), 'bar'); assert.deepEqual(subset(obj, index('bla')), undefined); }); it('should throw an error in case of an invalid subset for an object', function() { var obj = {'foo': 'bar'}; var i = index('a', 'b'); assert.throws(function () {subset(obj, i);}, /DimensionError/); }); it('should get the right subset of a matrix', function() { assert.deepEqual(subset(b, index(new Range(0,2), 1)), matrix([[2],[4]])); assert.deepEqual(subset(b, index(1, 0)), 3); }); it('should get a subset of a matrix returning a null or undefined value', function() { assert.deepEqual(subset([0], index(0)), 0); assert.deepEqual(subset([null], index(0)), null); assert.deepEqual(subset([undefined], index(0)), undefined); assert.deepEqual(subset([null, undefined], index(new Range(0,2))), [null, undefined]); }); it('should throw an error if trying to access an invalid subset of a matrix', function() { assert.throws(function () {subset(b, index(6, 0));}, RangeError); assert.throws(function () {subset(b, index(1));}, RangeError); assert.throws(function () {subset(b, index(1,0,0));}, RangeError); assert.throws(function () {subset(b, index(1.3, 0));}, TypeError); }); var d = [[1,2], [3,4]]; var g = matrix([[1,2], [3,4]]); // TODO: test getting subset of an array and matrix it('should set the right subset of an array', function() { assert.deepEqual(d, [[1,2], [3,4]]); assert.deepEqual(subset(d, index(new Range(0,2), 1), [[-2],[-4]]), [[1,-2], [3,-4]]); assert.deepEqual(d, [[1,2], [3,4]]); assert.deepEqual(subset(d, index(2, new Range(0,2)), [[5,6]]), [[1,2], [3,4], [5,6]]); assert.deepEqual(d, [[1,2], [3,4]]); assert.deepEqual(subset(d, index(0,0), 123), [[123,2], [3,4]]); }); it('should set a subset of an array with uninitialized default value', function() { var a = []; assert.deepEqual(subset(a, index(2), 1), [0,0,1]); assert.deepEqual(subset(a, index(2), 1, math.uninitialized), arr(uninit, uninit,1)); }); it('should throw an error if setting the subset of an array with an invalid replacement', function() { assert.throws(function () {subset(d, index(1), 123);}, RangeError); assert.throws(function () {subset(d, index(1.3,0), 123);}, TypeError); }); it('should set the right subset of a matrix', function() { assert.deepEqual(g, matrix([[1,2], [3,4]])); assert.deepEqual(subset(g, index(new Range(0,2), 1), [[-2],[-4]]), matrix([[1,-2], [3,-4]])); assert.deepEqual(g, matrix([[1,2], [3,4]])); assert.deepEqual(subset(g, index(2, new Range(0,2)), [[5,6]]), matrix([[1,2], [3,4], [5,6]])); }); it('should throw an error if setting the subset of a matrix with an invalid replacement', function() { assert.throws(function () {subset(d, index(1), 123);}, RangeError); assert.throws(function () {subset(d, index(1.3,0), 123);}, TypeError); }); describe('string', function () { it('should get the right subset of a string', function() { assert.deepEqual(subset('hello', index(1)), 'e'); assert.deepEqual(subset('hello', index(new Range(4,-1,-1))), 'olleh'); }); it('should throw an error if trying to access an invalid subset of a string', function() { //assert.throws(function () {subset('hello', 1);}, TypeError); assert.throws(function () {subset('hello', index([6]));}, RangeError); assert.throws(function () {subset('hello', index([-2]));}, RangeError); assert.throws(function () {subset('hello', index([1.3]));}, TypeError); }); it('should set the right subset of a string', function() { var j = 'hello'; assert.deepEqual(subset(j, index(0), 'H'), 'Hello'); assert.deepEqual(j, 'hello'); assert.deepEqual(subset(j, index(5), '!'), 'hello!'); assert.deepEqual(j, 'hello'); assert.deepEqual(subset(j, index(new Range(5,11)), ' world'), 'hello world'); assert.deepEqual(j, 'hello'); }); it('should throw an error when index is out of range for a string', function() { assert.throws(function () {subset('hello', index(5));}, /Index out of range/); assert.throws(function () {subset('hello', index(-1));}, /Index out of range/); }); it('should set the right subset of a string with resizing', function() { var j = ''; var defaultValue = 'i'; assert.deepEqual(subset(j, index(5), '!', defaultValue), 'iiiii!'); }); it('should set a property of an object', function() { var obj = {}; var res = subset(obj, index('foo'), 'bar'); assert.deepEqual(res, {foo: 'bar'}); assert.deepEqual(obj, {}); // should leave the original object untouched }); it('should throw an error if setting the subset of a string with an invalid replacement', function() { assert.throws(function () {subset('hello', index([1,2]), '1234');}, RangeError); assert.throws(function () {subset('hello', index(1,2), 'a');}, RangeError); }); it('should throw an error if in case of dimensions mismatch', function() { assert.throws(function () {subset('hello', index(1,2));}, /Dimension mismatch/); assert.throws(function () {subset('hello', index(1,2), 'a');}, /Dimension mismatch/); }); it('should throw an error if in case of a default value with length > 0', function() { assert.throws(function () {subset('hello', index(10), '!', 'foo');}, /Single character expected as defaultValue/); }); it('should throw an error if in case of an invalid index type', function() { assert.throws(function () {subset('hello', 2);}, /TypeError: Unexpected type of argument/); assert.throws(function () {subset('hello', 2, 'A');}, /TypeError: Unexpected type of argument/); }); }); it('should throw an error in case of invalid number of arguments', function() { assert.throws(function () {subset();}, /TypeError: Too few arguments/); assert.throws(function () {subset(d);}, /TypeError: Too few arguments/); assert.throws(function () {subset(d, index(0,0), 1, 0, 5);}, /TypeError: Too many arguments/); }); it('should throw an error in case of invalid type of arguments', function() { assert.throws(function () {subset([1,2], [0]);}, /TypeError: Unexpected type of argument/); //assert.throws(function () {subset(new Date(), index(0));}, /TypeError: Unexpected type of argument/); // FIXME: should fail too. Problem is, Date is also an Object // assert.throws(function () {subset(/foo/, index(0));}, /TypeError: Unexpected type of argument/); // FIXME: should fail too. Problem is, Date is also an Object }); it('should LaTeX subset', function () { var expression = math.parse('subset([1],index(0,0))'); assert.equal(expression.toTex(), '\\mathrm{subset}\\left(\\begin{bmatrix}1\\\\\\end{bmatrix},\\mathrm{index}\\left(0,0\\right)\\right)'); }); }); /** * Helper function to create an Array containing uninitialized values * Example: arr(uninit, uninit, 2); // [ , , 2 ] */ var uninit = {}; function arr() { var array = []; array.length = arguments.length; for (var i = 0; i < arguments.length; i++) { var value = arguments[i]; if (value !== uninit) { array[i] = value; } } return array; }