1 # $NetBSD: t_sort.sh,v 1.2 2025/03/02 20:00:32 riastradh Exp $ 2 # 3 # Copyright (c) 2025 The NetBSD Foundation, Inc. 4 # All rights reserved. 5 # 6 # Redistribution and use in source and binary forms, with or without 7 # modification, are permitted provided that the following conditions 8 # are met: 9 # 1. Redistributions of source code must retain the above copyright 10 # notice, this list of conditions and the following disclaimer. 11 # 2. Redistributions in binary form must reproduce the above copyright 12 # notice, this list of conditions and the following disclaimer in the 13 # documentation and/or other materials provided with the distribution. 14 # 15 # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 16 # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 17 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 18 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 19 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 20 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 21 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 22 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 23 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 24 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 25 # POSSIBILITY OF SUCH DAMAGE. 26 27 check_sort() 28 { 29 local sortfn 30 31 set -eu 32 33 sortfn="$1" 34 35 printf 'foo\nbar\nbaz\nquux' >in1 36 printf '1 bar\n2 baz\n0 foo\n3 quux\n' >out1 37 atf_check -s exit:0 -o file:out1 \ 38 "$(atf_get_srcdir)"/h_sort -n "$sortfn" <in1 39 40 atf_check -s exit:0 -o empty sh -c 'exec shuffle -f - <in1 >in2' 41 printf 'bar\nbaz\nfoo\nquux\n' >out2 42 atf_check -s exit:0 -o file:out2 \ 43 "$(atf_get_srcdir)"/h_sort "$sortfn" <in2 44 } 45 46 check_stablesort() 47 { 48 local sortfn 49 50 set -eu 51 52 sortfn="$1" 53 54 printf 'foo\nfoo\nfoo\nfoo\nfoo' >in1 55 printf '0 foo\n1 foo\n2 foo\n3 foo\n4 foo\n' >out1 56 atf_check -s exit:0 -o file:out1 \ 57 "$(atf_get_srcdir)"/h_sort -n "$sortfn" <in1 58 59 printf 'foo\nfoo\nfoo\nfoo\nfoo\nbar\nbar\nbar\nbar\nbar' >in2 60 printf '5 bar\n6 bar\n7 bar\n8 bar\n9 bar\n' >out2 61 printf '0 foo\n1 foo\n2 foo\n3 foo\n4 foo\n' >>out2 62 atf_check -s exit:0 -o file:out2 \ 63 "$(atf_get_srcdir)"/h_sort -n "$sortfn" <in2 64 65 printf 'foo\nfoo\nbar\nbaz\nquux' >in3 66 printf '2 bar\n3 baz\n0 foo\n1 foo\n4 quux\n' >out3 67 atf_check -s exit:0 -o file:out3 \ 68 "$(atf_get_srcdir)"/h_sort -n "$sortfn" <in3 69 70 printf 'foo\nbar\nbar\nbaz\nquux' >in4 71 printf '1 bar\n2 bar\n3 baz\n0 foo\n4 quux\n' >out4 72 atf_check -s exit:0 -o file:out4 \ 73 "$(atf_get_srcdir)"/h_sort -n "$sortfn" <in4 74 75 printf 'foo\nbar\nbaz\nbaz\nquux' >in5 76 printf '1 bar\n2 baz\n3 baz\n0 foo\n4 quux\n' >out5 77 atf_check -s exit:0 -o file:out5 \ 78 "$(atf_get_srcdir)"/h_sort -n "$sortfn" <in5 79 80 printf 'foo\nbar\nbaz\nquux\nquux' >in6 81 printf '1 bar\n2 baz\n0 foo\n3 quux\n4 quux\n' >out6 82 atf_check -s exit:0 -o file:out6 \ 83 "$(atf_get_srcdir)"/h_sort -n "$sortfn" <in6 84 } 85 86 sortfn_case() 87 { 88 local sortfn 89 90 sortfn="$1" 91 92 eval "${sortfn}_head() { atf_set descr \"Test ${sortfn}\"; }" 93 eval "${sortfn}_body() { check_sort $sortfn; }" 94 atf_add_test_case "$sortfn" 95 } 96 97 stablesortfn_case() 98 { 99 local sortfn 100 101 sortfn="$1" 102 103 eval "${sortfn}_stable_head() { atf_set descr \"Test ${sortfn}\"; }" 104 eval "${sortfn}_stable_body() { check_stablesort $sortfn; }" 105 atf_add_test_case "${sortfn}_stable" 106 } 107 108 atf_init_test_cases() 109 { 110 111 sortfn_case heapsort_r 112 sortfn_case mergesort_r 113 sortfn_case qsort_r 114 stablesortfn_case mergesort_r 115 } 116