xref: /netbsd-src/external/gpl3/gdb.old/dist/gdb/testsuite/gdb.threads/thread-find.exp (revision a24efa7dea9f1f56c3bdb15a927d3516792ace1c)
1# Copyright 2011-2015 Free Software Foundation, Inc.
2
3# This program is free software; you can redistribute it and/or modify
4# it under the terms of the GNU General Public License as published by
5# the Free Software Foundation; either version 3 of the License, or
6# (at your option) any later version.
7#
8# This program is distributed in the hope that it will be useful,
9# but WITHOUT ANY WARRANTY; without even the implied warranty of
10# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11# GNU General Public License for more details.
12#
13# You should have received a copy of the GNU General Public License
14# along with this program.  If not, see <http://www.gnu.org/licenses/>.
15
16# Please email any bugs, comments, and/or additions to this file to:
17# bug-gdb@gnu.org
18
19standard_testfile linux-dp.c
20if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != ""} {
21    return -1
22}
23
24clean_restart ${binfile}
25gdb_test_no_output "set print sevenbit-strings"
26runto_main
27
28# Run until there are some threads.
29gdb_breakpoint [gdb_get_line_number "linuxthreads.exp: info threads 2"]
30gdb_continue_to_breakpoint "main thread's sleep"
31
32# Create thread names.
33gdb_test "thread apply 1 thread name threadname_1" \
34    "Thread 1 .*" \
35    "name thread 1"
36
37gdb_test "thread apply 2 thread name threadname_2" \
38    "Thread 2 .*" \
39    "name thread 2"
40
41gdb_test "thread apply 3 thread name threadname_3" \
42    "Thread 3 .*" \
43    "name thread 3"
44
45gdb_test "thread apply 4 thread name threadname_4" \
46    "Thread 4 .*" \
47    "name thread 4"
48
49gdb_test "thread apply 5 thread name threadname_5" \
50    "Thread 5 .*" \
51    "name thread 5"
52
53gdb_test "thread apply 6 thread name threadname_6" \
54    "Thread 6 .*" \
55    "name thread 6"
56
57# Collect thread ids, if any.
58gdb_test_multiple "info threads" "collect thread id" {
59    -re ". 6 .*\[Tt\]hread (\[0-9a-fA-Fx\]+).* \"threadname_6\" \[^\r\n\]*" {
60	set thread6 $expect_out(1,string)
61	exp_continue
62    }
63    -re ". 5 .*\[Tt\]hread (\[0-9a-fA-Fx\]+).* \"threadname_5\" \[^\r\n\]*" {
64	set thread5 $expect_out(1,string)
65	exp_continue
66    }
67    -re ". 4 .*\[Tt\]hread (\[0-9a-fA-Fx\]+).* \"threadname_4\" \[^\r\n\]*" {
68	set thread4 $expect_out(1,string)
69	exp_continue
70    }
71    -re ". 3 .*\[Tt\]hread (\[0-9a-fA-Fx\]+).* \"threadname_3\" \[^\r\n\]*" {
72	set thread3 $expect_out(1,string)
73	exp_continue
74    }
75    -re ". 2 .*\[Tt\]hread (\[0-9a-fA-Fx\]+).* \"threadname_2\" \[^\r\n\]*" {
76	set thread2 $expect_out(1,string)
77	exp_continue
78    }
79    -re ". 1 .*\[Tt\]hread (\[0-9a-fA-Fx\]+).* \"threadname_1\" \[^\r\n\]*" {
80	set thread1 $expect_out(1,string)
81	exp_continue
82    }
83    -re ".*$gdb_prompt $" {
84	pass "collect thread id"
85    }
86}
87
88if { [info exists thread6] } then {
89    gdb_test "echo $thread6\\n" "$thread6" "got thread ids"
90}
91
92# Collect process ids, if any.
93gdb_test_multiple "info threads" "collect thread id" {
94    -re ". 6 .*\[Pp\]rocess (\[0-9a-fA-Fx\]+).* \"threadname_6\" \[^\r\n\]*" {
95	set process6 $expect_out(1,string)
96	exp_continue
97    }
98    -re ". 5 .*\[Pp\]rocess (\[0-9a-fA-Fx\]+).* \"threadname_5\" \[^\r\n\]*" {
99	set process5 $expect_out(1,string)
100	exp_continue
101    }
102    -re ". 4 .*\[Pp\]rocess (\[0-9a-fA-Fx\]+).* \"threadname_4\" \[^\r\n\]*" {
103	set process4 $expect_out(1,string)
104	exp_continue
105    }
106    -re ". 3 .*\[Pp\]rocess (\[0-9a-fA-Fx\]+).* \"threadname_3\" \[^\r\n\]*" {
107	set process3 $expect_out(1,string)
108	exp_continue
109    }
110    -re ". 2 .*\[Pp\]rocess (\[0-9a-fA-Fx\]+).* \"threadname_2\" \[^\r\n\]*" {
111	set process2 $expect_out(1,string)
112	exp_continue
113    }
114    -re ". 1 .*\[Pp\]rocess (\[0-9a-fA-Fx\]+).* \"threadname_1\" \[^\r\n\]*" {
115	set process1 $expect_out(1,string)
116	exp_continue
117    }
118    -re ".*$gdb_prompt $" {
119	pass "collect process id"
120    }
121}
122
123if { [info exists process6] } then {
124    gdb_test "echo $process6\\n" "$process6" "got process ids"
125}
126
127# Collect lwp ids, if any.
128gdb_test_multiple "info threads" "collect thread id" {
129    -re ". 6 .*LWP (\[0-9a-fA-Fx\]+).* \"threadname_6\" \[^\r\n\]*" {
130	set lwp6 $expect_out(1,string)
131	exp_continue
132    }
133    -re ". 5 .*LWP (\[0-9a-fA-Fx\]+).* \"threadname_5\" \[^\r\n\]*" {
134	set lwp5 $expect_out(1,string)
135	exp_continue
136    }
137    -re ". 4 .*LWP (\[0-9a-fA-Fx\]+).* \"threadname_4\" \[^\r\n\]*" {
138	set lwp4 $expect_out(1,string)
139	exp_continue
140    }
141    -re ". 3 .*LWP (\[0-9a-fA-Fx\]+).* \"threadname_3\" \[^\r\n\]*" {
142	set lwp3 $expect_out(1,string)
143	exp_continue
144    }
145    -re ". 2 .*LWP (\[0-9a-fA-Fx\]+).* \"threadname_2\" \[^\r\n\]*" {
146	set lwp2 $expect_out(1,string)
147	exp_continue
148    }
149    -re ". 1 .*LWP (\[0-9a-fA-Fx\]+).* \"threadname_1\" \[^\r\n\]*" {
150	set lwp1 $expect_out(1,string)
151	exp_continue
152    }
153    -re ".*$gdb_prompt $" {
154	pass "collect lwp id"
155    }
156}
157
158if { [info exists lwp6] } then {
159    gdb_test "echo $lwp6\\n" "$lwp6" "got lwp ids"
160}
161
162#
163# Now: test 'thread find' with names.
164#
165
166gdb_test "thread find threadname_6" \
167    "Thread 6 has name 'threadname_6'" "find thread name 6"
168gdb_test "thread find threadname_5" \
169    "Thread 5 has name 'threadname_5'" "find thread name 5"
170gdb_test "thread find threadname_4" \
171    "Thread 4 has name 'threadname_4'" "find thread name 4"
172gdb_test "thread find threadname_3" \
173    "Thread 3 has name 'threadname_3'" "find thread name 3"
174gdb_test "thread find threadname_2" \
175    "Thread 2 has name 'threadname_2'" "find thread name 2"
176gdb_test "thread find threadname_1" \
177    "Thread 1 has name 'threadname_1'" "find thread name 1"
178
179#
180# Test 'thread find' with thread ids, if any.
181#
182
183if { [info exists thread6] } then {
184    gdb_test "thread find $thread6" \
185	"Thread 6 has .*$thread6.*" "find thread id 6"
186    gdb_test "thread find $thread5" \
187	"Thread 5 has .*$thread5.*" "find thread id 5"
188    gdb_test "thread find $thread4" \
189	"Thread 4 has .*$thread4.*" "find thread id 4"
190    gdb_test "thread find $thread3" \
191	"Thread 3 has .*$thread3.*" "find thread id 3"
192    gdb_test "thread find $thread2" \
193	"Thread 2 has .*$thread2.*" "find thread id 2"
194    gdb_test "thread find $thread1" \
195	"Thread 1 has .*$thread1.*" "find thread id 1"
196}
197
198#
199# Test 'thread find' with process ids, if any.
200#
201
202if { [info exists process6] } then {
203    gdb_test "thread find $process6" \
204	"Thread 6 has .*$process6.*" "find process id 6"
205    gdb_test "thread find $process5" \
206	"Thread 5 has .*$process5.*" "find process id 5"
207    gdb_test "thread find $process4" \
208	"Thread 4 has .*$process4.*" "find process id 4"
209    gdb_test "thread find $process3" \
210	"Thread 3 has .*$process3.*" "find process id 3"
211    gdb_test "thread find $process2" \
212	"Thread 2 has .*$process2.*" "find process id 2"
213    gdb_test "thread find $process1" \
214	"Thread 1 has .*$process1.*" "find process id 1"
215}
216
217#
218# Test 'thread find' with lwp ids, if any.
219#
220
221if { [info exists lwp6] } then {
222    gdb_test "thread find $lwp6" \
223	"Thread 6 has .*$lwp6.*" "find lwp id 6"
224    gdb_test "thread find $lwp5" \
225	"Thread 5 has .*$lwp5.*" "find lwp id 5"
226    gdb_test "thread find $lwp4" \
227	"Thread 4 has .*$lwp4.*" "find lwp id 4"
228    gdb_test "thread find $lwp3" \
229	"Thread 3 has .*$lwp3.*" "find lwp id 3"
230    gdb_test "thread find $lwp2" \
231	"Thread 2 has .*$lwp2.*" "find lwp id 2"
232    gdb_test "thread find $lwp1" \
233	"Thread 1 has .*$lwp1.*" "find lwp id 1"
234}
235
236# Test no match.
237
238gdb_test "thread find foobarbaz" "No threads match .*" "no thread"
239
240#
241# Test regular expression
242#
243
244set see1 0
245set see2 0
246set see3 0
247set see4 0
248set see5 0
249set see6 0
250
251gdb_test_multiple "thread find threadname_\[345\]" "test regular exp" {
252    -re "Thread 6 has name \[^\r\n\]*" {
253	set see6 1
254	exp_continue
255    }
256    -re "Thread 5 has name \[^\r\n\]*" {
257	set see5 1
258	exp_continue
259    }
260    -re "Thread 4 has name \[^\r\n\]*" {
261	set see4 1
262	exp_continue
263    }
264    -re "Thread 3 has name \[^\r\n\]*" {
265	set see3 1
266	exp_continue
267    }
268    -re "Thread 2 has name \[^\r\n\]*" {
269	set see2 1
270	exp_continue
271    }
272    -re "Thread 1 has name \[^\r\n\]*" {
273	set see1 1
274	exp_continue
275    }
276    -re ".*$gdb_prompt $" {
277	if { $see3 && $see4 && $see5 && !$see1 && !$see2 && !$see6 } then {
278	    pass "test regular exp"
279	} else {
280	    fail "test regular exp"
281	}
282    }
283}
284
285#
286# Test info threads on a subset of threads
287#
288
289set see1 0
290set see2 0
291set see3 0
292set see4 0
293set see5 0
294set see6 0
295
296gdb_test_multiple "info threads 2 4 6" "info threads 2 4 6" {
297    -re ". 6 \[^\r\n\]*\"threadname_6\" \[^\r\n\]*" {
298	set see6 1
299	exp_continue
300    }
301    -re ". 5 \[^\r\n\]*\"threadname_5\" \[^\r\n\]*" {
302	set see5 1
303	exp_continue
304    }
305    -re ". 4 \[^\r\n\]*\"threadname_4\" \[^\r\n\]*" {
306	set see4 1
307	exp_continue
308    }
309    -re ". 3 \[^\r\n\]*\"threadname_3\" \[^\r\n\]*" {
310	set see3 1
311	exp_continue
312    }
313    -re ". 2 \[^\r\n\]*\"threadname_2\" \[^\r\n\]*" {
314	set see2 1
315	exp_continue
316    }
317    -re ". 1 \[^\r\n\]*\"threadname_1\" \[^\r\n\]*" {
318	set see1 1
319	exp_continue
320    }
321    -re "$gdb_prompt $" {
322	if { $see2 && $see4 && $see6 && !$see1 && !$see3 && !$see5 } then {
323	    pass "info threads 2 4 6"
324	} else {
325	    fail "info threads 2 4 6"
326	}
327    }
328}
329
330#
331# Test info threads on a range
332#
333
334set see1 0
335set see2 0
336set see3 0
337set see4 0
338set see5 0
339set see6 0
340
341gdb_test_multiple "info threads 3-5" "info threads 3-5" {
342    -re ". 6 .*\"threadname_6\" \[^\r\n\]*" {
343	set see6 1
344	exp_continue
345    }
346    -re ". 5 .*\"threadname_5\" \[^\r\n\]*" {
347	set see5 1
348	exp_continue
349    }
350    -re ". 4 .*\"threadname_4\" \[^\r\n\]*" {
351	set see4 1
352	exp_continue
353    }
354    -re ". 3 .*\"threadname_3\" \[^\r\n\]*" {
355	set see3 1
356	exp_continue
357    }
358    -re ". 2 .*\"threadname_2\" \[^\r\n\]*" {
359	set see2 1
360	exp_continue
361    }
362    -re ". 1 .*\"threadname_1\" \[^\r\n\]*" {
363	set see1 1
364	exp_continue
365    }
366    -re "$gdb_prompt $" {
367	if { $see3 && $see4 && $see5 && !$see1 && !$see2 && !$see6 } then {
368	    pass "info threads 3-5"
369	} else {
370	    fail "info threads 3-5"
371	}
372    }
373}
374
375# Test inverted range
376
377gdb_test "info threads 5-3" "inverted range" "test inverted range"
378
379# Test degenerate range
380
381set see1 0
382set see2 0
383set see3 0
384set see4 0
385set see5 0
386set see6 0
387
388gdb_test_multiple "info threads 3-3" "info threads 3-3" {
389    -re ". 6 .*\"threadname_6\" \[^\r\n\]*" {
390	set see6 1
391	exp_continue
392    }
393    -re ". 5 .*\"threadname_5\" \[^\r\n\]*" {
394	set see5 1
395	exp_continue
396    }
397    -re ". 4 .*\"threadname_4\" \[^\r\n\]*" {
398	set see4 1
399	exp_continue
400    }
401    -re ". 3 .*\"threadname_3\" \[^\r\n\]*" {
402	set see3 1
403	exp_continue
404    }
405    -re ". 2 .*\"threadname_2\" \[^\r\n\]*" {
406	set see2 1
407	exp_continue
408    }
409    -re ". 1 .*\"threadname_1\" \[^\r\n\]*" {
410	set see1 1
411	exp_continue
412    }
413    -re ".*$gdb_prompt $" {
414	if { $see3 && !$see1 && !$see2 && !$see4 && !$see5 && !$see6 } then {
415	    pass "info threads 3-3"
416	} else {
417	    fail "info threads 3-3"
418	}
419    }
420}
421
422# Test bad input
423
424gdb_test "info thread foo" \
425    "Args must be numbers or '.' variables." \
426    "info thread foo"
427
428gdb_test "info thread foo -1" \
429    "Args must be numbers or '.' variables." \
430    "info thread foo -1"
431