mathjs/test/expression/node/UpdateNode.test.js
Niels Heisterkamp b7fe0bfbf1 Added LaTeX conversion of expressions using toTex() on expression.
Also added some basic tests, which cover some use cases; but should be expanded.
2014-05-19 08:20:06 +02:00

191 lines
5.9 KiB
JavaScript

// test UpdateNode
var assert = require('assert'),
approx = require('../../../tools/approx'),
mathjs = require('../../../index'),
math = mathjs(),
bigmath = mathjs({number: 'bignumber'}),
Node = require('../../../lib/expression/node/Node'),
ConstantNode = require('../../../lib/expression/node/ConstantNode'),
RangeNode = require('../../../lib/expression/node/RangeNode'),
IndexNode = require('../../../lib/expression/node/IndexNode'),
UpdateNode = require('../../../lib/expression/node/UpdateNode'),
SymbolNode = require('../../../lib/expression/node/SymbolNode');
describe('UpdateNode', function() {
it ('should create an UpdateNode', function () {
var a = new SymbolNode('a');
var b = new ConstantNode('number', '2');
var c = new ConstantNode('number', '1');
var i = new IndexNode(a, [b, c]);
var v = new ConstantNode('number', '5');
var n = new UpdateNode(i, v);
assert(n instanceof UpdateNode);
assert(n instanceof Node);
assert.equal(n.type, 'UpdateNode');
});
it ('should throw an error when calling without new operator', function () {
var a = new SymbolNode('a');
var b = new ConstantNode('number', '2');
var c = new ConstantNode('number', '1');
var i = new IndexNode(a, [b, c]);
var v = new ConstantNode('number', '5');
assert.throws(function () {UpdateNode(i, v)}, SyntaxError);
});
it ('should throw an error when calling with wrong arguments', function () {
var a = new SymbolNode('a');
var b = new ConstantNode('number', '2');
var c = new ConstantNode('number', '1');
var i = new IndexNode(a, [b, c]);
var v = new ConstantNode('number', '5');
assert.throws(function () {new UpdateNode([2, 3], v)}, TypeError);
assert.throws(function () {new UpdateNode(i, 5)}, TypeError);
assert.throws(function () {new UpdateNode()}, TypeError);
});
it ('should compile an UpdateNode', function () {
var a = new SymbolNode('a');
var ranges = [
new ConstantNode('number', '2'),
new ConstantNode('number', '1')
];
var v = new ConstantNode('number', '5');
var n = new UpdateNode(new IndexNode(a, ranges), v);
var expr = n.compile(math);
var scope = {
a: [[0, 0], [0, 0]]
};
assert.deepEqual(expr.eval(scope), [[0, 0], [5, 0]]);
assert.deepEqual(scope, {
a: [[0, 0], [5, 0]]
});
});
it ('should compile a UpdateNode with range and context parameters', function () {
var a = new SymbolNode('a');
var ranges = [
new ConstantNode('number', '2'),
new RangeNode([
new ConstantNode('number', '1'),
new SymbolNode('end')
])
];
var b = new SymbolNode('b');
var n = new UpdateNode(new IndexNode(a, ranges), b);
var expr = n.compile(math);
var scope = {
a: [[0, 0], [0, 0]],
b: [5, 6]
};
assert.deepEqual(expr.eval(scope), [[0, 0], [5, 6]]);
assert.deepEqual(scope, {
a: [[0, 0], [5, 6]],
b: [5, 6]
});
});
it ('should compile a UpdateNode with negative step range and context parameters', function () {
var a = new SymbolNode('a');
var ranges = [
new ConstantNode('number', '2'),
new RangeNode([
new SymbolNode('end'),
new ConstantNode('number', '1'),
new ConstantNode('number', '-1')
])
];
var b = new SymbolNode('b');
var n = new UpdateNode(new IndexNode(a, ranges), b);
var expr = n.compile(math);
var scope = {
a: [[0, 0], [0, 0]],
b: [5, 6]
};
assert.deepEqual(expr.eval(scope), [[0, 0], [6, 5]]);
assert.deepEqual(scope, {
a: [[0, 0], [6, 5]],
b: [5, 6]
});
});
it ('should compile a UpdateNode with bignumber setting', function () {
var a = new SymbolNode('a');
var ranges = [
new ConstantNode('number', '2'),
new ConstantNode('number', '1')
];
var v = new ConstantNode('number', '5');
var n = new UpdateNode(new IndexNode(a, ranges), v);
var expr = n.compile(bigmath);
var scope = {
a: [[0, 0], [0, 0]]
};
assert.deepEqual(expr.eval(scope), [[0, 0], [bigmath.bignumber(5), 0]]);
assert.deepEqual(scope, {
a: [[0, 0], [bigmath.bignumber(5), 0]]
});
});
it ('should find a UpdateNode', function () {
var a = new SymbolNode('a');
var b = new ConstantNode('number', '2');
var c = new ConstantNode('number', '1');
var i = new IndexNode(a, [b, c]);
var v = new ConstantNode('number', '2');
var n = new UpdateNode(i, v);
assert.deepEqual(n.find({type: UpdateNode}), [n]);
assert.deepEqual(n.find({type: SymbolNode}), [a]);
assert.deepEqual(n.find({type: ConstantNode}), [b, c, v]);
assert.deepEqual(n.find({properties: {value: '1'}}), [c]);
assert.deepEqual(n.find({properties: {value: '2'}}), [b, v]);
assert.deepEqual(n.find({properties: {name: 'q'}}), []);
});
it ('should match a UpdateNode', function () {
var a = new SymbolNode('a');
var b = new ConstantNode('number', '2');
var c = new ConstantNode('number', '1');
var i = new IndexNode(a, [b, c]);
var v = new ConstantNode('number', '5');
var n = new UpdateNode(i, v);
assert.equal(n.match({type: UpdateNode}), true);
assert.equal(n.match({type: ConstantNode}), false);
});
it ('should stringify a UpdateNode', function () {
var a = new SymbolNode('a');
var ranges = [
new ConstantNode('number', '2'),
new ConstantNode('number', '1')
];
var v = new ConstantNode('number', '5');
var n = new UpdateNode(new IndexNode(a, ranges), v);
assert.equal(n.toString(), 'a[2, 1] = 5');
});
it ('should LaTeX a UpdateNode', function () {
var a = new SymbolNode('a');
var ranges = [
new ConstantNode('number', '2'),
new ConstantNode('number', '1')
];
var v = new ConstantNode('number', '5');
var n = new UpdateNode(new IndexNode(a, ranges), v);
assert.equal(n.toString(), 'a[2, 1] = 5');
});
});