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