mirror of
https://git.libssh.org/projects/libssh.git
synced 2026-02-11 18:50:28 +09:00
Reproducer for out of bounds read of SFTP extensions
Signed-off-by: Jakub Jelen <jjelen@redhat.com> Reviewed-by: Pavol Žáčik <pzacik@redhat.com>
This commit is contained in:
@@ -72,6 +72,63 @@ static void session_setup_channel(void **state)
|
||||
assert_non_null(s->ssh.tsftp);
|
||||
}
|
||||
|
||||
static void session_setup_extensions(void **state)
|
||||
{
|
||||
struct torture_state *s = *state;
|
||||
struct passwd *pwd = NULL;
|
||||
int rc, count;
|
||||
const char *name = NULL, *data = NULL;
|
||||
sftp_session sftp = NULL;
|
||||
|
||||
pwd = getpwnam("bob");
|
||||
assert_non_null(pwd);
|
||||
|
||||
rc = setuid(pwd->pw_uid);
|
||||
assert_return_code(rc, errno);
|
||||
|
||||
s->ssh.session = torture_ssh_session(s,
|
||||
TORTURE_SSH_SERVER,
|
||||
NULL,
|
||||
TORTURE_SSH_USER_ALICE,
|
||||
NULL);
|
||||
assert_non_null(s->ssh.session);
|
||||
|
||||
s->ssh.tsftp = torture_sftp_session(s->ssh.session);
|
||||
assert_non_null(s->ssh.tsftp);
|
||||
sftp = s->ssh.tsftp->sftp;
|
||||
|
||||
/* null parameter */
|
||||
count = sftp_extensions_get_count(NULL);
|
||||
assert_int_equal(count, 0);
|
||||
|
||||
count = sftp_extensions_get_count(sftp);
|
||||
assert_int_not_equal(count, 0);
|
||||
|
||||
/* first null parameter */
|
||||
name = sftp_extensions_get_name(NULL, 0);
|
||||
assert_null(name);
|
||||
data = sftp_extensions_get_data(NULL, 0);
|
||||
assert_null(data);
|
||||
|
||||
/* First extension */
|
||||
name = sftp_extensions_get_name(sftp, 0);
|
||||
assert_non_null(name);
|
||||
data = sftp_extensions_get_data(sftp, 0);
|
||||
assert_non_null(data);
|
||||
|
||||
/* Last extension */
|
||||
name = sftp_extensions_get_name(sftp, count - 1);
|
||||
assert_non_null(name);
|
||||
data = sftp_extensions_get_data(sftp, count - 1);
|
||||
assert_non_null(data);
|
||||
|
||||
/* Overrun */
|
||||
name = sftp_extensions_get_name(sftp, count);
|
||||
assert_null(name);
|
||||
data = sftp_extensions_get_data(sftp, count);
|
||||
assert_null(data);
|
||||
}
|
||||
|
||||
static int session_teardown(void **state)
|
||||
{
|
||||
struct torture_state *s = *state;
|
||||
@@ -92,7 +149,10 @@ int torture_run_tests(void) {
|
||||
session_teardown),
|
||||
cmocka_unit_test_setup_teardown(session_setup_channel,
|
||||
NULL,
|
||||
session_teardown)
|
||||
session_teardown),
|
||||
cmocka_unit_test_setup_teardown(session_setup_extensions,
|
||||
NULL,
|
||||
session_teardown),
|
||||
};
|
||||
|
||||
ssh_init();
|
||||
|
||||
Reference in New Issue
Block a user