forked from TheAlgorithms/JavaScript
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLiouvilleFunction.test.js
32 lines (28 loc) · 996 Bytes
/
LiouvilleFunction.test.js
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
import { liouvilleFunction } from '../LiouvilleFunction'
const expectedValuesArray = [
1, -1, -1, 1, -1, 1, -1, -1, 1, 1, -1, -1, -1, 1, 1, 1, -1, -1, -1, -1, 1, 1,
-1, 1, 1, 1, -1, -1, -1, -1, -1, -1, 1, 1, 1, 1, -1, 1, 1, 1, -1, -1, -1, -1,
-1, 1, -1, -1, 1, -1, 1, -1, -1, 1, 1, 1, 1, 1, -1, 1, -1, 1, -1, 1, 1, -1,
-1, -1, 1, -1, -1, -1, -1, 1, -1, -1, 1, -1, -1, -1, 1, 1, -1, 1, 1, 1, 1, 1,
-1, 1, 1, -1, 1, 1, 1, 1, -1, -1, -1, 1
]
describe('Testing liouville function', () => {
for (let i = 1; i <= 100; i++) {
it(
'Testing for number = ' + i + ', should return ' + expectedValuesArray[i],
() => {
expect(liouvilleFunction(i)).toBe(expectedValuesArray[i - 1])
}
)
}
it('should throw error when supplied negative numbers', () => {
expect(() => {
liouvilleFunction(-1)
}).toThrow(Error)
})
it('should throw error when supplied zero', () => {
expect(() => {
liouvilleFunction(0)
}).toThrow(Error)
})
})