function sumOddFibonacciNumbers(n) {
let result = 1;
let prev = 1, prevprev = 1;
for (let i = 3; i <= n; i ++) {
sum = prev + prevprev;
result += prev % 2 != 0 ? prev : 0;
if (sum > n) return result;
prevprev = prev;
prev = sum;
}
return 1
}
/**
* Test Suite
*/
describe('sumOddFibonacciNumbers()', () => {
it('returns sum of all odd Fibonnci numbers', () => {
// arrange
const num = 10;
// act
const result = sumOddFibonacciNumbers(num);
// log
console.log("result 1: ", result);
// assert
expect(result).toBe(10);
});
it('returns sum of all odd Fibonnci numbers 2nd example', () => {
// arrange
const num = 1000;
// act
const result = sumOddFibonacciNumbers(num);
// log
console.log("result 2: ", result);
// assert
expect(result).toBe(1785);
});
});