mirror of
https://git.libssh.org/projects/libssh.git
synced 2025-12-09 15:41:10 +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:
@@ -424,6 +424,42 @@ static void torture_channel_exit_status(void **state)
|
|||||||
assert_int_equal(exit_status, 0);
|
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
|
/* Ensure that calling 'ssh_channel_get_exit_status' on a freed channel does not
|
||||||
* lead to segmentation faults. */
|
* lead to segmentation faults. */
|
||||||
@@ -571,6 +607,9 @@ int torture_run_tests(void) {
|
|||||||
cmocka_unit_test_setup_teardown(torture_channel_exit_status,
|
cmocka_unit_test_setup_teardown(torture_channel_exit_status,
|
||||||
session_setup,
|
session_setup,
|
||||||
session_teardown),
|
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,
|
cmocka_unit_test_setup_teardown(torture_freed_channel_get_exit_status,
|
||||||
session_setup,
|
session_setup,
|
||||||
session_teardown),
|
session_teardown),
|
||||||
|
|||||||
Reference in New Issue
Block a user