mathjs/test/function/combinatorics/bellNumbers.test.js

45 lines
1.6 KiB
JavaScript

var assert = require('assert'),
error = require('../../../lib/error/index'),
math = require('../../../index'),
bellNumbers = math.bellNumbers;
describe('bellNumbers', function() {
it('should calculate the number of partitions of a set', function() {
assert.equal(bellNumbers(3), 5);
assert.equal(bellNumbers(0), 1);
assert.equal(bellNumbers(8), 4140);
});
it('should calculate the bellNumbers of n items with BigNumbers', function(){
assert.deepEqual(bellNumbers(math.bignumber(2)), math.bignumber(2));
assert.deepEqual(bellNumbers(math.bignumber(3)), math.bignumber(5));
});
it('should not work with non-integer and negative input', function() {
assert.throws(function() {bellNumbers(0.5)}, TypeError);
assert.throws(function() {bellNumbers(-1)}, TypeError);
assert.throws(function() {bellNumbers(math.bignumber(-3))}, TypeError);
assert.throws(function() {bellNumbers(math.bignumber(3.5))}, TypeError);
});
it('should throw an error in case of non-integer input', function() {
assert.throws(function() {bellNumbers(5.2)}, /Non-negative integer value expected/);
});
it('should throw an error in case of negative input', function() {
assert.throws(function() {bellNumbers(-2)}, /Non-negative integer value expected/);
});
it('should throw an error in case of wrong number or type of arguments', function() {
assert.throws(function() {bellNumbers(5, 3, 2)});
assert.throws(function() {bellNumbers(true, "hello world")});
});
it('should LaTeX bellNumbers', function () {
var expression = math.parse('bellNumbers(3)');
assert.equal(expression.toTex(), '\\mathrm{B}_{3}');
});
});