File: bexecve.test

package info (click to toggle)
strace 4.26-0.2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 35,988 kB
  • sloc: ansic: 95,598; sh: 7,155; makefile: 2,489; awk: 335; perl: 267; sed: 6
file content (39 lines) | stat: -rwxr-xr-x 1,097 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#!/bin/sh
#
# Check -bexecve behavior.
#
# Copyright (c) 2015 Dmitry V. Levin <ldv@altlinux.org>
# Copyright (c) 2015-2018 The strace developers.
# All rights reserved.
#
# SPDX-License-Identifier: GPL-2.0-or-later

. "${srcdir=.}/init.sh"

run_strace_redir()
{
	args="$*"
	$STRACE "$@" 2> "$LOG"
}

run_strace_redir -enone ../set_ptracer_any true ||
	dump_log_and_fail_with "$STRACE $args: unexpected exit status"

run_strace_redir -enone ../set_ptracer_any false
[ $? -eq 1 ] ||
	dump_log_and_fail_with "$STRACE $args: unexpected exit status"

run_strace_redir -bexecve -enone ../set_ptracer_any false ||
	dump_log_and_fail_with "$STRACE $args: unexpected exit status"

pattern_detached='[^:]*strace: Process [1-9][0-9]* detached'
pattern_personality='[^:]*strace: \[ Process PID=[1-9][0-9]* runs in .* mode. \]'

LC_ALL=C grep -x "$pattern_detached" "$LOG" > /dev/null ||
	dump_log_and_fail_with "$STRACE $args: output mismatch"

if LC_ALL=C grep -E -v -x "($pattern_detached|$pattern_personality)" "$LOG" > /dev/null; then
	dump_log_and_fail_with "$STRACE $args: unexpected output"
fi

exit 0