44 lines
855 B
TypeScript
44 lines
855 B
TypeScript
describe('modInv', function () {
|
|
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)
|
|
},
|
|
{
|
|
a: BigInt(2),
|
|
n: BigInt(4),
|
|
modInv: NaN
|
|
},
|
|
{
|
|
a: BigInt(0),
|
|
n: BigInt(0),
|
|
modInv: NaN
|
|
},
|
|
{
|
|
a: BigInt(0),
|
|
n: BigInt(37),
|
|
modInv: NaN
|
|
}
|
|
]
|
|
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))
|
|
})
|
|
})
|
|
}
|
|
})
|