2020-05-11 18:56:30 +00:00
|
|
|
'use strict'
|
|
|
|
|
|
|
|
// Every test file (you can create as many as you want) should start like this
|
|
|
|
// Please, do NOT touch. They will be automatically removed for browser tests -->
|
|
|
|
const _pkg = require('../lib/index.node')
|
|
|
|
const chai = require('chai')
|
|
|
|
// <--
|
|
|
|
|
|
|
|
const inputs = [
|
|
|
|
{
|
|
|
|
a: BigInt(1),
|
|
|
|
n: BigInt(19),
|
|
|
|
modInv: BigInt(1)
|
|
|
|
},
|
|
|
|
{
|
|
|
|
a: BigInt(2),
|
|
|
|
n: BigInt(5),
|
|
|
|
modInv: BigInt(3)
|
|
|
|
},
|
|
|
|
{
|
|
|
|
a: BigInt(-2),
|
|
|
|
n: BigInt(5),
|
|
|
|
modInv: BigInt(2)
|
2020-05-29 15:33:07 +00:00
|
|
|
}]
|
|
|
|
|
|
|
|
const invalidInputs = [
|
2020-05-11 18:56:30 +00:00
|
|
|
{
|
|
|
|
a: BigInt(2),
|
2020-05-29 15:33:07 +00:00
|
|
|
n: BigInt(4)
|
2020-05-11 18:56:30 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
a: BigInt(0),
|
2020-05-29 15:33:07 +00:00
|
|
|
n: BigInt(0)
|
2020-05-11 18:56:30 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
a: BigInt(0),
|
2020-05-29 15:33:07 +00:00
|
|
|
n: BigInt(37)
|
2020-05-11 18:56:30 +00:00
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
describe('modInv', function () {
|
|
|
|
for (const input of inputs) {
|
|
|
|
describe(`modInv(${input.a}, ${input.n})`, function () {
|
|
|
|
it(`should return ${input.modInv}`, function () {
|
|
|
|
const ret = _pkg.modInv(input.a, input.n)
|
|
|
|
// chai.assert( String(ret) === String(input.modInv) );
|
|
|
|
chai.expect(String(ret)).to.be.equal(String(input.modInv))
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
2020-05-29 15:33:07 +00:00
|
|
|
for (const input of invalidInputs) {
|
|
|
|
describe(`modInv(${input.a}, ${input.n})`, function () {
|
|
|
|
it('should throw RangeError', function () {
|
|
|
|
try {
|
|
|
|
_pkg.modInv(input.a, input.n)
|
|
|
|
throw new Error('should have failed')
|
|
|
|
} catch (err) {
|
|
|
|
chai.expect(err).to.be.instanceOf(RangeError)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
2020-05-11 18:56:30 +00:00
|
|
|
})
|