mathjs/test/function/arithmetic/unaryPlus.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

98 lines
4.0 KiB
JavaScript

// test unary plus
const assert = require('assert')
const math = require('../../../src/main')
const bignumber = math.bignumber
const fraction = math.fraction
describe('unaryPlus', function () {
it('should return unary plus of a boolean', function () {
assert.strictEqual(math.unaryPlus(true), 1)
assert.strictEqual(math.unaryPlus(false), 0)
})
it('should return bignumber unary plus of a boolean', function () {
const bigmath = math.create({ number: 'BigNumber' })
assert.deepStrictEqual(bigmath.unaryPlus(true), bigmath.bignumber(1))
assert.deepStrictEqual(bigmath.unaryPlus(false), bigmath.bignumber(0))
})
it('should return unary plus on a string', function () {
assert.strictEqual(math.unaryPlus('2'), 2)
assert.strictEqual(math.unaryPlus('-2'), -2)
})
it('should return bignumber unary plus on a string', function () {
const bigmath = math.create({ number: 'BigNumber' })
assert.deepStrictEqual(bigmath.unaryPlus('2'), bigmath.bignumber(2))
assert.deepStrictEqual(bigmath.unaryPlus('-2'), bigmath.bignumber(-2))
})
// TODO: this is temporary until the test above works again
it('should return bignumber unary plus on a string', function () {
const bigmath = math.create({ number: 'BigNumber' })
const a = bigmath.unaryPlus('2')
assert(a instanceof math.type.BigNumber)
assert.deepStrictEqual(a.toString(), '2')
const b = bigmath.unaryPlus('-2')
assert(b instanceof math.type.BigNumber)
assert.deepStrictEqual(b.toString(), '-2')
})
it('should perform unary plus of a number', function () {
assert.deepStrictEqual(math.unaryPlus(2), 2)
assert.deepStrictEqual(math.unaryPlus(-2), -2)
assert.deepStrictEqual(math.unaryPlus(0), 0)
})
it('should perform unary plus of a big number', function () {
assert.deepStrictEqual(math.unaryPlus(bignumber(2)), bignumber(2))
assert.deepStrictEqual(math.unaryPlus(bignumber(-2)), bignumber(-2))
assert.deepStrictEqual(math.unaryPlus(bignumber(0)).valueOf(), bignumber(0).valueOf())
})
it('should perform unary plus of a fraction', function () {
const a = fraction(0.5)
assert(math.unaryPlus(a) instanceof math.type.Fraction)
assert.strictEqual(a.toString(), '0.5')
assert.strictEqual(math.unaryPlus(fraction(0.5)).toString(), '0.5')
assert.strictEqual(math.unaryPlus(fraction(-0.5)).toString(), '-0.5')
})
it('should perform unary plus of a complex number', function () {
assert.strictEqual(math.unaryPlus(math.complex(3, 2)).toString(), '3 + 2i')
assert.strictEqual(math.unaryPlus(math.complex(3, -2)).toString(), '3 - 2i')
assert.strictEqual(math.unaryPlus(math.complex(-3, 2)).toString(), '-3 + 2i')
assert.strictEqual(math.unaryPlus(math.complex(-3, -2)).toString(), '-3 - 2i')
})
it('should perform unary plus of a unit', function () {
assert.strictEqual(math.unaryPlus(math.unit(5, 'km')).toString(), '5 km')
})
it('should perform element-wise unary plus on a matrix', function () {
const a2 = math.matrix([[1, 2], [3, 4]])
const a7 = math.unaryPlus(a2)
assert.ok(a7 instanceof math.type.Matrix)
assert.deepStrictEqual(a7.size(), [2, 2])
assert.deepStrictEqual(a7.valueOf(), [[1, 2], [3, 4]])
assert.deepStrictEqual(math.unaryPlus([[1, 2], [3, 4]]), [[1, 2], [3, 4]])
})
it('should throw an error in case of invalid number of arguments', function () {
assert.throws(function () { math.unaryPlus() }, /TypeError: Too few arguments/)
assert.throws(function () { math.unaryPlus(1, 2) }, /TypeError: Too many arguments/)
})
it('should throw an error in case of invalid type of argument', function () {
assert.throws(function () { math.unaryPlus(new Date()) }, /TypeError: Unexpected type of argument/)
assert.throws(function () { math.unaryPlus(null) }, /TypeError: Unexpected type of argument/)
})
it('should LaTeX unaryPlus', function () {
const expression = math.parse('unaryPlus(1)')
assert.strictEqual(expression.toTex(), '+\\left(1\\right)')
})
})