istanbul
istanbul copied to clipboard
Odd branch coverage issues with generator functions
Hi there! So I've been using istanbul for code coverage. Big fan. The project I've been using it on is a React/Redux app that utilizes Redux-Sagas. The big thing with sagas is it's use of generator functions. I've found that there's some ... weird branch-coverage issues when it comes to branch coverage. I've attached a couple screenshots to demonstrate.
data:image/s3,"s3://crabby-images/6c746/6c746236e5aefb9b126a349939e529885a823ddd" alt="screen shot 2016-06-13 at 8 47 37 pm"
data:image/s3,"s3://crabby-images/d8dae/d8dae449874467f41c58380f6d0a51b240545896" alt="screen shot 2016-06-13 at 8 44 33 pm"
data:image/s3,"s3://crabby-images/059bd/059bd0d90978b845eaba6566f06807111af1c45d" alt="screen shot 2016-06-13 at 8 44 42 pm"
Not really sure what's going on with this. I'm not too concerned, as I know I've covered the code. Would just be nice to see those 100% across the board
Same for me, duplicate of https://github.com/gotwarlost/istanbul/issues/248
Is there a workaround possible with /* istanbul ignore XX */
? I tried if
because in the HTML report is shows this 'I' symbol, but nothing changes. When I use next
the whole function is ignored :(
I presume you are transpiling this code? I think what is going on is that the transpiler is putting in a conditional in front of the generator function causing the ignored branch.
Right, I use Babel.
Krishnan Anantheswaran [email protected] schrieb am So., 19. Juni 2016 19:31:
I presume you are transpiling this code? I think what is going on is that the transpiler is putting in a conditional in front of the generator function causing the ignored branch.
— You are receiving this because you are subscribed to this thread. Reply to this email directly, view it on GitHub https://github.com/gotwarlost/istanbul/issues/645#issuecomment-227009619, or mute the thread https://github.com/notifications/unsubscribe/AAJ9OD9r4WWrcahhqlk0JG5UZtY8VBP4ks5qNXzrgaJpZM4I03dM .
:+1:
I was confused by the happy result with no real solution other than pointing the finger at Babel.
I, too, was having this issue with a project I am working on with React/Redux/Sagas. This post sent me looking for a way to skip the coverage on the 'extraneous' if
just to find out that both Babel and Istanbul were correctly reporting coverage from my tests.
Poking with a stick, /* istanbul ignore if */
, didn't seem to help other than making me think harder. I read this article on generators.
given:
function* dataConsumer() {
console.log('Started');
console.log(`1. ${yield}`); // (A)
console.log(`2. ${yield}`);
return 'result';
}
behavior:
> let genObj = dataConsumer();
> genObj.next()
Started
{ value: undefined, done: false }
> genObj.next('a')
1. a
{ value: undefined, done: false }
> genObj.next('b')
2. b
{ value: 'result', done: true }
The underlying result is a branch condition indicating exit with the done
property equal to true. The missing test, in my case, was to call the final next and receive an object with done: true
(This can be extra troublesome in the cases where working with Sagas you might have a sequence of events wrapped in a while(true)
statement. (Following examples from the interwebs doesn't always give you testable code ;-) ))
Hope this is helpful
Is there any update to this issue?
@gdw-atwork nice catch man! You saved my life :)