// test hypot import assert from 'assert' import approx from '../../../../tools/approx' import math from '../../../../src/bundleAny' const hypot = math.hypot const bignumber = math.bignumber describe('hypot', function () { it('should return the hypot of numbers', function () { assert.strictEqual(hypot(3, 4), 5) assert.strictEqual(hypot(3, -4), 5) approx.equal(hypot(3, 4, 5), 7.0710678118654755) assert.strictEqual(hypot(-2), 2) assert.strictEqual(hypot(0), 0) assert.strictEqual(hypot(Infinity), Infinity) }) it('should return the hypot of BigNumbers', function () { assert.deepStrictEqual(hypot(bignumber(3), bignumber(4)), bignumber(5)) assert.deepStrictEqual(hypot(bignumber(3), bignumber(-4)), bignumber(5)) assert.deepStrictEqual(hypot(bignumber(3), bignumber(4), bignumber(5)), bignumber('7.07106781186547524400844362104849039284835937688474036588339869')) assert.deepStrictEqual(hypot(bignumber(-2)), bignumber(2)) }) it('should return the hypot of an Array with numbers', function () { assert.strictEqual(hypot([3, 4]), 5) }) it('should return the hypot of an Matrix with numbers', function () { assert.strictEqual(hypot(math.matrix([3, 4])), 5) }) it('should return the hypot of an Array with mixed numbers and BigNumbers', function () { assert.deepStrictEqual(hypot([3, bignumber(4)]), bignumber(5)) }) it('should throw an error in case of invalid number of arguments', function () { assert.throws(function () { hypot() }, /TypeError: Too few arguments/) assert.throws(function () { hypot([], 2) }, /TypeError: Too many arguments/) }) it('should throw an error in case of unsupported types', function () { assert.throws(function () { hypot(new Date()) }, /TypeError: Unexpected type of argument/) assert.throws(function () { hypot([new Date()]) }, /TypeError: Unexpected type of argument/) assert.throws(function () { hypot([2, 3, math.complex()]) }, /TypeError: Unexpected type of argument/) assert.throws(function () { hypot(undefined) }, /TypeError: Unexpected type of argument/) }) it('should LaTeX hypot', function () { const expression = math.parse('hypot(3,4)') assert.strictEqual(expression.toTex(), '\\hypot\\left(3,4\\right)') }) })