torture: Create a torture_terminate_process() function
Signed-off-by: Andreas Schneider <asn@cryptomilk.org>
Этот коммит содержится в:
родитель
d403c01a30
Коммит
ae89b6c078
@ -404,6 +404,47 @@ int torture_isdir(const char *path) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int torture_terminate_process(const char *pidfile)
|
||||||
|
{
|
||||||
|
char buf[8] = {0};
|
||||||
|
long int tmp;
|
||||||
|
ssize_t rc;
|
||||||
|
pid_t pid;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
/* read the pidfile */
|
||||||
|
fd = open(pidfile, O_RDONLY);
|
||||||
|
if (fd < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = read(fd, buf, sizeof(buf));
|
||||||
|
close(fd);
|
||||||
|
if (rc <= 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
buf[sizeof(buf) - 1] = '\0';
|
||||||
|
|
||||||
|
tmp = strtol(buf, NULL, 10);
|
||||||
|
if (tmp == 0 || tmp > 0xFFFF || errno == ERANGE) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
pid = (pid_t)(tmp & 0xFFFF);
|
||||||
|
|
||||||
|
/* Make sure the process goes away! */
|
||||||
|
kill(pid, SIGTERM);
|
||||||
|
|
||||||
|
kill(pid, 0);
|
||||||
|
if (rc == 0) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"WARNING: The process server is still running!\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
ssh_session torture_ssh_session(const char *host,
|
ssh_session torture_ssh_session(const char *host,
|
||||||
const unsigned int *port,
|
const unsigned int *port,
|
||||||
const char *user,
|
const char *user,
|
||||||
@ -931,43 +972,13 @@ void torture_teardown_socket_dir(void **state)
|
|||||||
void torture_teardown_sshd_server(void **state)
|
void torture_teardown_sshd_server(void **state)
|
||||||
{
|
{
|
||||||
struct torture_state *s = *state;
|
struct torture_state *s = *state;
|
||||||
char buf[8] = {0};
|
int rc;
|
||||||
long int tmp;
|
|
||||||
ssize_t rc;
|
|
||||||
pid_t pid;
|
|
||||||
int fd;
|
|
||||||
|
|
||||||
/* read the pidfile */
|
rc = torture_terminate_process(s->srv_pidfile);
|
||||||
fd = open(s->srv_pidfile, O_RDONLY);
|
if (rc != 0) {
|
||||||
if (fd < 0) {
|
fprintf(stderr, "Failed to terminate sshd");
|
||||||
goto done;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = read(fd, buf, sizeof(buf));
|
|
||||||
close(fd);
|
|
||||||
if (rc <= 0) {
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
|
|
||||||
buf[sizeof(buf) - 1] = '\0';
|
|
||||||
|
|
||||||
tmp = strtol(buf, NULL, 10);
|
|
||||||
if (tmp == 0 || tmp > 0xFFFF || errno == ERANGE) {
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
|
|
||||||
pid = (pid_t)(tmp & 0xFFFF);
|
|
||||||
|
|
||||||
/* Make sure the daemon goes away! */
|
|
||||||
kill(pid, SIGTERM);
|
|
||||||
|
|
||||||
kill(pid, 0);
|
|
||||||
if (rc == 0) {
|
|
||||||
fprintf(stderr,
|
|
||||||
"WARNING the sshd server is still running!\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
done:
|
|
||||||
torture_teardown_socket_dir(state);
|
torture_teardown_socket_dir(state);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -81,6 +81,8 @@ void torture_cmdline_parse(int argc, char **argv, struct argument_s *arguments);
|
|||||||
int torture_rmdirs(const char *path);
|
int torture_rmdirs(const char *path);
|
||||||
int torture_isdir(const char *path);
|
int torture_isdir(const char *path);
|
||||||
|
|
||||||
|
int torture_terminate_process(const char *pidfile);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Returns the verbosity level asked by user
|
* Returns the verbosity level asked by user
|
||||||
*/
|
*/
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user