bug-gnulib
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

mbsnlen: Fix bug in mcel-based implementation


From: Bruno Haible
Subject: mbsnlen: Fix bug in mcel-based implementation
Date: Wed, 19 Jun 2024 02:41:42 +0200

The new u*-vasnprintf tests that I added today succeed on all
platforms. But on Solaris 11.4, in a testdir that contains also
the 'mcel-prefer' module, they fail:


FAIL: unistdio/test-ulc-vasnprintf3.sh
======================================

../../gltests/unistdio/test-ulc-vasnprintf3.c:226: assertion 'strcmp (result, " 
      h\303\251t\303\251rog\303\251n\303\251it\303\251 33") == 0' failed
Stack trace:
0x40c59d print_stack_trace
        ../../gllib/abort-debug.c:40
0x40c59d rpl_abort
        ../../gllib/abort-debug.c:94
0x40c0f8 test_function
        ../../gltests/unistdio/test-ulc-vasnprintf3.c:226
0x40c487 test_vasnprintf
        ../../gltests/unistdio/test-ulc-vasnprintf3.c:266
0x40c4be main
        ../../gltests/unistdio/test-ulc-vasnprintf3.c:276
../../gltests/unistdio/test-ulc-vasnprintf3.sh: line 20: 6427: Abort(coredump)
../../build-aux/test-driver: line 113: 6425: Abort(coredump)
FAIL unistdio/test-ulc-vasnprintf3.sh (exit status: 262)


The cause, it turns out, is that
  mbsnlen ("h\251", 1)
returns 2. Which is obvious nonsense: mbsnlen (s, count) should always return
a value ≤ count.

So, I wrote unit tests for mbsnlen, and the mcel-based implementation fails
these tests in many places:

../../gltests/test-mbsnlen.c:35: assertion 'mbsnlen ("", 1) == 1' failed
../../gltests/test-mbsnlen.c:36: assertion 'mbsnlen ("\0", 2) == 2' failed
../../gltests/test-mbsnlen.c:38: assertion 'mbsnlen ("H", 0) == 0' failed
../../gltests/test-mbsnlen.c:40: assertion 'mbsnlen ("H", 2) == 2' failed
../../gltests/test-mbsnlen.c:42: assertion 'mbsnlen ("Hello", 0) == 0' failed
../../gltests/test-mbsnlen.c:43: assertion 'mbsnlen ("Hello", 1) == 1' failed
../../gltests/test-mbsnlen.c:44: assertion 'mbsnlen ("Hello", 2) == 2' failed
../../gltests/test-mbsnlen.c:46: assertion 'mbsnlen ("Hello", 6) == 6' failed
../../gltests/test-mbsnlen.c:50: assertion 'mbsnlen ("\303\244\303\266", 0) == 
0' failed
../../gltests/test-mbsnlen.c:51: assertion 'mbsnlen ("\303\244\303\266", 1) == 
1' failed
../../gltests/test-mbsnlen.c:52: assertion 'mbsnlen ("\303\244\303\266", 2) == 
1' failed
../../gltests/test-mbsnlen.c:53: assertion 'mbsnlen ("\303\244\303\266", 3) == 
2' failed
../../gltests/test-mbsnlen.c:55: assertion 'mbsnlen ("\303\244\303\266", 5) == 
3' failed
../../gltests/test-mbsnlen.c:57: assertion 'mbsnlen ("7\342\202\254", 0) == 0' 
failed
../../gltests/test-mbsnlen.c:58: assertion 'mbsnlen ("7\342\202\254", 1) == 1' 
failed
../../gltests/test-mbsnlen.c:59: assertion 'mbsnlen ("7\342\202\254", 2) == 2' 
failed
../../gltests/test-mbsnlen.c:60: assertion 'mbsnlen ("7\342\202\254", 3) == 2' 
failed
../../gltests/test-mbsnlen.c:62: assertion 'mbsnlen ("7\342\202\254", 5) == 3' 
failed
../../gltests/test-mbsnlen.c:64: assertion 'mbsnlen ("\360\237\220\203", 0) == 
0' failed
../../gltests/test-mbsnlen.c:65: assertion 'mbsnlen ("\360\237\220\203", 1) == 
1' failed
../../gltests/test-mbsnlen.c:66: assertion 'mbsnlen ("\360\237\220\203", 2) == 
1' failed
../../gltests/test-mbsnlen.c:67: assertion 'mbsnlen ("\360\237\220\203", 3) == 
1' failed
../../gltests/test-mbsnlen.c:69: assertion 'mbsnlen ("\360\237\220\203", 5) == 
2' failed
../../gltests/test-mbsnlen.c:73: assertion 'mbsnlen ("\342\202", 2) == 1' failed
../../gltests/test-mbsnlen.c:74: assertion 'mbsnlen ("\360\237\220", 3) == 1' 
failed

The two attached patches make the tests pass. At this point, I don't have
time to deal with the MEE vs. SEE behaviour differences; that has to wait
for later.


2024-06-18  Bruno Haible  <bruno@clisp.org>

        mbsnlen: Add tests.
        * tests/test-mbsnlen.c: New file.
        * tests/test-mbsnlen.sh: New file, based on tests/test-mbsspn.sh.
        * modules/mbsnlen-tests: New file.

        mbsnlen: Fix bug (regression 2023-09-26).
        * lib/mbsnlen.c (mbsnlen): Fix bug in GNULIB_MCEL_PREFER implementation.

Attachment: 0001-mbsnlen-Fix-bug-regression-2023-09-26.patch
Description: Text Data

Attachment: 0002-mbsnlen-Add-tests.patch
Description: Text Data


reply via email to

[Prev in Thread] Current Thread [Next in Thread]