1*cf5a6c84SAndroid Build Coastguard Worker#!/bin/bash 2*cf5a6c84SAndroid Build Coastguard Worker 3*cf5a6c84SAndroid Build Coastguard Worker# SUSv4 compliant sort tests. 4*cf5a6c84SAndroid Build Coastguard Worker# Copyright 2005, 2012 by Rob Landley <[email protected]> 5*cf5a6c84SAndroid Build Coastguard Worker 6*cf5a6c84SAndroid Build Coastguard Worker[ -f testing.sh ] && . testing.sh 7*cf5a6c84SAndroid Build Coastguard Worker 8*cf5a6c84SAndroid Build Coastguard Worker# The basic tests. These should work even with the small config. 9*cf5a6c84SAndroid Build Coastguard Worker 10*cf5a6c84SAndroid Build Coastguard Workertesting "unknown argument" 'sort --oops 2>/dev/null ; echo $?' "2\n" "" "" 11*cf5a6c84SAndroid Build Coastguard Workertesting "sort" "sort input" "a\nb\nc\n" "c\na\nb\n" "" 12*cf5a6c84SAndroid Build Coastguard Workertesting "#2" "sort input" "010\n1\n3\n" "3\n1\n010\n" "" 13*cf5a6c84SAndroid Build Coastguard Workertesting "stdin" "sort" "a\nb\nc\n" "" "b\na\nc\n" 14*cf5a6c84SAndroid Build Coastguard Workertesting "numeric" "sort -n input" "1\n3\n010\n" "3\n1\n010\n" "" 15*cf5a6c84SAndroid Build Coastguard Workertesting "reverse" "sort -r input" "wook\nwalrus\npoint\npabst\naargh\n" \ 16*cf5a6c84SAndroid Build Coastguard Worker "point\nwook\npabst\naargh\nwalrus\n" "" 17*cf5a6c84SAndroid Build Coastguard Workertesting "sort -o" "sort input -o output && cat output" "a\nb\nc\n" "c\na\nb\n" "" 18*cf5a6c84SAndroid Build Coastguard Workertesting "sort -o same" "sort input -o input && cat input" "a\nb\nc\n" "c\na\nb\n" "" 19*cf5a6c84SAndroid Build Coastguard Worker 20*cf5a6c84SAndroid Build Coastguard Worker# Longish chunk of data re-used by the next few tests. The expected output 21*cf5a6c84SAndroid Build Coastguard Worker# varies, but the input (this) is the same. 22*cf5a6c84SAndroid Build Coastguard Worker 23*cf5a6c84SAndroid Build Coastguard Workerdata="42 1 3 woot 24*cf5a6c84SAndroid Build Coastguard Worker42 1 010 zoology 25*cf5a6c84SAndroid Build Coastguard Workeregg 1 2 papyrus 26*cf5a6c84SAndroid Build Coastguard Worker7 3 42 soup 27*cf5a6c84SAndroid Build Coastguard Worker999 3 0 algebra 28*cf5a6c84SAndroid Build Coastguard Worker" 29*cf5a6c84SAndroid Build Coastguard Worker 30*cf5a6c84SAndroid Build Coastguard Worker# Sorting with keys 31*cf5a6c84SAndroid Build Coastguard Worker 32*cf5a6c84SAndroid Build Coastguard Workertesting "one key" "sort -k4,4 input" \ 33*cf5a6c84SAndroid Build Coastguard Worker"999 3 0 algebra 34*cf5a6c84SAndroid Build Coastguard Workeregg 1 2 papyrus 35*cf5a6c84SAndroid Build Coastguard Worker7 3 42 soup 36*cf5a6c84SAndroid Build Coastguard Worker42 1 3 woot 37*cf5a6c84SAndroid Build Coastguard Worker42 1 010 zoology 38*cf5a6c84SAndroid Build Coastguard Worker" "$data" "" 39*cf5a6c84SAndroid Build Coastguard Worker 40*cf5a6c84SAndroid Build Coastguard Worker# The numeric sort orders field 2, ignores field 3 (because numeric sort stops 41*cf5a6c84SAndroid Build Coastguard Worker# at the whitespace), then the global fallback sort does an alpha sort on 42*cf5a6c84SAndroid Build Coastguard Worker# the whole string (starting at the beginning of the line). 43*cf5a6c84SAndroid Build Coastguard Worker 44*cf5a6c84SAndroid Build Coastguard Workertesting "key range with numeric option" "sort -k2,3n input" \ 45*cf5a6c84SAndroid Build Coastguard Worker"42 1 010 zoology 46*cf5a6c84SAndroid Build Coastguard Worker42 1 3 woot 47*cf5a6c84SAndroid Build Coastguard Workeregg 1 2 papyrus 48*cf5a6c84SAndroid Build Coastguard Worker7 3 42 soup 49*cf5a6c84SAndroid Build Coastguard Worker999 3 0 algebra 50*cf5a6c84SAndroid Build Coastguard Worker" "$data" "" 51*cf5a6c84SAndroid Build Coastguard Worker 52*cf5a6c84SAndroid Build Coastguard Worker# Numeric sort on field 2 (again, ignore field 3 because it's numeric), 53*cf5a6c84SAndroid Build Coastguard Worker# then do a _reversed_ alpha sort on the whole line as a tiebreaker. 54*cf5a6c84SAndroid Build Coastguard Worker 55*cf5a6c84SAndroid Build Coastguard Workertesting "key range with numeric option and global reverse" \ 56*cf5a6c84SAndroid Build Coastguard Worker"sort -k2,3n -r input" \ 57*cf5a6c84SAndroid Build Coastguard Worker"egg 1 2 papyrus 58*cf5a6c84SAndroid Build Coastguard Worker42 1 3 woot 59*cf5a6c84SAndroid Build Coastguard Worker42 1 010 zoology 60*cf5a6c84SAndroid Build Coastguard Worker999 3 0 algebra 61*cf5a6c84SAndroid Build Coastguard Worker7 3 42 soup 62*cf5a6c84SAndroid Build Coastguard Worker" "$data" "" 63*cf5a6c84SAndroid Build Coastguard Worker 64*cf5a6c84SAndroid Build Coastguard Worker# Reversed numeric sort on field 2 (numeric ignores field 3), then 65*cf5a6c84SAndroid Build Coastguard Worker# break ties with alpha sort on whole line. 66*cf5a6c84SAndroid Build Coastguard Worker 67*cf5a6c84SAndroid Build Coastguard Workertesting "key range with multiple options" "sort -k2,3rn input" \ 68*cf5a6c84SAndroid Build Coastguard Worker"7 3 42 soup 69*cf5a6c84SAndroid Build Coastguard Worker999 3 0 algebra 70*cf5a6c84SAndroid Build Coastguard Worker42 1 010 zoology 71*cf5a6c84SAndroid Build Coastguard Worker42 1 3 woot 72*cf5a6c84SAndroid Build Coastguard Workeregg 1 2 papyrus 73*cf5a6c84SAndroid Build Coastguard Worker" "$data" "" 74*cf5a6c84SAndroid Build Coastguard Worker 75*cf5a6c84SAndroid Build Coastguard Workertesting "key doesn't strip leading blanks, disables fallback global sort" \ 76*cf5a6c84SAndroid Build Coastguard Worker"sort -n -k2 -t ' '" " a \n 1 \n 2 \n" "" " 2 \n 1 \n a \n" 77*cf5a6c84SAndroid Build Coastguard Worker 78*cf5a6c84SAndroid Build Coastguard Worker# Test case contributed by Joey Hess: 79*cf5a6c84SAndroid Build Coastguard Worker 80*cf5a6c84SAndroid Build Coastguard Workertesting "key edge case with -t" "sort -n -k4 -t/" \ 81*cf5a6c84SAndroid Build Coastguard Worker"/usr/lib/finish-install.d/1 82*cf5a6c84SAndroid Build Coastguard Worker/usr/lib/finish-install.d/4 83*cf5a6c84SAndroid Build Coastguard Worker/usr/lib/prebaseconfig.d/2 84*cf5a6c84SAndroid Build Coastguard Worker/usr/lib/prebaseconfig.d/6 85*cf5a6c84SAndroid Build Coastguard Worker" "" "/usr/lib/finish-install.d/1 86*cf5a6c84SAndroid Build Coastguard Worker/usr/lib/prebaseconfig.d/2 87*cf5a6c84SAndroid Build Coastguard Worker/usr/lib/finish-install.d/4 88*cf5a6c84SAndroid Build Coastguard Worker/usr/lib/prebaseconfig.d/6 89*cf5a6c84SAndroid Build Coastguard Worker" 90*cf5a6c84SAndroid Build Coastguard Worker 91*cf5a6c84SAndroid Build Coastguard Workertoyonly testing "-x" "sort -x" "010\na0\n 0c0\n" "" "a0\n010\n 0c0\n" 92*cf5a6c84SAndroid Build Coastguard Worker 93*cf5a6c84SAndroid Build Coastguard Worker# Test that -f applies to key or fallback independently 94*cf5a6c84SAndroid Build Coastguard Worker 95*cf5a6c84SAndroid Build Coastguard Workertesting "" "sort -k2,2f" "A b b\na B C\na B a\n" "" "a B a\nA b b\na B C\n" 96*cf5a6c84SAndroid Build Coastguard Workertesting "" "sort -k2,2" "a B C\na B a\nA b b\n" "" "a B a\nA b b\na B C\n" 97*cf5a6c84SAndroid Build Coastguard Workertesting "" "sort -f -k2,2" "A b b\na B C\na B a\n" "" "a B a\nA b b\na B C\n" 98*cf5a6c84SAndroid Build Coastguard Workertesting "" "sort -t, -k3n" "3,4,1,2\n4,1,2,3\n1,2,3,4\n2,3,4,1\n" "" \ 99*cf5a6c84SAndroid Build Coastguard Worker "1,2,3,4\n2,3,4,1\n4,1,2,3\n3,4,1,2\n" 100*cf5a6c84SAndroid Build Coastguard Workertoyonly testing "-kx" "sort -k1,1x" "3\na\n0c\n" "" "0c\na\n3\n" 101*cf5a6c84SAndroid Build Coastguard Worker 102*cf5a6c84SAndroid Build Coastguard Worker# This has irredeemable version skew on the host and no standard defining it. 103*cf5a6c84SAndroid Build Coastguard Worker# testing "-V" "LANG=c sort -V" \ 104*cf5a6c84SAndroid Build Coastguard Worker# "toy-2.37.tar.gz\ntoy-3.4.tar.gz\ntoy-3.12.tar.gz\ntoy-4.16-rc2.tar.gz\ntoy-4.16.tar.gz\n" "" \ 105*cf5a6c84SAndroid Build Coastguard Worker# "toy-3.12.tar.gz\ntoy-2.37.tar.gz\ntoy-3.4.tar.gz\ntoy-4.16-rc2.tar.gz\ntoy-4.16.tar.gz" 106*cf5a6c84SAndroid Build Coastguard Worker 107*cf5a6c84SAndroid Build Coastguard Workertestcmd "-c" "-c 2>&1 | grep -o [0-9]*" "3\n" "" "a\nb\na\nc" 108*cf5a6c84SAndroid Build Coastguard Workertestcmd "-uc" "-uc 2>&1 | grep -o [0-9]*" "3\n" "" "a\nb\nb\nc" 109*cf5a6c84SAndroid Build Coastguard Workertestcmd "-C 1" "-C || echo yes" "yes\n" "" "one\ntwo\nthree" 110*cf5a6c84SAndroid Build Coastguard Workertestcmd "-C 2" "-C && echo yes" "yes\n" "" "a\nb\nc\n" 111*cf5a6c84SAndroid Build Coastguard Worker 112*cf5a6c84SAndroid Build Coastguard Workertoyonly testcmd 'negative -k' '-k-2,-2 -k-1r' 'a b z\nd e q\nx e a\nb m n\n' \ 113*cf5a6c84SAndroid Build Coastguard Worker '' 'a b z\nd e q\nb m n\nx e a\n' 114*cf5a6c84SAndroid Build Coastguard Workertoyonly testcmd 'negative -k2' '-k-2' 'a b z\nx e a\nd e q\nb m n\n' \ 115*cf5a6c84SAndroid Build Coastguard Worker '' 'a b z\nd e q\nb m n\nx e a\n' 116*cf5a6c84SAndroid Build Coastguard Worker 117*cf5a6c84SAndroid Build Coastguard Workertestcmd 'missing key becomes ""' '-k3r' 'm n o\ng h i\na b c\nd e\nj k\n' \ 118*cf5a6c84SAndroid Build Coastguard Worker '' 'a b c\nd e\ng h i\nj k\nm n o\n' 119*cf5a6c84SAndroid Build Coastguard Workertoyonly testcmd 'negative straddle' '-k-1r' 'm n o\nj k\ng h i\nd e\na b c\n' \ 120*cf5a6c84SAndroid Build Coastguard Worker '' 'a b c\nd e\ng h i\nj k\nm n o\n' 121*cf5a6c84SAndroid Build Coastguard Workertoyonly testcmd 'missing negative' '-k-3r' 'm n o\ng h i\na b c\nd e\nj k\n' \ 122*cf5a6c84SAndroid Build Coastguard Worker '' 'a b c\nd e\ng h i\nj k\nm n o\n' 123*cf5a6c84SAndroid Build Coastguard Worker 124*cf5a6c84SAndroid Build Coastguard Workeroptional TOYBOX_FLOAT 125*cf5a6c84SAndroid Build Coastguard Worker 126*cf5a6c84SAndroid Build Coastguard Worker# not numbers < NaN < -infinity < numbers < +infinity 127*cf5a6c84SAndroid Build Coastguard Workertesting "-g" "sort -g" \ 128*cf5a6c84SAndroid Build Coastguard Worker "bork\nNaN\n-inf\n0.4\n1.222\n01.37\n2.1\n+infinity\n" "" \ 129*cf5a6c84SAndroid Build Coastguard Worker "01.37\n1.222\n2.1\n0.4\nNaN\nbork\n-inf\n+infinity\n" 130*cf5a6c84SAndroid Build Coastguard Worker 131*cf5a6c84SAndroid Build Coastguard Worker# -n without number sorts as leading zero, but fallback is whole string 132*cf5a6c84SAndroid Build Coastguard Workertestcmd '-n without number sorts as leading zero' '-n' \ 133*cf5a6c84SAndroid Build Coastguard Worker '-1\n0A\n0D\nC\n1z\n3b\n' '' '1z\n0D\n3b\nC\n-1\n0A\n' 134*cf5a6c84SAndroid Build Coastguard Worker 135*cf5a6c84SAndroid Build Coastguard Workertestcmd '-u implies -s' '-uk2,2n' 'zero 1\nthree 2\nfour 3\n' '' \ 136*cf5a6c84SAndroid Build Coastguard Worker 'zero 1\none 1\nfour 3\ntwo 1\nthree 2\nalso 1' 137