2009-07-31 12:20:51 +02:00
|
|
|
proc setup {} {
|
|
|
|
save_env
|
|
|
|
}; # setup()
|
|
|
|
|
|
|
|
|
|
|
|
proc teardown {} {
|
|
|
|
assert_env_unmodified {/OLDPWD=/d}
|
|
|
|
}; # teardown()
|
|
|
|
|
|
|
|
|
|
|
|
setup
|
|
|
|
|
|
|
|
|
|
|
|
assert_complete_any "screen -"
|
|
|
|
|
|
|
|
|
|
|
|
sync_after_int
|
|
|
|
|
|
|
|
|
|
|
|
set test "-c should complete files/dirs"
|
2010-02-05 15:16:19 +01:00
|
|
|
set dir fixtures/shared/default
|
2009-07-31 12:20:51 +02:00
|
|
|
set prompt "/$dir/@"
|
|
|
|
assert_bash_exec "cd $dir" "" $prompt
|
|
|
|
set cmd "screen -c "
|
|
|
|
set expected {bar {bar bar.d} foo {foo.d}}
|
|
|
|
send "$cmd\t"
|
|
|
|
expect -ex "$cmd"
|
|
|
|
expect {
|
2009-12-04 22:12:54 +01:00
|
|
|
-re "\r\nbar\\s+bar bar.d/\\s+foo\\s+foo.d/" { pass "$test" }
|
|
|
|
# Directories might not be suffixed with a slash (/). This is because
|
|
|
|
# _filedir only works if `-o filenames' is in effect, which isn't the
|
|
|
|
# case for `screen' on bash-3, so an expected failure (xfail)
|
|
|
|
-re "\r\nbar\\s+bar bar.d\\s+foo\\s+foo.d" {
|
2009-12-05 14:53:47 +01:00
|
|
|
if {[lindex $BASH_VERSINFO 0] < 4} {xfail "$test"} {fail "$test"}
|
2009-12-04 22:12:54 +01:00
|
|
|
}
|
2009-12-24 10:00:29 +01:00
|
|
|
-re "\r\nbar\\s+bar\\\\ bar.d/\\s+foo\\s+foo.d/" {
|
|
|
|
# On bash-3, the space in `bar bar.d' is escaped with a backslash
|
|
|
|
# as a side-effect of emulating `-o filenames'.
|
|
|
|
if {[lindex $BASH_VERSINFO 0] <= 3} {pass "$test"} {fail "$test"}
|
|
|
|
}
|
2009-07-31 12:20:51 +02:00
|
|
|
-re $prompt { unresolved "$test at prompt" }
|
|
|
|
default { unresolved "$test" }
|
|
|
|
}; # expect
|
|
|
|
sync_after_int $prompt
|
|
|
|
assert_bash_exec "cd \$TESTDIR"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
sync_after_int
|
|
|
|
|
|
|
|
|
|
|
|
teardown
|