2021-06-09 15:13:24 +03:00
|
|
|
tags {"external:skip"} {
|
|
|
|
|
2015-02-10 14:40:27 +01:00
|
|
|
set system_name [string tolower [exec uname -s]]
|
2021-11-11 14:51:33 +03:00
|
|
|
set backtrace_supported 0
|
2015-02-10 14:40:27 +01:00
|
|
|
|
2021-02-23 12:57:45 +02:00
|
|
|
# We only support darwin or Linux with glibc
|
|
|
|
if {$system_name eq {darwin}} {
|
2021-11-11 14:51:33 +03:00
|
|
|
set backtrace_supported 1
|
2021-02-23 12:57:45 +02:00
|
|
|
} elseif {$system_name eq {linux}} {
|
|
|
|
# Avoid the test on libmusl, which does not support backtrace
|
2022-06-09 11:59:33 +02:00
|
|
|
# and on static binaries (ldd exit code 1) where we can't detect libmusl
|
|
|
|
catch {
|
|
|
|
set ldd [exec ldd src/redis-server]
|
|
|
|
if {![string match {*libc.*musl*} $ldd]} {
|
|
|
|
set backtrace_supported 1
|
|
|
|
}
|
2021-02-23 12:57:45 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-11-11 14:51:33 +03:00
|
|
|
if {$backtrace_supported} {
|
2020-11-04 13:13:55 +02:00
|
|
|
set server_path [tmpdir server.log]
|
2015-02-10 14:40:27 +01:00
|
|
|
start_server [list overrides [list dir $server_path]] {
|
|
|
|
test "Server is able to generate a stack trace on selected systems" {
|
|
|
|
r config set watchdog-period 200
|
|
|
|
r debug sleep 1
|
|
|
|
set pattern "*debugCommand*"
|
2021-12-07 18:02:58 +08:00
|
|
|
set res [wait_for_log_messages 0 \"$pattern\" 0 100 100]
|
|
|
|
if {$::verbose} { puts $res }
|
2015-02-10 14:40:27 +01:00
|
|
|
}
|
|
|
|
}
|
2021-11-11 14:51:33 +03:00
|
|
|
}
|
2020-11-03 14:59:21 +02:00
|
|
|
|
2021-11-11 14:51:33 +03:00
|
|
|
# Valgrind will complain that the process terminated by a signal, skip it.
|
|
|
|
if {!$::valgrind} {
|
|
|
|
if {$backtrace_supported} {
|
|
|
|
set crash_pattern "*STACK TRACE*"
|
|
|
|
} else {
|
|
|
|
set crash_pattern "*crashed by signal*"
|
|
|
|
}
|
|
|
|
|
|
|
|
set server_path [tmpdir server1.log]
|
2022-12-11 18:20:42 +02:00
|
|
|
start_server [list overrides [list dir $server_path crash-memcheck-enabled no]] {
|
2021-11-11 14:51:33 +03:00
|
|
|
test "Crash report generated on SIGABRT" {
|
|
|
|
set pid [s process_id]
|
|
|
|
exec kill -SIGABRT $pid
|
2021-12-07 18:02:58 +08:00
|
|
|
set res [wait_for_log_messages 0 \"$crash_pattern\" 0 50 100]
|
|
|
|
if {$::verbose} { puts $res }
|
2020-11-04 13:13:55 +02:00
|
|
|
}
|
2020-11-03 14:59:21 +02:00
|
|
|
}
|
2020-11-04 13:13:55 +02:00
|
|
|
|
2021-11-11 14:51:33 +03:00
|
|
|
set server_path [tmpdir server2.log]
|
2022-12-11 18:20:42 +02:00
|
|
|
start_server [list overrides [list dir $server_path crash-memcheck-enabled no]] {
|
2021-11-11 14:51:33 +03:00
|
|
|
test "Crash report generated on DEBUG SEGFAULT" {
|
|
|
|
catch {r debug segfault}
|
2021-12-07 18:02:58 +08:00
|
|
|
set res [wait_for_log_messages 0 \"$crash_pattern\" 0 50 100]
|
|
|
|
if {$::verbose} { puts $res }
|
2021-11-11 14:51:33 +03:00
|
|
|
}
|
|
|
|
}
|
2020-11-03 14:59:21 +02:00
|
|
|
}
|
2021-06-09 15:13:24 +03:00
|
|
|
|
|
|
|
}
|