mathjs/test/function/utils/isNegative.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

69 lines
2.8 KiB
JavaScript

const assert = require('assert')
const math = require('../../../src/main')
const isNegative = math.isNegative
const bignumber = math.bignumber
const fraction = math.fraction
const complex = math.complex
const unit = math.unit
describe('isNegative', function () {
it('should test whether a number is negative', function () {
assert.strictEqual(isNegative(0), false)
assert.strictEqual(isNegative(-0), false)
assert.strictEqual(isNegative(2), false)
assert.strictEqual(isNegative(-3), true)
assert.strictEqual(isNegative(Infinity), false)
assert.strictEqual(isNegative(-Infinity), true)
assert.strictEqual(isNegative(NaN), false)
})
it('should test whether a boolean is negative', function () {
assert.strictEqual(isNegative(true), false)
assert.strictEqual(isNegative(false), false)
})
it('should test whether a BigNumber is negative', function () {
assert.strictEqual(isNegative(bignumber(0)), false)
assert.strictEqual(isNegative(bignumber(-0)), false)
assert.strictEqual(isNegative(bignumber(2)), false)
assert.strictEqual(isNegative(bignumber(-3)), true)
assert.strictEqual(isNegative(bignumber(Infinity)), false)
assert.strictEqual(isNegative(bignumber(-Infinity)), true)
assert.strictEqual(isNegative(bignumber(NaN)), false)
})
it('should test whether a Fraction is negative', function () {
assert.strictEqual(isNegative(fraction(2)), false)
assert.strictEqual(isNegative(fraction(-3)), true)
assert.strictEqual(isNegative(fraction(0)), false)
assert.strictEqual(isNegative(fraction(-0)), false)
})
it('should test whether a unit is negative', function () {
assert.strictEqual(isNegative(unit('0 m')), false)
assert.strictEqual(isNegative(unit('0 kB')), false)
assert.strictEqual(isNegative(unit('5 cm')), false)
assert.strictEqual(isNegative(unit('-3 inch')), true)
})
it('should test whether a string contains a negative value', function () {
assert.strictEqual(isNegative('2'), false)
assert.strictEqual(isNegative('-2'), true)
assert.strictEqual(isNegative('0'), false)
})
it('should test isNegative element wise on an Array', function () {
assert.deepStrictEqual(isNegative([0, 5, 0, -3]), [false, false, false, true])
})
it('should test isNegative element wise on a Matrix', function () {
assert.deepStrictEqual(isNegative(math.matrix([0, 5, 0, -3])), math.matrix([false, false, false, true]))
})
it('should throw an error in case of unsupported data types', function () {
assert.throws(function () { isNegative(complex(2, 3)) }, /TypeError: Unexpected type of argument/)
assert.throws(function () { isNegative(new Date()) }, /TypeError: Unexpected type of argument/)
assert.throws(function () { isNegative({}) }, /TypeError: Unexpected type of argument/)
})
})