Hi Shuah!

On 4/27/26 11:14 PM, Shuah Khan wrote:
> On 4/27/26 05:24, Sarthak Sharma wrote:
>> ksft_exit_skip() increments ksft_xskip before printing the KTAP
>> result. As a result, ksft_test_num() already includes the skipped
>> test.
>>
>> Adding 1 to ksft_test_num() increments the printed test number
>> again, producing an incorrect test number and wrong KTAP output.
>>
>> Drop the extra increment and print ksft_test_num() directly.
> 
> I applied this patch to linux-kselftest fixes branch.
> 
> I ran a few tests and couldn't really see the problem this patch
> fixes with and without the patch.
> 
> Can you send me before and after for mm or timers test runs?

Sure, this will affect the output whenever a ksft_exit_skip() is called
after a ksft plan has been printed.

Let us look at acct_syscall test. When I run the test without root, I
get the following output before applying the patch:

TAP version 13
1..1
ok 2 # SKIP This test needs root to run!
# 1 skipped test(s) detected. Consider enabling relevant config options
to improve coverage.
# Totals: pass:0 fail:0 xfail:0 xpass:0 skip:1 error:0

where we should have observed ok 1 instead of ok 2.

When I run the test without root, after applying the patch, I get the
corrected output:

TAP version 13
1..1
ok 1 # SKIP This test needs root to run!
# 1 skipped test(s) detected. Consider enabling relevant config options
to improve coverage.
# Totals: pass:0 fail:0 xfail:0 xpass:0 skip:1 error:0

Since a lot of selftests are being formatted to give KTAP output right
now, this patch is expected to fix a larger number of tests once that
gets merged.

> 
>>
>> Fixes: b85d387c9b09 ("kselftest: fix TAP output for skipped tests")
>> Signed-off-by: Sarthak Sharma <[email protected]>
>> ---
>>   tools/testing/selftests/kselftest.h | 2 +-
>>   1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/tools/testing/selftests/kselftest.h b/tools/testing/
>> selftests/kselftest.h
>> index afbcf8412ae5..827b47cf4df8 100644
>> --- a/tools/testing/selftests/kselftest.h
>> +++ b/tools/testing/selftests/kselftest.h
>> @@ -449,7 +449,7 @@ static inline __noreturn __printf(1, 2) void
>> ksft_exit_skip(const char *msg, ...
>>        */
>>       if (ksft_plan || ksft_test_num()) {
>>           ksft_cnt.ksft_xskip++;
>> -        printf("ok %u # SKIP ", 1 + ksft_test_num());
>> +        printf("ok %u # SKIP ", ksft_test_num());
>>       } else {
>>           printf("1..0 # SKIP ");
>>       }
> 
> thanks,
> -- Shuah


Reply via email to