1 /* Test qsort with invalid comparison functions.
2 Copyright (C) 2023-2024 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <http://www.gnu.org/licenses/>. */
19 #include <array_length.h>
21 #include <support/check.h>
23 /* Invalid comparison function that always returns -1. */
25 invalid_compare_1 (const void *a1
, const void *b1
)
29 /* Check that the marker value matches, which means that we are
30 likely within the array. */
31 TEST_COMPARE (*a
, 842523635);
32 TEST_COMPARE (*b
, 842523635);
33 TEST_VERIFY_EXIT (*a
== 842523635);
34 TEST_VERIFY_EXIT (*b
== 842523635);
38 /* Invalid comparison function that always returns 1. */
40 invalid_compare_2 (const void *a1
, const void *b1
)
44 TEST_COMPARE (*a
, 842523635);
45 TEST_COMPARE (*b
, 842523635);
46 TEST_VERIFY_EXIT (*a
== 842523635);
47 TEST_VERIFY_EXIT (*b
== 842523635);
54 int array
[] = {842523635, 842523635, 842523635, 842523635, 842523635};
55 qsort (array
, array_length (array
), sizeof (array
[0]), invalid_compare_1
);
56 qsort (array
, array_length (array
), sizeof (array
[0]), invalid_compare_2
);
60 #include <support/test-driver.c>