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(10), math.bignumber(4)),math.bignumber(34105)); // // assert.deepEqual(bellNumbers(math.bignumber(8), math.bignumber(6)),math.bignumber(266)); // }); 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 not work with the 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}'); }); });