2025-07-16 10:40:13 +02:00

144 lines
3.6 KiB
JavaScript

import assert from 'assert'
import math from '../../../../src/defaultInstance.js'
import sinon from 'sinon'
const row = math.row
const matrix = math.matrix
describe('row', function () {
const a = [
[0, 2, 0, 0, 0],
[0, 1, 0, 2, 4],
[0, 0, 0, 0, 0],
[8, 4, 0, 3, 0],
[0, 0, 0, 6, 0]
]
const m = matrix(a)
it('should throw an error if the row is out of range', function () {
assert.throws(function () {
const r = row(m, 9)
assert.deepStrictEqual(
r.valueOf(), [[0], [0], [0], [0], [0]]
)
}, /IndexError: Index out of range \(9 > 4\)/)
})
it('should throw an error if the row is not an integer', function () {
assert.throws(function () {
const r = row(m, 'x')
assert.deepStrictEqual(
r.valueOf(), [[0], [0], [0], [0], [0]]
)
}, /Error: Cannot convert "x" to a number/)
})
it('should throw an error if the matrix does not have two dimensions', function () {
assert.throws(function () {
const m = matrix([[[1, 2, 3]]])
const r = row(m, 0)
assert.deepStrictEqual(
r.valueOf(), [[0], [0], [0], [0], [0]]
)
}, /Error: Only two dimensional matrix is supported/)
})
it('should return the first matrix row', function () {
const r = row(m, 0)
assert.deepStrictEqual(
r.valueOf(), [[0, 2, 0, 0, 0]]
)
})
it('should return the first array row', function () {
const r = row(a, 0)
assert.deepStrictEqual(
r.valueOf(), [[0, 2, 0, 0, 0]]
)
})
it('should return the last matrix row', function () {
const r = row(m, 4)
assert.deepStrictEqual(
r.valueOf(), [[0, 0, 0, 6, 0]]
)
})
it('should return the last array row', function () {
const r = row(a, 4)
assert.deepStrictEqual(
r.valueOf(), [[0, 0, 0, 6, 0]]
)
})
it('should return an intermediate matrix row', function () {
const r = row(m, 1)
assert.deepStrictEqual(
r.valueOf(), [[0, 1, 0, 2, 4]]
)
})
it('should return an intermediate array row', function () {
const r = row(a, 1)
assert.deepStrictEqual(
r.valueOf(), [[0, 1, 0, 2, 4]]
)
})
it('should return the row of an 1x1 array', function () {
assert.deepStrictEqual(row([[5]], 0), [[5]])
assert.deepStrictEqual(row([[5], [6], [7]], 0), [[5]])
})
it('should return the row of an 1x1 matrix', function () {
assert.deepStrictEqual(row(matrix([[5]]), 0), matrix([[5]]))
assert.deepStrictEqual(row(matrix([[5], [6], [7]]), 0), matrix([[5]]))
})
it('should return an empty matrix row', function () {
const r = row(m, 2)
assert.deepStrictEqual(
r.valueOf(), [[0, 0, 0, 0, 0]]
)
})
it('should return an empty array row', function () {
const r = row(a, 2)
assert.deepStrictEqual(
r.valueOf(), [[0, 0, 0, 0, 0]]
)
})
it('should work with config legacySubset during deprecation', function () {
const math2 = math.create()
// Add a spy to temporarily disable console.warn
const warnStub = sinon.stub(console, 'warn')
math2.config({ legacySubset: true })
const a = [
[0, 2, 0, 0, 0],
[0, 1, 0, 2, 4],
[0, 0, 0, 0, 0],
[8, 4, 0, 3, 0],
[0, 0, 0, 6, 0]
]
// Test row with legacySubset syntax
// This is not strictly necessary and should be removed after the deprecation period
assert.deepStrictEqual(
math2.row(a, 3).valueOf(), [[8, 4, 0, 3, 0]]
)
// Test row without legacySubset syntax
math2.config({ legacySubset: false })
assert.deepStrictEqual(
math2.row(a, 3).valueOf(), [[8, 4, 0, 3, 0]]
)
// Restore console.warn
warnStub.restore()
})
})