Blame lib/telnet.exp

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
}