-
-
Notifications
You must be signed in to change notification settings - Fork 5.8k
Expand file tree
/
Copy pathRepunitTheorem.test.js
More file actions
50 lines (43 loc) · 1.75 KB
/
RepunitTheorem.test.js
File metadata and controls
50 lines (43 loc) · 1.75 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import {
isRepunitDivisibleByPrime,
multiplicativeOrder10,
repunitMod
} from '../RepunitTheorem'
describe('RepunitTheorem', () => {
it('computes multiplicative order examples', () => {
expect(multiplicativeOrder10(11n)).toBe(2n)
expect(multiplicativeOrder10(37n)).toBe(3n)
expect(multiplicativeOrder10(7n)).toBe(6n)
})
it('checks repunit divisibility using the theorem', () => {
// 111111 is divisible by 3, 7, 11, 13, 37
expect(isRepunitDivisibleByPrime(6, 3n)).toBe(true)
expect(isRepunitDivisibleByPrime(6, 7n)).toBe(true)
expect(isRepunitDivisibleByPrime(6, 11n)).toBe(true)
expect(isRepunitDivisibleByPrime(6, 13n)).toBe(true)
expect(isRepunitDivisibleByPrime(6, 37n)).toBe(true)
})
it('returns false when divisibility condition does not hold', () => {
expect(isRepunitDivisibleByPrime(1, 3n)).toBe(false)
expect(isRepunitDivisibleByPrime(3, 3n)).toBe(true)
expect(isRepunitDivisibleByPrime(6, 19n)).toBe(false)
expect(isRepunitDivisibleByPrime(9, 2n)).toBe(false)
expect(isRepunitDivisibleByPrime(9, 5n)).toBe(false)
})
it('computes repunit modulo without building huge integers', () => {
expect(repunitMod(6, 37n)).toBe(0n)
expect(repunitMod(6, 11n)).toBe(0n)
expect(repunitMod(7, 13n)).toBe(1n)
})
it('validates multiplicative order input', () => {
expect(() => multiplicativeOrder10(1n)).toThrow(RangeError)
expect(() => multiplicativeOrder10(10n)).toThrow(RangeError)
})
it('validates repunitMod input', () => {
expect(() => repunitMod(0, 7n)).toThrow(RangeError)
expect(() => repunitMod(5, 0n)).toThrow(RangeError)
})
it('validates repunit divisibility input length', () => {
expect(() => isRepunitDivisibleByPrime(0, 7n)).toThrow(RangeError)
})
})