|
Packit |
62fe53 |
# Copyright (C) 1992-2016 Free Software Foundation, Inc.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# This file is part of DejaGnu.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# DejaGnu is free software; you can redistribute it and/or modify it
|
|
Packit |
62fe53 |
# under the terms of the GNU General Public License as published by
|
|
Packit |
62fe53 |
# the Free Software Foundation; either version 3 of the License, or
|
|
Packit |
62fe53 |
# (at your option) any later version.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# DejaGnu is distributed in the hope that it will be useful, but
|
|
Packit |
62fe53 |
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
62fe53 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit |
62fe53 |
# General Public License for more details.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# You should have received a copy of the GNU General Public License
|
|
Packit |
62fe53 |
# along with DejaGnu; if not, write to the Free Software Foundation,
|
|
Packit |
62fe53 |
# Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Connect to HOSTNAME using Telnet. ARGS is a list of options.
|
|
Packit |
62fe53 |
# Currently the only supported option is "raw". Sets the fileid field
|
|
Packit |
62fe53 |
# in the config array and returns -1 for error or the spawn id.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
proc telnet_open { hostname args } {
|
|
Packit |
62fe53 |
global verbose
|
|
Packit |
62fe53 |
global connectmode
|
|
Packit |
62fe53 |
global spawn_id
|
|
Packit |
62fe53 |
global timeout
|
|
Packit |
62fe53 |
global board_info
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
set raw 0
|
|
Packit |
62fe53 |
foreach arg $args {
|
|
Packit |
62fe53 |
switch -- $arg {
|
|
Packit |
62fe53 |
"raw" { set raw 1 }
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
set port 23
|
|
Packit |
62fe53 |
if {[board_info $hostname exists name]} {
|
|
Packit |
62fe53 |
set connhost [board_info $hostname name]
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
set connhost $hostname
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
if {[board_info $connhost exists hostname]} {
|
|
Packit |
62fe53 |
set hostname [board_info $connhost hostname]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
if {[file exists /usr/kerberos/bin/telnet]} {
|
|
Packit |
62fe53 |
set telnet /usr/kerberos/bin/telnet
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
set telnet telnet
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Instead of unsetting it, let's return it. One connection at a
|
|
Packit |
62fe53 |
# time, please.
|
|
Packit |
62fe53 |
if {[board_info $connhost exists fileid]} {
|
|
Packit |
62fe53 |
return [board_info $connhost fileid]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Get the hostname and port number from the config array.
|
|
Packit |
62fe53 |
if {[board_info $connhost exists netport]} {
|
|
Packit |
62fe53 |
set type $hostname
|
|
Packit |
62fe53 |
set hosttmp [split [board_info $connhost netport] ":"]
|
|
Packit |
62fe53 |
set hostname [lindex $hosttmp 0]
|
|
Packit |
62fe53 |
if { [llength $hosttmp] > 1 } {
|
|
Packit |
62fe53 |
set port [lindex $hosttmp 1]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
unset hosttmp
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
set type target
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
if {[board_info $connhost exists shell_prompt]} {
|
|
Packit |
62fe53 |
set shell_prompt [board_info $connhost shell_prompt]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
if {![info exists shell_prompt]} {
|
|
Packit |
62fe53 |
# If no prompt, then set it to something generic.
|
|
Packit |
62fe53 |
set shell_prompt ".*> "
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
set tries 0
|
|
Packit |
62fe53 |
set result -1
|
|
Packit |
62fe53 |
set need_respawn 1
|
|
Packit |
62fe53 |
verbose "Starting a telnet connection to $hostname:$port $shell_prompt" 2
|
|
Packit |
62fe53 |
while { $result < 0 && $tries <= 3 } {
|
|
Packit |
62fe53 |
if { $need_respawn } {
|
|
Packit |
62fe53 |
set need_respawn 0
|
|
Packit |
62fe53 |
spawn $telnet $hostname $port
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
expect {
|
|
Packit |
62fe53 |
"Trying " {
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "$shell_prompt.*$" {
|
|
Packit |
62fe53 |
verbose "Got prompt\n"
|
|
Packit |
62fe53 |
set result 0
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "nt Name:|ogin:" {
|
|
Packit |
62fe53 |
if {[board_info $connhost exists telnet_username]} {
|
|
Packit |
62fe53 |
exp_send "[board_info $connhost telnet_username]\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
if {[board_info $connhost exists username]} {
|
|
Packit |
62fe53 |
exp_send "[board_info $connhost username]\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
perror "telnet: need to login"
|
|
Packit |
62fe53 |
break
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
"assword:" {
|
|
Packit |
62fe53 |
if {[board_info $connhost exists telnet_password]} {
|
|
Packit |
62fe53 |
exp_send "[board_info $connhost telnet_password]\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
if {[board_info $connhost exists password]} {
|
|
Packit |
62fe53 |
exp_send "[board_info $connhost password]\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
perror "telnet: need a password"
|
|
Packit |
62fe53 |
break
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "advance.*y/n.*\\?" {
|
|
Packit |
62fe53 |
exp_send "n\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re {([Aa]dvanced|[Ss]imple) or ([Ss]imple|[Aa]dvanced)} {
|
|
Packit |
62fe53 |
exp_send "simple\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
"Connected to" {
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
"unknown host" {
|
|
Packit |
62fe53 |
exp_send "\003"
|
|
Packit |
62fe53 |
perror "telnet: unknown host"
|
|
Packit |
62fe53 |
break
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
"VxWorks Boot" {
|
|
Packit |
62fe53 |
exp_send "@\n"
|
|
Packit |
62fe53 |
sleep 20
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "Escape character is.*\\.\[\r\n\]" {
|
|
Packit |
62fe53 |
if { $raw || [board_info $connhost exists dont_wait_for_prompt] } {
|
|
Packit |
62fe53 |
set result 0
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
if {[board_info $connhost exists send_initial_cr]} {
|
|
Packit |
62fe53 |
exp_send "\n"
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
"has logged on from" {
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
"You have no Kerberos tickets" {
|
|
Packit |
62fe53 |
warning "telnet: no kerberos Tickets, please kinit"
|
|
Packit |
62fe53 |
break
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "Connection refused.*$" {
|
|
Packit |
62fe53 |
catch "exp_send \"\003\"" foo
|
|
Packit |
62fe53 |
sleep 5
|
|
Packit |
62fe53 |
warning "telnet: connection refused."
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "Sorry, this system is engaged.*" {
|
|
Packit |
62fe53 |
exp_send "\003"
|
|
Packit |
62fe53 |
warning "telnet: already connected."
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
"Connection closed by foreign host.*$" {
|
|
Packit |
62fe53 |
warning "telnet: connection closed by foreign host."
|
|
Packit |
62fe53 |
break
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "\[\r\n\]+" {
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
timeout {
|
|
Packit |
62fe53 |
exp_send "\n"
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
eof {
|
|
Packit |
62fe53 |
warning "telnet: got unexpected EOF from telnet."
|
|
Packit |
62fe53 |
catch close
|
|
Packit |
62fe53 |
catch wait
|
|
Packit |
62fe53 |
set need_respawn 1
|
|
Packit |
62fe53 |
sleep 5
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
incr tries
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# We look for this here again cause it means something went wrong,
|
|
Packit |
62fe53 |
# and it doesn't always show up in the expect in buffer till the
|
|
Packit |
62fe53 |
# server times out.
|
|
Packit |
62fe53 |
if {[info exists expect_out(buffer)]} {
|
|
Packit |
62fe53 |
if {[regexp "assword:|ogin:" $expect_out(buffer)]} {
|
|
Packit |
62fe53 |
perror "telnet: need to supply a login and password."
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
if { $result < 0 } {
|
|
Packit |
62fe53 |
catch close
|
|
Packit |
62fe53 |
catch wait
|
|
Packit |
62fe53 |
set spawn_id -1
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
if { $spawn_id >= 0 } {
|
|
Packit |
62fe53 |
verbose "setting board_info($connhost,fileid) to $spawn_id" 3
|
|
Packit |
62fe53 |
set board_info($connhost,fileid) $spawn_id
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
return $spawn_id
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Put the Telnet connection to HOSTNAME into binary mode.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
proc telnet_binary { hostname } {
|
|
Packit |
62fe53 |
if {[board_info $hostname exists fileid]} {
|
|
Packit |
62fe53 |
remote_send $hostname "?"
|
|
Packit |
62fe53 |
remote_expect $hostname 5 {
|
|
Packit |
62fe53 |
-re "telnet> *$" {}
|
|
Packit |
62fe53 |
default {}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
remote_send $hostname "set binary\n"
|
|
Packit |
62fe53 |
remote_expect $hostname 5 {
|
|
Packit |
62fe53 |
-re "Format is .*telnet> *$" {
|
|
Packit |
62fe53 |
remote_send $hostname "toggle binary\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "Negotiating network ascii.*telnet> *$" {
|
|
Packit |
62fe53 |
remote_send $hostname "toggle binary\n"
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "Negotiating binary.*\[\r\n\].*$" { }
|
|
Packit |
62fe53 |
-re "binary.*unknown argument.*telnet> *$" {
|
|
Packit |
62fe53 |
remote_send $hostname "mode character\n"
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "Already operating in binary.*\[\r\n\].*$" { }
|
|
Packit |
62fe53 |
timeout {
|
|
Packit |
62fe53 |
warning "Never got binary response from telnet."
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|