mirror of
https://github.com/josdejong/mathjs.git
synced 2025-12-08 19:46:04 +00:00
133 lines
4.6 KiB
JavaScript
133 lines
4.6 KiB
JavaScript
// test AssignmentNode
|
|
var assert = require('assert');
|
|
var approx = require('../../../tools/approx');
|
|
var math = require('../../../index');
|
|
var Node = require('../../../lib/expression/node/Node');
|
|
var ConstantNode = require('../../../lib/expression/node/ConstantNode');
|
|
var SymbolNode = require('../../../lib/expression/node/SymbolNode');
|
|
var ArrayNode = require('../../../lib/expression/node/ArrayNode');
|
|
var RangeNode = require('../../../lib/expression/node/RangeNode');
|
|
var AssignmentNode = require('../../../lib/expression/node/AssignmentNode');
|
|
var OperatorNode = require('../../../lib/expression/node/OperatorNode');
|
|
|
|
describe('AssignmentNode', function() {
|
|
|
|
it ('should create an AssignmentNode', function () {
|
|
var n = new AssignmentNode('a', new Node());
|
|
assert(n instanceof AssignmentNode);
|
|
assert(n instanceof Node);
|
|
assert.equal(n.type, 'AssignmentNode');
|
|
});
|
|
|
|
it ('should throw an error when calling without new operator', function () {
|
|
assert.throws(function () {AssignmentNode('a', new Node())}, SyntaxError);
|
|
});
|
|
|
|
it ('should throw an error when creating an AssignmentNode with a reserved keyword', function () {
|
|
assert.throws(function () {
|
|
new AssignmentNode('end', new Node());
|
|
}, /Illegal symbol name/)
|
|
});
|
|
|
|
it ('should throw an error on wrong constructor arguments', function () {
|
|
assert.throws(function () {new AssignmentNode()}, TypeError );
|
|
assert.throws(function () {new AssignmentNode(new Node())}, TypeError );
|
|
assert.throws(function () {new AssignmentNode('a')}, TypeError );
|
|
assert.throws(function () {new AssignmentNode(2, new Node())}, TypeError );
|
|
assert.throws(function () {new AssignmentNode(new Node(), new Node())}, TypeError );
|
|
});
|
|
|
|
it ('should compile an AssignmentNode', function () {
|
|
var b = new ConstantNode(3);
|
|
var n = new AssignmentNode('b', b);
|
|
|
|
var expr = n.compile(math);
|
|
|
|
var scope = {};
|
|
assert.equal(expr.eval(scope), 3);
|
|
assert.equal(scope.b, 3);
|
|
});
|
|
|
|
it ('should filter an AssignmentNode', function () {
|
|
var a = new ConstantNode(1);
|
|
var b = new SymbolNode('x');
|
|
var c = new ConstantNode(2);
|
|
var d = new ArrayNode([a, b, c]);
|
|
var e = new AssignmentNode('array', d);
|
|
|
|
assert.deepEqual(e.filter(function (node) {return node instanceof AssignmentNode}),[e]);
|
|
assert.deepEqual(e.filter(function (node) {return node instanceof SymbolNode}), [b]);
|
|
assert.deepEqual(e.filter(function (node) {return node instanceof RangeNode}), []);
|
|
assert.deepEqual(e.filter(function (node) {return node instanceof ConstantNode}), [a, c]);
|
|
assert.deepEqual(e.filter(function (node) {return node instanceof ConstantNode && node.value == '2'}), [c]);
|
|
});
|
|
|
|
it ('should filter an AssignmentNode without expression', function () {
|
|
var e = new AssignmentNode('a', new Node());
|
|
|
|
assert.deepEqual(e.filter(function (node) {return node instanceof AssignmentNode}),[e]);
|
|
assert.deepEqual(e.filter(function (node) {return node instanceof SymbolNode}), []);
|
|
});
|
|
|
|
it ('should map an AssignmentNodes (nested) parameters', function () {
|
|
// a = x + 2
|
|
var a = new SymbolNode('x');
|
|
var b = new ConstantNode(2);
|
|
var c = new OperatorNode('+', 'add', [a, b]);
|
|
var d = new AssignmentNode('a', c);
|
|
|
|
var e = new ConstantNode(3);
|
|
var f = d.map(function (node) {
|
|
return node instanceof SymbolNode && node.name == 'x' ? e : node;
|
|
});
|
|
|
|
assert.notStrictEqual(f, d);
|
|
assert.deepEqual(f.expr.params[0], e);
|
|
assert.deepEqual(f.expr.params[1], b);
|
|
});
|
|
|
|
it ('should map an AssignmentNode itself', function () {
|
|
// a = x + 2
|
|
var a = new SymbolNode('add');
|
|
var b = new ConstantNode(2);
|
|
var c = new OperatorNode('+', 'add', [a, b]);
|
|
var d = new AssignmentNode('a', c);
|
|
|
|
var e = new ConstantNode(5);
|
|
var f = d.map(function (node) {
|
|
return node instanceof AssignmentNode ? e : node;
|
|
});
|
|
|
|
assert.strictEqual(f, e);
|
|
});
|
|
|
|
it ('should clone an AssignmentNode', function () {
|
|
// a = x + 2
|
|
var a = new SymbolNode('add');
|
|
var b = new ConstantNode(2);
|
|
var c = new OperatorNode('+', 'add', [a, b]);
|
|
var d = new AssignmentNode('a', c);
|
|
|
|
var e = d.clone();
|
|
assert(e instanceof AssignmentNode);
|
|
assert.deepEqual(e, d);
|
|
assert.notStrictEqual(e, d);
|
|
assert.notStrictEqual(e.expr, d.expr);
|
|
});
|
|
|
|
it ('should stringify a AssignmentNode', function () {
|
|
var b = new ConstantNode(3);
|
|
var n = new AssignmentNode('b', b);
|
|
|
|
assert.equal(n.toString(), 'b = 3');
|
|
});
|
|
|
|
it ('should LaTeX a AssignmentNode', function () {
|
|
var b = new ConstantNode(3);
|
|
var n = new AssignmentNode('b', b);
|
|
|
|
assert.equal(n.toTex(), '{b}={3}');
|
|
});
|
|
|
|
});
|