Skip to content
8 changes: 8 additions & 0 deletions Recursive/Factorial.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,14 @@
*/

const factorial = (n) => {
if (!Number.isInteger(n)) {
throw new RangeError('Not a Whole Number')
}

if (n < 0) {
throw new RangeError('Not a Positive Number')
}

if (n === 0) {
return 1
}
Expand Down
8 changes: 8 additions & 0 deletions Recursive/test/Factorial.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,4 +8,12 @@ describe('Factorial', () => {
it('should return factorial 120 for value "5"', () => {
expect(factorial(5)).toBe(120)
})

it('Throw Error for Invalid Input', () => {
expect(() => factorial('-')).toThrow('Not a Whole Number')
expect(() => factorial(null)).toThrow('Not a Whole Number')
expect(() => factorial(undefined)).toThrow('Not a Whole Number')
expect(() => factorial(3.142)).toThrow('Not a Whole Number')
expect(() => factorial(-1)).toThrow('Not a Positive Number')
})
})