t9902-completion: ignore COMPREPLY element order in some tests

The order or possible completion words in the COMPREPLY array doesn't
actually matter, as long as all the right words are in there, because
Bash will sort them anyway.  Yet, our tests looking at the elements of
COMPREPLY always expect them to be in a specific order.

Now, this hasn't been an issue before, but the next patch is about to
optimize a bit more our git-aware path completion, and as a harmless
side effect the order of elements in COMPREPLY will change.  Worse,
the order will be downright undefined, because after the next patch
path components will come directly from iterating through an
associative array in 'awk', and the order of iteration over the
elements in those arrays is undefined, and indeed different 'awk'
implementations produce different order.  Consequently, we can't get
away with simply adjusting the expected results in the affected tests.

Modify the 'test_completion' helper function to sort both the expected
and the actual results, i.e. the elements in COMPREPLY, before
comparing them, so the tests using this helper function will work
regardless of the order of elements.

Note that this change still leaves a bunch of tests depending on the
order of elements in COMPREPLY, tests that focus on a specific helper
function and therefore don't use the 'test_completion' helper.  I
would rather deal with those later, when (if ever) the need actually
arises, than create unnecessary code churn now.

Signed-off-by: SZEDER Gábor <szeder.dev@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
SZEDER Gábor 2018-04-17 00:41:12 +02:00 committed by Junio C Hamano
parent 105c0efff3
commit 9703797c9d

View File

@ -84,10 +84,11 @@ test_completion ()
then then
printf '%s\n' "$2" >expected printf '%s\n' "$2" >expected
else else
sed -e 's/Z$//' >expected sed -e 's/Z$//' |sort >expected
fi && fi &&
run_completion "$1" && run_completion "$1" &&
test_cmp expected out sort out >out_sorted &&
test_cmp expected out_sorted
} }
# Test __gitcomp. # Test __gitcomp.
@ -1405,6 +1406,7 @@ test_expect_success 'complete files' '
echo "expected" > .gitignore && echo "expected" > .gitignore &&
echo "out" >> .gitignore && echo "out" >> .gitignore &&
echo "out_sorted" >> .gitignore &&
git add .gitignore && git add .gitignore &&
test_completion "git commit " ".gitignore" && test_completion "git commit " ".gitignore" &&