1
0
mirror of https://git.libssh.org/projects/libssh.git synced 2025-12-08 03:42:12 +03:00

tests:client: Add test which checks if we got an exit signal

Fixes #235

Signed-off-by: Andreas Schneider <asn@cryptomilk.org>
Reviewed-by: Jakub Jelen <jjelen@redhat.com>
This commit is contained in:
Andreas Schneider
2024-02-02 15:57:37 +01:00
parent 04d86aeeae
commit a5f082db83

View File

@@ -424,6 +424,42 @@ static void torture_channel_exit_status(void **state)
assert_int_equal(exit_status, 0);
}
static void torture_channel_exit_signal(void **state)
{
struct torture_state *s = *state;
ssh_session session = s->ssh.session;
ssh_channel channel = NULL;
char request[256];
uint32_t exit_status = (uint32_t)-1;
char *exit_signal = NULL;
int core_dumped = false;
int rc;
rc = snprintf(request, sizeof(request), "cat");
assert_return_code(rc, errno);
channel = ssh_channel_new(session);
assert_non_null(channel);
rc = ssh_channel_open_session(channel);
assert_ssh_return_code(session, rc);
/* Make the request, read parts with close */
rc = ssh_channel_request_exec(channel, request);
assert_ssh_return_code(session, rc);
rc = ssh_channel_request_send_signal(channel, "TERM");
assert_ssh_return_code(session, rc);
exit_status = ssh_channel_get_exit_state(channel,
&exit_status,
&exit_signal,
&core_dumped);
assert_ssh_return_code(session, rc);
assert_int_equal(exit_status, 0);
assert_string_equal(exit_signal, "TERM");
SAFE_FREE(exit_signal);
}
/* Ensure that calling 'ssh_channel_get_exit_status' on a freed channel does not
* lead to segmentation faults. */
@@ -571,6 +607,9 @@ int torture_run_tests(void) {
cmocka_unit_test_setup_teardown(torture_channel_exit_status,
session_setup,
session_teardown),
cmocka_unit_test_setup_teardown(torture_channel_exit_signal,
session_setup,
session_teardown),
cmocka_unit_test_setup_teardown(torture_freed_channel_get_exit_status,
session_setup,
session_teardown),