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