Blame SOURCES/gdb-6.5-readline-long-line-crash-test.patch

0b3064
From FEDORA_PATCHES Mon Sep 17 00:00:00 2001
0b3064
From: Fedora GDB patches <invalid@email.com>
0b3064
Date: Fri, 27 Oct 2017 21:07:50 +0200
0b3064
Subject: gdb-6.5-readline-long-line-crash-test.patch
0b3064
0b3064
;; Fix readline segfault on excessively long hand-typed lines.
0b3064
;;=fedoratest
0b3064
0b3064
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=214196
0b3064
0b3064
diff --git a/gdb/testsuite/gdb.base/readline-overflow.exp b/gdb/testsuite/gdb.base/readline-overflow.exp
0b3064
new file mode 100644
0b3064
--- /dev/null
0b3064
+++ b/gdb/testsuite/gdb.base/readline-overflow.exp
0b3064
@@ -0,0 +1,104 @@
0b3064
+# Copyright 2006 Free Software Foundation, Inc.
0b3064
+
0b3064
+# This program is free software; you can redistribute it and/or modify
0b3064
+# it under the terms of the GNU General Public License as published by
0b3064
+# the Free Software Foundation; either version 2 of the License, or
0b3064
+# (at your option) any later version.
0b3064
+# 
0b3064
+# This program is distributed in the hope that it will be useful,
0b3064
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
0b3064
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
0b3064
+# GNU General Public License for more details.
0b3064
+# 
0b3064
+# You should have received a copy of the GNU General Public License
0b3064
+# along with this program; if not, write to the Free Software
0b3064
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  
0b3064
+
0b3064
+# Please email any bugs, comments, and/or additions to this file to:
0b3064
+# bug-gdb@prep.ai.mit.edu
0b3064
+
0b3064
+# This file was written by Jan Kratochvil <jan.kratochvil@redhat.com>
0b3064
+
0b3064
+# This file is part of the gdb testsuite.
0b3064
+
0b3064
+#
0b3064
+# Tests for readline buffer overflow.
0b3064
+#
0b3064
+
0b3064
+if $tracelevel {
0b3064
+  strace $tracelevel
0b3064
+}
0b3064
+
0b3064
+global env
0b3064
+
0b3064
+save_vars { env(INPUTRC) env(GDBHISTFILE) env(HISTSIZE) TERM timeout } {
0b3064
+    # The arrow key test relies on the standard VT100 bindings, so
0b3064
+    # make sure that an appropriate terminal is selected.  The same
0b3064
+    # bug doesn't show up if we use ^P / ^N instead.
0b3064
+    setenv TERM vt100
0b3064
+
0b3064
+    # Don't let a .inputrc file or an existing setting of INPUTRC mess up
0b3064
+    # the test results.  Even if /dev/null doesn't exist on the particular
0b3064
+    # platform, the readline library will use the default setting just by
0b3064
+    # failing to open the file.  OTOH, opening /dev/null successfully will
0b3064
+    # also result in the default settings being used since nothing will be
0b3064
+    # read from this file.
0b3064
+    set env(INPUTRC) "/dev/null"
0b3064
+
0b3064
+    set timeout 600
0b3064
+
0b3064
+    set env(GDBHISTFILE) "${srcdir}/${subdir}/gdb_history"
0b3064
+    set env(HISTSIZE) "10"
0b3064
+
0b3064
+    gdb_exit
0b3064
+    gdb_start
0b3064
+    gdb_reinitialize_dir $srcdir/$subdir
0b3064
+
0b3064
+
0b3064
+    set width 11
0b3064
+    gdb_test "set width $width" \
0b3064
+	"" \
0b3064
+	"Setting width to $width."
0b3064
+    #gdb_test "set height 1" \
0b3064
+	#         "" \
0b3064
+	#         "Setting height to 1."
0b3064
+    send_gdb "run X"
0b3064
+    set i 0
0b3064
+    # It crashes using `set width 7' on `set total 3560'.
0b3064
+    # Sometimes it corrupts screen on `set width 7'.
0b3064
+    # Bugreport used `set total 130001':
0b3064
+    # 	https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=214196
0b3064
+    # Check also `timeout' above.
0b3064
+    set total 4200
0b3064
+    gdb_expect {
0b3064
+	-re X {
0b3064
+	    incr i
0b3064
+	    if {$i <= $total} {
0b3064
+		send_gdb "X"
0b3064
+		exp_continue
0b3064
+	    }
0b3064
+	}
0b3064
+	-re "\[ \b\r\n\]" {
0b3064
+	    exp_continue
0b3064
+	}
0b3064
+	eof {
0b3064
+	    fail "gdb sending total $total characters"
0b3064
+	    note "Failed after sending $i characters, reason: EOF"
0b3064
+	    gdb_clear_suppressed
0b3064
+	}
0b3064
+	timeout {
0b3064
+	    fail "gdb sending total $total characters"
0b3064
+	    note "Failed after sending $i characters (timeout $timeout), reason: TIMEOUT"
0b3064
+	    gdb_clear_suppressed
0b3064
+	}
0b3064
+	default {
0b3064
+	    fail "gdb sending total $total characters"
0b3064
+	    note "Failed after sending $i characters, reason: 0=\[$expect_out(0,string)\] buffer=\[$expect_out(buffer)\]"
0b3064
+	    gdb_clear_suppressed
0b3064
+	}
0b3064
+    }
0b3064
+    send_gdb "\r"
0b3064
+    gdb_test "" \
0b3064
+	"No executable file specified..*" \
0b3064
+	"All the characters transferred"
0b3064
+}