2013-09-20 Chung-Lin Tang <cltang@codesourcery.com>
[deliverable/binutils-gdb.git] / gdb / testsuite / gdb.base / a2-run.exp
index 89f2c7d9f6e1c4b5bf34f631e2746f684d15ca7f..c8467dc31b56c4fd43c8790ecc365bbdec40e340 100644 (file)
@@ -1,59 +1,35 @@
-#   Copyright (C) 1988, 1990, 1991, 1992, 1994 Free Software Foundation, Inc.
+#   Copyright 1988-2013 Free Software Foundation, Inc.
 
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
+# the Free Software Foundation; either version 3 of the License, or
 # (at your option) any later version.
-# 
+#
 # This program is distributed in the hope that it will be useful,
 # but WITHOUT ANY WARRANTY; without even the implied warranty of
 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 # GNU General Public License for more details.
-# 
+#
 # You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
-
-# Please email any bugs, comments, and/or additions to this file to:
-# bug-gdb@prep.ai.mit.edu
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
 # This file was written by Rob Savoye. (rob@cygnus.com)
 
-# These tests don't work for targets can't take arguments...
-
-if [target_info exists gdb,noargs] then {
-    verbose "Skipping a2-run.exp because of noargs."
-    return
-}
-
-if [target_info exists gdb,noinferiorio] {
-    verbose "Skipping a2-run.exp because of noinferiorio."
+# Can't do this test without stdio support.
+if [gdb_skip_stdio_test "a2run.exp"] {
     return
 }
 
-if $tracelevel then {
-    strace $tracelevel
-}
-
 #
 # test running programs
 #
-set prms_id 0
-set bug_id 0
-
-set testfile "run"
-set srcfile ${testfile}.c
-set binfile ${objdir}/${subdir}/${testfile}
-if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
-    perror "Couldn't compile ${srcfile}"
+
+standard_testfile run.c
+
+if { [prepare_for_testing ${testfile}.exp $testfile $srcfile] } {
     return -1
 }
 
-gdb_exit
-gdb_start
-gdb_reinitialize_dir $srcdir/$subdir
-gdb_load ${binfile}
-
 # Run with no arguments.
 # On VxWorks this justs make sure the program was run.
 gdb_run_cmd
@@ -61,11 +37,11 @@ gdb_run_cmd
 if [istarget "*-*-vxworks*"] then {
     set timeout 120
     verbose "Timeout is now $timeout seconds" 2
-    expect {
-       -i $gdb_spawn_id "Program exited normally" {
+    gdb_expect {
+        "$inferior_exited_re normally" {
            unresolved "run \"$testfile\" with no args"
        }
-       -i $gdb_spawn_id -re "usage:  factorial <number>" {
+        -re "usage:  factorial <number>" {
            pass "run \"$testfile\" with no args"
        }
        timeout {
@@ -74,13 +50,26 @@ if [istarget "*-*-vxworks*"] then {
     }
     set timeout 10
     verbose "Timeout is now $timeout seconds" 2
-    expect -re "$prompt $" {}
+    gdb_expect -re "$gdb_prompt $" {}
 } else {
-    expect {
-       -re ".*usage:  factorial <number>.*Program exited with code 01.*$prompt $" {
+    gdb_expect {
+       -re ".*usage:  factorial <number>.*$inferior_exited_re with code 01.\r\n$gdb_prompt $" {
+           pass "run \"$testfile\" with no args"
+           pass "no spurious messages at program exit"
+       }
+       -re ".*usage:  factorial <number>.*$inferior_exited_re with code 01.*$gdb_prompt $" {
            pass "run \"$testfile\" with no args"
+           fail "no spurious messages at program exit"
        }
-       -re ".*$prompt $" {
+       -re ".*usage:  factorial <number>.* EXIT code 1.*$inferior_exited_re normally.\r\n$gdb_prompt $" {
+           pass "run \"$testfile\" with no args (exit wrapper)"
+           pass "no spurious messages at program exit"
+       }
+       -re ".*usage:  factorial <number>.* EXIT code 1.*$inferior_exited_re normally.*$gdb_prompt $" {
+           pass "run \"$testfile\" with no args (exit wrapper)"
+           fail "no spurious messages at program exit"
+       }
+       -re ".*$gdb_prompt $" {
            fail "run \"$testfile\" with no args"
            verbose "expect_out is $expect_out(buffer)" 2
        }
@@ -89,17 +78,25 @@ if [istarget "*-*-vxworks*"] then {
        }
     }
 }
+
+# The remaining tests don't work for targets can't take arguments...
+
+if [target_info exists noargs] then {
+    verbose "Skipping rest of a2-run.exp because of noargs."
+    return
+}
+
 # Now run with some arguments
 if [istarget "*-*-vxworks*"] then {
     send_gdb "run vxmain \"5\"\n"
-    expect -re "run vxmain \"5\"\r\n" {}
+    gdb_expect -re "run vxmain \"5\"\r\n" {}
     set timeout 120
     verbose "Timeout is now $timeout seconds" 2
-    expect {
-       -i $shell_id "Program exited normally" {
+    gdb_expect {
+        "$inferior_exited_re normally" {
            unresolved "run \"$testfile\" with arg"
        }
-       -i $shell_id "120" {
+        "120" {
            pass "run \"$testfile\" with arg"
        }
        timeout {
@@ -108,62 +105,61 @@ if [istarget "*-*-vxworks*"] then {
     }
     set timeout 10
     verbose "Timeout is now $timeout seconds" 2
-    expect -re "$prompt $" {}
+    gdb_expect -re "$gdb_prompt $" {}
 } else {
-       setup_xfail "mips-idt-*"
+       setup_xfail "arm-*-coff"
        gdb_run_cmd 5
-       expect {
-           -re ".*120.*$prompt $"\
+       gdb_expect {
+           -re ".*120.*$gdb_prompt $"\
                                { pass "run \"$testfile\" with arg" }
-           -re ".*$prompt $"   { fail "run \"$testfile\" with arg" }
+           -re ".*$gdb_prompt $"       { fail "run \"$testfile\" with arg" }
            timeout             { fail "(timeout) run \"$testfile\" with arg" }
        }
 }
 
 # Run again with same arguments.
-setup_xfail "mips-idt-*"
 gdb_run_cmd
 
 if [istarget "*-*-vxworks*"] then {
     set timeout 120
     verbose "Timeout is now $timeout seconds" 2
-    expect {
-       -i $shell_id "Program exited normally" {
+    gdb_expect {
+        "$inferior_exited_re normally" {
            unresolved "run \"$testfile\" again with same args"
        }
-       -i $shell_id "120" { pass "run \"$testfile\" again with same args" }
+        "120" { pass "run \"$testfile\" again with same args" }
        timeout { fail "(timeout) run \"$testfile\" again with same args" }
     }
     set timeout 10
     verbose "Timeout is now $timeout seconds" 2
-    expect -re "$prompt $" {}
+    gdb_expect -re "$gdb_prompt $" {}
 } else {
-    expect {
-           -re ".*120.*$prompt $"\
+    setup_xfail "arm-*-coff"
+    gdb_expect {
+           -re ".*120.*$gdb_prompt $"\
                                { pass "run \"$testfile\" again with same args" }
-           -re ".*$prompt $"   { fail "run \"$testfile\" again with same args" }
+           -re ".*$gdb_prompt $"       { fail "run \"$testfile\" again with same args" }
            timeout             { fail "(timeout) run \"$testfile\" again with same args" }
        }
 }
 
 # Use "set args" command to specify no arguments as default and run again.
 if [istarget "*-*-vxworks*"] then {
-    send_gdb "set args main\n"
+    gdb_test_no_output "set args main"
 } else {
-    send_gdb "set args\n"
+    gdb_test_no_output "set args"
 }
-expect -re "$prompt $"
 
 gdb_run_cmd
 
 if [istarget "*-*-vxworks*"] then {
     set timeout 120
     verbose "Timeout is now $timeout seconds" 2
-    expect {
-       -i $shell_id "Program exited normally" {
+    gdb_expect {
+        "$inferior_exited_re normally" {
            unresolved "run after setting args to nil"
        }
-       -i $shell_id "usage:  factorial <number>" {
+        "usage:  factorial <number>" {
            pass "run after setting args to nil"
        }
        timeout {
@@ -172,13 +168,13 @@ if [istarget "*-*-vxworks*"] then {
     }
     set timeout 10
     verbose "Timeout is now $timeout seconds" 2
-    expect -re "$prompt $" {}
+    gdb_expect -re "$gdb_prompt $" {}
 } else {
-    expect {
-       -re ".*usage:  factorial <number>.*$prompt $" {
+    gdb_expect {
+       -re ".*usage:  factorial <number>.*$gdb_prompt $" {
            pass "run after setting args to nil"
        }
-       -re ".*$prompt $" {
+       -re ".*$gdb_prompt $" {
            fail "run after setting args to nil"
        }
        timeout {
@@ -188,23 +184,22 @@ if [istarget "*-*-vxworks*"] then {
 }
 
 # Use "set args" command to specify an argument and run again.
-setup_xfail "mips-idt-*"
 if [istarget "*-*-vxworks*"] then {
-   send_gdb "set args vxmain \"6\"\n"
+    gdb_test_no_output "set args vxmain \"6\""
 } else {
-       send_gdb "set args 6\n"
+    gdb_test_no_output "set args 6"
 }
-expect -re "$prompt $"
+
 gdb_run_cmd
 
 if [istarget "*-*-vxworks*"] then {
     set timeout 120
     verbose "Timeout is now $timeout seconds" 2
-    expect {
-       -i $shell_id "Program exited normally" {
+    gdb_expect {
+        "$inferior_exited_re normally" {
            unresolved "run \"$testfile\" again after setting args"
        }
-       -i $shell_id "720" {
+        "720" {
            pass "run \"$testfile\" again after setting args"
        }
        timeout {
@@ -213,13 +208,14 @@ if [istarget "*-*-vxworks*"] then {
     }
     set timeout 10
     verbose "Timeout is now $timeout seconds" 2
-    expect -re "$prompt $" {}
+    gdb_expect -re "$gdb_prompt $" {}
 } else {
-    expect {
-           -re ".*720.*$prompt $" {
+    setup_xfail "arm-*-coff"
+    gdb_expect {
+           -re ".*720.*$gdb_prompt $" {
                pass "run \"$testfile\" again after setting args"
            }
-           -re ".*$prompt $" {
+           -re ".*$gdb_prompt $" {
                fail "run \"$testfile\" again after setting args"
            }
            timeout {
@@ -230,23 +226,13 @@ if [istarget "*-*-vxworks*"] then {
 
 # GOAL: Test that shell is being used with "run".  For remote debugging
 # targets, there is no guarantee that a "shell" (whatever that is) is used.
-if [isnative] then {
-    send_gdb "run `echo 8`\n"
-    expect {
-       -re "Starting program.*40320.*$prompt $" {
-           pass "run \"$testfile\" with shell"
-       }
-       -re ".*$prompt $" {
-           fail "run \"$testfile\" with shell"
-       }
-       timeout {
-           fail "(timeout) run \"$testfile\" with shell"
-       }
-    }
+if ![is_remote target] then {
+    gdb_test "run `echo 8`" \
+       "Starting program.*40320.*" \
+       "run \"$testfile\" with shell"
 }
 
 # Reset the default arguments for VxWorks
 if [istarget "*-*-vxworks*"] then {
-    send_gdb "set args main\n"
-    expect -re ".*$prompt $" {}
+    gdb_test_no_output "set args main"
 }
This page took 0.029127 seconds and 4 git commands to generate.