mathjs/test/function/matrix/size.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

67 lines
2.7 KiB
JavaScript

// test size
const assert = require('assert')
const math = require('../../../src/main')
const size = math.size
const matrix = math.matrix
describe('size', function () {
it('should calculate the size of an array', function () {
assert.deepStrictEqual(size([[1, 2, 3], [4, 5, 6]]), [2, 3])
assert.deepStrictEqual(size([[[1, 2], [3, 4]], [[5, 6], [7, 8]]]), [2, 2, 2])
assert.deepStrictEqual(size([1, 2, 3]), [3])
assert.deepStrictEqual(size([[1], [2], [3]]), [3, 1])
assert.deepStrictEqual(size([100]), [1])
assert.deepStrictEqual(size([[100]]), [1, 1])
assert.deepStrictEqual(size([[[100]]]), [1, 1, 1])
assert.deepStrictEqual(size([]), [0])
assert.deepStrictEqual(size([[]]), [1, 0])
assert.deepStrictEqual(size([[[]]]), [1, 1, 0])
assert.deepStrictEqual(size([[[], []]]), [1, 2, 0])
})
it('should calculate the size of a matrix', function () {
assert.deepStrictEqual(size(matrix()), matrix([0]))
assert.deepStrictEqual(size(matrix([[1, 2, 3], [4, 5, 6]])), matrix([2, 3]))
assert.deepStrictEqual(size(matrix([[], []])), matrix([2, 0]))
})
it('should calculate the size of a range', function () {
assert.deepStrictEqual(size(math.range(2, 6)), matrix([4]))
})
it('should calculate the size of a scalar', function () {
assert.deepStrictEqual(size(2), matrix([]))
assert.deepStrictEqual(size(math.bignumber(2)), matrix([]))
assert.deepStrictEqual(size(math.complex(2, 3)), matrix([]))
assert.deepStrictEqual(size(true), matrix([]))
assert.deepStrictEqual(size(null), matrix([]))
})
it('should calculate the size of a scalar with setting matrix=="array"', function () {
const math2 = math.create({ matrix: 'Array' })
assert.deepStrictEqual(math2.size(2), [])
assert.deepStrictEqual(math2.size(math2.bignumber(2)), [])
assert.deepStrictEqual(math2.size(math2.complex(2, 3)), [])
assert.deepStrictEqual(math2.size('string'), [6])
})
it('should calculate the size of a string', function () {
assert.deepStrictEqual(size('hello'), matrix([5]))
assert.deepStrictEqual(size(''), matrix([0]))
})
it('should throw an error if called with an invalid number of arguments', function () {
assert.throws(function () { size() }, /TypeError: Too few arguments/)
assert.throws(function () { size(1, 2) }, /TypeError: Too many arguments/)
})
it('should throw an error if called with invalid type of arguments', function () {
assert.throws(function () { size(new Date()) }, /TypeError: Unexpected type of argument/)
})
it('should LaTeX size', function () {
const expression = math.parse('size(1)')
assert.strictEqual(expression.toTex(), '\\mathrm{size}\\left(1\\right)')
})
})