On 6/3/2019 2:11 PM, Barret Rhoden wrote:
> Hi -
> 
> On 5/30/19 2:24 PM, Derrick Stolee wrote:
>>> 8934ac8c 1190)     ent->ignored == next->ignored &&
>>> 8934ac8c 1191)     ent->unblamable == next->unblamable) {
>> These lines are part of this diff:
>>
>> --- a/blame.c
>> +++ b/blame.c
>> @@ -479,7 +479,9 @@ void blame_coalesce(struct blame_scoreboard *sb)
>>
>>          for (ent = sb->ent; ent && (next = ent->next); ent = next) {
>>                  if (ent->suspect == next->suspect &&
>> -                   ent->s_lno + ent->num_lines == next->s_lno) {
>> +                   ent->s_lno + ent->num_lines == next->s_lno &&
>> +                   ent->ignored == next->ignored &&
>> +                   ent->unblamable == next->unblamable) {
>>                          ent->num_lines += next->num_lines;
>>                          ent->next = next->next;
>>                          blame_origin_decref(next->suspect);
>>
>> The fact that they are uncovered means that the && chain is short-circuited 
>> at
>> "ent->s_lno + ent->num_lines == next->s_lno" before the new conditions can be
>> checked. So, the block inside is never covered. It includes a call to
>> blame_origin_decref() and free(), so it would be good to try and exercise 
>> this region.
> 
> What is your setup for determining if a line is uncovered?  Are you running 
> something like gcov for all of the tests in t/?
> 
> I removed this change, and none of the other blame tests appeared to trigger 
> this code block either, independently of this change.  (I put an assert(0) 
> inside the block).
> 
> However, two of our blame-ignore tests do get past the first two checks in 
> the if clause, (the suspects are equal and the s_lno chunks are adjacent) and 
> we do check the ignored/unblamable conditions.
> 
> Specifically, if I undo this change and put an assert(0) in that block, two 
> of our tests hit that code, and one of our tests fails if I don't do the 
> check for ignored/unblamable.

The tests use gcov while running the tests in t/. Here is the build [1].

There are some i/o errors happening in the build, which I have not
full diagnosed. It is entirely possible that you actually are covered,
but there was an error collecting the coverage statistics. The simplest
thing to do is to insert a die() statement and re-run the tests.

Thanks,
-Stolee

[1] https://dev.azure.com/git/git/_build/results?buildId=615

Reply via email to