Re: Expect timeout problem. I needs help.



I use autoexpect to generate a script file.
And again, I meet the problem.
Sometimes the script runs as expected, sometimes it timeout.


#!/usr/local/bin/expect -f
#
# This Expect script was generated by autoexpect on Tue Nov 29 15:33:42
2005
# Expect and autoexpect were both written by Don Libes, NIST.
#
# Note that autoexpect does not guarantee a working script. It
# necessarily has to guess about certain things. Two reasons a script
# might fail are:
#
# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet,
# etc.) and devices discard or ignore keystrokes that arrive "too
# quickly" after prompts. If you find your new script hanging up at
# one spot, try adding a short sleep just before the previous send.
# Setting "force_conservative" to 1 (see below) makes Expect do this
# automatically - pausing briefly before sending each character. This
# pacifies every program I know of. The -c flag makes the script do
# this in the first place. The -C flag allows you to define a
# character to toggle this mode off and on.

set force_conservative 0 ;# set to 1 to force conservative mode even
if
;# script wasn't run conservatively originally
if {$force_conservative} {
set send_slow {1 .1}
proc send {ignore arg} {
sleep .1
exp_send -s -- $arg
}
}

#
# 2) differing output - Some programs produce different output each
time
# they run. The "date" command is an obvious example. Another is
# ftp, if it produces throughput statistics at the end of a file
# transfer. If this causes a problem, delete these patterns or replace
# them with wildcards. An alternative is to use the -p flag (for
# "prompt") which makes Expect only look for the last line of output
# (i.e., the prompt). The -P flag allows you to define a character to
# toggle this mode off and on.
#
# Read the man page for more info.
#
# -Don


set timeout -1
spawn $env(SHELL)
match_max 100000
expect -exact "\]0;brian@localhost:~\[brian@brian brian\]\$"
send -- "su\r"
expect -exact "su\r
Password: "
send -- "sec1123\r"
expect -exact "\r
\]0;brian@localhost:/home/brian\[root@brian brian\]\$"
send -- "whoami\r"
expect -exact "whoami\r
root\r
\]0;brian@localhost:/home/brian\[root@brian brian\]\$"
send -- "exit\r"
expect -exact "exit\r
exit\r
\]0;brian@localhost:~\[brian@brian brian\]\$"
send -- "exit\r"
expect eof

.



Relevant Pages

  • Re: Problems running autoexpect.tcl
    ... just want to get this script to run to see what it does and if it will ... I also tried using tclsh8.4 and running autoexpect or autoexpect.tcl ... I think from your description you are forgetting to press [Control-D] ... buffering all your interaction up to your system defined buffer ...
    (comp.lang.tcl)
  • Re: Any Expect coders out there?
    ... One of the scripts I downloaded was autoexpect which is ... I've tried using it to generate an ftp script ... The Expect_4.53 was included with the Cygwin ...
    (comp.lang.tcl)
  • Re: [OT] SSH login script - Help
    ... I'd like to do is somehow change the above so that the script prompts ... You might want to use autoexpect for that. ... This can get you in security problems since you'd need to write your ...
    (Fedora)
  • Problems running autoexpect.tcl
    ... I'm a total beginner for Linux and TCL - I just want to get this script to run to see what it does and if it will do what I need it to do, then I intend to figure out how it works. ... If I understood the example description, it is supposed to open a new shell, and when that shell is closed the script gets filled with the data it collects. ... I also tried using tclsh8.4 and running autoexpect or autoexpect.tcl from there, but no success - invalid command name for both autoexpect and autoexpect.tcl. ...
    (comp.lang.tcl)
  • Re: changing existing local user flag "never expires"
    ... set the flag "password never expires". ... A non-zero result means that the flag is ... which means that the script results in the flag not being ... If (lngFlags And ADS_UF_DONT_EXPIRE_PASSWD) = 0 Then ...
    (microsoft.public.scripting.vbscript)