Blame lib/rsh.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
# Connect to HOSTNAME using rsh(1).
Packit 62fe53
#
Packit 62fe53
proc rsh_open { hostname } {
Packit 62fe53
    global spawn_id
Packit 62fe53
Packit 62fe53
    set tries 0
Packit 62fe53
    set result -1
Packit 62fe53
Packit 62fe53
    if {![board_info $hostname exists rsh_prog]} {
Packit 62fe53
	if { [which remsh] != 0 } {
Packit 62fe53
	    set RSH remsh
Packit 62fe53
	} else {
Packit 62fe53
	    set RSH rsh
Packit 62fe53
	}
Packit 62fe53
    } else {
Packit 62fe53
	set RSH [board_info $hostname rsh_prog]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $hostname exists username]} {
Packit 62fe53
	set rsh_useropts "-l [board_info $hostname username]"
Packit 62fe53
    } else {
Packit 62fe53
	set rsh_useropts ""
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    # Get the hostname and port number from the config array.
Packit 62fe53
    if {[board_info $hostname exists name]} {
Packit 62fe53
	set hostname [board_info $hostname name]
Packit 62fe53
    }
Packit 62fe53
    set hostname [lindex [split [board_info ${hostname} netport] ":"] 0]
Packit 62fe53
    if {[board_info ${hostname} exists shell_prompt]} {
Packit 62fe53
	set shell_prompt [board_info ${hostname} shell_prompt]
Packit 62fe53
    } else {
Packit 62fe53
	set shell_prompt ".*> "
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $hostname exists fileid]} {
Packit 62fe53
	unset board_info($hostname,fileid)
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    spawn $RSH $rsh_useropts $hostname
Packit 62fe53
    if { $spawn_id < 0 } {
Packit 62fe53
	perror "invalid spawn id from $RSH"
Packit 62fe53
	return -1
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    send "\r\n"
Packit 62fe53
    while { $tries <= 3 } {
Packit 62fe53
	expect {
Packit 62fe53
	    -re ".*$shell_prompt.*$" {
Packit 62fe53
		verbose "Got prompt\n"
Packit 62fe53
		set result 0
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "TERM = .*$" {
Packit 62fe53
		warning "Setting terminal type to vt100"
Packit 62fe53
		set result 0
Packit 62fe53
		send "vt100\n"
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    "unknown host" {
Packit 62fe53
		exp_send "\003"
Packit 62fe53
		perror "telnet: unknown host"
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    "has logged on from" {
Packit 62fe53
		exp_continue
Packit 62fe53
	    }
Packit 62fe53
	    -re "isn't registered for Kerberos.*service.*$" {
Packit 62fe53
		warning "$RSH: isn't registered for Kerberos, please kinit"
Packit 62fe53
		catch close
Packit 62fe53
		catch wait
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "Kerberos rcmd failed.*$" {
Packit 62fe53
		warning "$RSH: Kerberos rcmd failed, please kinit"
Packit 62fe53
		catch close
Packit 62fe53
		catch wait
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "You have no Kerberos tickets.*$" {
Packit 62fe53
		warning "$RSH: No kerberos Tickets, please kinit"
Packit 62fe53
		catch close
Packit 62fe53
		catch wait
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    "Terminal type is" {
Packit 62fe53
		verbose "$RSH: connected, got terminal prompt" 2
Packit 62fe53
		set result 0
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "trying normal rlogin.*$" {
Packit 62fe53
		warning "$RSH: trying normal rlogin."
Packit 62fe53
		catch close
Packit 62fe53
		catch wait
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "unencrypted connection.*$" {
Packit 62fe53
		warning "$RSH: unencrypted connection, please kinit"
Packit 62fe53
		catch close
Packit 62fe53
		catch wait
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "Sorry, shell is locked.*Connection closed.*$" {
Packit 62fe53
		warning "$RSH: already connected."
Packit 62fe53
	    }
Packit 62fe53
	    timeout {
Packit 62fe53
		warning "$RSH: timed out trying to connect."
Packit 62fe53
	    }
Packit 62fe53
	    eof {
Packit 62fe53
		perror "$RSH: got EOF while trying to connect."
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	}
Packit 62fe53
	incr tries
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if { $result < 0 } {
Packit 62fe53
	close -i $spawn_id
Packit 62fe53
	set spawn_id -1
Packit 62fe53
    } else {
Packit 62fe53
	set board_info($hostname,fileid) $spawn_id
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    return $spawn_id
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
# Download SRCFILE to DESTFILE on DESTHOST.
Packit 62fe53
#
Packit 62fe53
proc rsh_download {desthost srcfile destfile} {
Packit 62fe53
    # must be done before desthost is rewritten
Packit 62fe53
    if {[board_info $desthost exists rcp_prog]} {
Packit 62fe53
	set RCP [board_info $desthost rcp_prog]
Packit 62fe53
    } else {
Packit 62fe53
	set RCP rcp
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $desthost exists rsh_prog]} {
Packit 62fe53
	set RSH [board_info $desthost rsh_prog]
Packit 62fe53
    } else {
Packit 62fe53
	if { [which remsh] != 0 } {
Packit 62fe53
	    set RSH remsh
Packit 62fe53
	} else {
Packit 62fe53
	    set RSH rsh
Packit 62fe53
	}
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $desthost exists username]} {
Packit 62fe53
	set rsh_useropts "-l [board_info $desthost username]"
Packit 62fe53
	set rcp_user "[board_info $desthost username]@"
Packit 62fe53
    } else {
Packit 62fe53
	set rsh_useropts ""
Packit 62fe53
	set rcp_user ""
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $desthost exists name]} {
Packit 62fe53
	set desthost [board_info $desthost name]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $desthost exists hostname]} {
Packit 62fe53
	set desthost [board_info $desthost hostname]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    set status [catch "exec $RSH $rsh_useropts $desthost rm -f $destfile |& cat" output]
Packit 62fe53
    set status [catch "exec $RCP $srcfile $rcp_user$desthost:$destfile |& cat" output]
Packit 62fe53
    if { $status == 0 } {
Packit 62fe53
	verbose "Copied $srcfile to $desthost:$destfile" 2
Packit 62fe53
	return $destfile
Packit 62fe53
    } else {
Packit 62fe53
	verbose "Download to $desthost failed, $output."
Packit 62fe53
	return ""
Packit 62fe53
    }
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
proc rsh_upload {desthost srcfile destfile} {
Packit 62fe53
    if {[board_info $desthost exists rcp_prog]} {
Packit 62fe53
	set RCP [board_info $desthost rcp_prog]
Packit 62fe53
    } else {
Packit 62fe53
	set RCP rcp
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $desthost exists username]} {
Packit 62fe53
	set rcp_user "[board_info $desthost username]@"
Packit 62fe53
    } else {
Packit 62fe53
	set rcp_user ""
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $desthost exists name]} {
Packit 62fe53
	set desthost [board_info $desthost name]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $desthost exists hostname]} {
Packit 62fe53
	set desthost [board_info $desthost hostname]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    set status [catch "exec $RCP $rcp_user$desthost:$srcfile $destfile" output]
Packit 62fe53
    if { $status == 0 } {
Packit 62fe53
	verbose "Copied $desthost:$srcfile to $destfile" 2
Packit 62fe53
	return $destfile
Packit 62fe53
    } else {
Packit 62fe53
	verbose "Upload from $desthost failed, $output."
Packit 62fe53
	return ""
Packit 62fe53
    }
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
# Execute CMD on BOARDNAME.
Packit 62fe53
#
Packit 62fe53
proc rsh_exec { boardname program pargs inp outp } {
Packit 62fe53
    global timeout
Packit 62fe53
Packit 62fe53
    verbose "Executing on $boardname: $program $pargs < $inp"
Packit 62fe53
Packit 62fe53
    if {![board_info $boardname exists rsh_prog]} {
Packit 62fe53
	if { [which remsh] != 0 } {
Packit 62fe53
	    set RSH remsh
Packit 62fe53
	} else {
Packit 62fe53
	    set RSH rsh
Packit 62fe53
	}
Packit 62fe53
    } else {
Packit 62fe53
	set RSH [board_info $boardname rsh_prog]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $boardname exists username]} {
Packit 62fe53
	set rsh_useropts "-l [board_info $boardname username]"
Packit 62fe53
    } else {
Packit 62fe53
	set rsh_useropts ""
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $boardname exists name]} {
Packit 62fe53
	set boardname [board_info $boardname name]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $boardname exists hostname]} {
Packit 62fe53
	set hostname [board_info $boardname hostname]
Packit 62fe53
    } else {
Packit 62fe53
	set hostname $boardname
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    # If CMD sends any output to stderr, exec will think it failed.
Packit 62fe53
    # More often than not that will be true, but it doesn't catch the
Packit 62fe53
    # case where there is no output but the exit code is non-zero.
Packit 62fe53
    if { $inp == "" } {
Packit 62fe53
	set inp "/dev/null"
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    set ret [local_exec "$RSH $rsh_useropts $hostname sh -c '$program $pargs \\; echo XYZ\\\${?}ZYX'" $inp $outp $timeout]
Packit 62fe53
    set status [lindex $ret 0]
Packit 62fe53
    set output [lindex $ret 1]
Packit 62fe53
Packit 62fe53
    verbose "$RSH status is $status, output is $output"
Packit 62fe53
Packit 62fe53
    # `status' doesn't mean much here other than rsh worked ok.
Packit 62fe53
    # What we want is whether $program ran ok.  Return $status
Packit 62fe53
    # if the program timed out, status will be 1 indicating that
Packit 62fe53
    # rsh ran and failed.  If rsh fails, we will get FAIL rather
Packit 62fe53
    # than UNRESOLVED - this will help the problem be noticed.
Packit 62fe53
    if { $status != 0 } {
Packit 62fe53
	regsub "XYZ(\[0-9\]*)ZYX\n?" $output "" output
Packit 62fe53
	return [list $status "$RSH to $boardname failed for $program, $output"]
Packit 62fe53
    }
Packit 62fe53
    if { [regexp "XYZ(\[0-9\]*)ZYX" $output junk status] == 0 } {
Packit 62fe53
	set status ""
Packit 62fe53
    }
Packit 62fe53
    verbose "rsh_exec: status:$status text:$output" 4
Packit 62fe53
    if { $status == "" } {
Packit 62fe53
	return [list -1 "Couldn't parse $RSH output, $output."]
Packit 62fe53
    }
Packit 62fe53
    regsub "XYZ(\[0-9\]*)ZYX\n?" $output "" output
Packit 62fe53
    # Delete one trailing \n because that is what `exec' will do and we want
Packit 62fe53
    # to behave identical to it.
Packit 62fe53
    regsub "\n$" $output "" output
Packit 62fe53
    return [list [expr {$status != 0}] $output]
Packit 62fe53
}