Skip to content

Commit

Permalink
test: Update generate for pytest+pexpect
Browse files Browse the repository at this point in the history
  • Loading branch information
scop committed Jul 1, 2018
1 parent 641173e commit 8b1d916
Showing 1 changed file with 12 additions and 57 deletions.
69 changes: 12 additions & 57 deletions test/generate
Original file line number Diff line number Diff line change
@@ -1,64 +1,19 @@
#!/bin/bash -eu
# Generate skeleton files for completion of specified command.
# Test skeleton files are generated as well.
# @param $1 string Command, e.g. 'make'
# @param $2 string Completion function, e.g. _command
# @param $3 string Completion arguments, e.g. '-o filenames'


# Generate test code
# @param $1 string Command, e.g. 'make'
generate_test_completion() {
local path="completion/$1.exp"
# Does file already exist?
#if [ ! -f "$path" ]; then
# No, file doesn't exist; generate file
cat <<EXPECT > "$path"
assert_source_completions $1
EXPECT
#fi
} # generate_test_completion()


# Generate test code
# @param $1 string Command, e.g. 'make'
# @param $2 string Completion function, e.g. _command
# @param $3 string Completion arguments, e.g. ' -o filenames'
generate_test_lib_completions() {
local path="lib/completions/$1.exp"
# Does file already exist?
#if [ ! -f "$path" ]; then
# No, file doesn't exist; generate file
cat <<EXPECT > "$path"
proc setup {} {
save_env
}
proc teardown {} {
assert_env_unmodified
}

setup
assert_complete_any "$1 "
sync_after_int
# Generate skeleton files for completion of specified command.

if [[ $# -ne 1 ]]; then
echo "Usage: $0 command" >&2
exit 1
fi

teardown
EXPECT
#fi
} # generate_test_lib_completions()
cat <<EOF >t/test_$1.py
import pytest
# If argument count is wrong, show help
if [ $# -ne 1 ]; then
echo "Usage: $0 command"
echo "Example: $0 make"
exit 1
fi
class Test(object):
generate_test_completion "$1"
generate_test_lib_completions "$1"
@pytest.mark.complete("$1 ")
def test_(self, completion):
assert completion.list
EOF

0 comments on commit 8b1d916

Please sign in to comment.