mathjs/test/function/arithmetic/square.test.js
greenkeeper[bot] c5971b371a Update standard to the latest version 🚀 (#1226)
* chore(package): update standard to version 12.0.0

* update to new lint version with --fix

I believe this mainly adds whitespace to `{}`'s.

* Replace assert.equal with assert.strictEqual

This breaks a lot of tests which I will endevour to fix in the next
commits.

* Fix most errors due to assert.strictEquals

Some instances of `strictEquals` are replaced by `deepEquals`.
`toString` has been used to make some string comparisions explicit.
Tests will still fail untill #1236 and #1237 are fixed.

* Fix assertion erros due to -0

With node 10, assert.strictEqual no longer considers `0 === -0`.
I missed these first time round as I was using node 8.

* Put toString correct side of bracket

I was converting the constructor to a string rather
than the result of the computation. Oops.

* Fixed #1236: quantileSeq has inconsistant return

* Update package-lock

* Fixed #1237: norm sometimes returning a complex number instead of number

* Fix cli tests

* More changes for standardjs, and fixes in unit tests
2018-09-08 16:33:58 +02:00

70 lines
2.6 KiB
JavaScript

// test square
const assert = require('assert')
const math = require('../../../src/main')
const bignumber = math.bignumber
const fraction = math.fraction
const matrix = math.matrix
const square = math.square
describe('square', function () {
it('should return the square of a boolean', function () {
assert.strictEqual(square(true), 1)
assert.strictEqual(square(false), 0)
})
it('should return the square of a number', function () {
assert.strictEqual(square(4), 16)
assert.strictEqual(square(-2), 4)
assert.strictEqual(square(0), 0)
})
it('should return the square of a big number', function () {
assert.deepStrictEqual(square(bignumber(4)), bignumber(16))
assert.deepStrictEqual(square(bignumber(-2)), bignumber(4))
assert.deepStrictEqual(square(bignumber(0)), bignumber(0))
})
it('should return the square of a fraction', function () {
const a = fraction(0.5)
assert(square(a) instanceof math.type.Fraction)
assert.strictEqual(square(a).toString(), '0.25')
assert.strictEqual(a.toString(), '0.5')
})
it('should throw an error if used with wrong number of arguments', function () {
assert.throws(function () { square() }, /TypeError: Too few arguments/)
assert.throws(function () { square(1, 2) }, /TypeError: Too many arguments/)
})
it('should throw an in case of wrong type of arguments', function () {
assert.throws(function () { square(null) }, /TypeError: Unexpected type of argument/)
})
it('should return the square of a complex number', function () {
assert.deepStrictEqual(square(math.complex('2i')), math.complex('-4'))
assert.deepStrictEqual(square(math.complex('2+3i')), math.complex('-5+12i'))
assert.deepStrictEqual(square(math.complex('2')), math.complex('4'))
})
it('should return the square of a unit', function () {
assert.strictEqual(square(math.unit('4 cm')).toString(), '16 cm^2')
assert.strictEqual(square(math.unit('-2 cm')).toString(), '4 cm^2')
assert.strictEqual(square(math.unit('0 cm')).toString(), '0 cm^2')
})
it('should throw an error when used with a string', function () {
assert.throws(function () { square('text') })
})
it('should return the square of each element in a matrix', function () {
assert.deepStrictEqual(square([2, 3, 4, 5]), [4, 9, 16, 25])
assert.deepStrictEqual(square(matrix([2, 3, 4, 5])), matrix([4, 9, 16, 25]))
assert.deepStrictEqual(square(matrix([[1, 2], [3, 4]])), matrix([[1, 4], [9, 16]]))
})
it('should LaTeX square', function () {
const expression = math.parse('square(4)')
assert.strictEqual(expression.toTex(), '\\left(4\\right)^2')
})
})