Freddy Vulto 11da957e45 (testsuite) `match_items()' matches on bash-prompt
Also made `match_items()' more strict about matching
space/newline/prompt after the last item.

Added options to match_items():
- end-newline
- end-prompt
- end-space
and transferred them to other functions.

Function `assert_complete()' now has a `-nospace' option to explicitly
disallow a space after a completion...

Function `assert_bash_list()' now expects a single item to be followed
by a newline.
2010-11-17 23:36:58 +01:00

52 lines
1.1 KiB
Plaintext

# @param string $part Reference to variable to hold partial unique username
# @param string $full Reference to variable to hold full unique username
proc setup {part full} {
upvar $part _part
upvar $full _full
assert_bash_exec {compgen -u} {} /@ users
find_unique_completion_pair $users _part _full
save_env
}
proc teardown {} {
assert_env_unmodified {
/COMPREPLY=/d
}
}
setup part full
set test "function should run without errors"
assert_bash_exec {_tilde > /dev/null} $test
sync_after_int
set test "function should not pollute environment"
# NOTE: A possible environment pollution is detected by assert_env_modified() in teardown()
assert_bash_exec {foo() { local aa="~"; _tilde "$aa"; }; foo; unset foo} $test
sync_after_int
set test "~full should complete to ~full unmodified"
set cmd [format {_tilde "~%s"; printf "%%s\n" "${COMPREPLY[@]}"} $full]
assert_bash_list "~$full" $cmd $test
sync_after_int
set test "~part should complete to ~full"
set cmd [format {_tilde "~%s"; printf "%%s\n" "${COMPREPLY[@]}"} $part]
assert_bash_list "~$full" $cmd $test
teardown