Annotation of embedaddon/rsync/testrun.c, revision 1.1

1.1     ! misho       1: /* Run a testsuite script with a timeout. */
        !             2: 
        !             3: #include "rsync.h"
        !             4: 
        !             5: #define DEFAULT_TIMEOUT_SECS (5*60)
        !             6: #define TIMEOUT_ENV "TESTRUN_TIMEOUT"
        !             7: 
        !             8:  int main(int argc, char *argv[])
        !             9: {
        !            10:        pid_t pid;
        !            11:        char *timeout_env;
        !            12:        int status, timeout_secs, slept = 0;
        !            13: 
        !            14:        if (argc < 2) {
        !            15:                fprintf(stderr, "Usage: testrun [SHELL_OPTIONS] TESTSUITE_SCRIPT [ARGS]\n");
        !            16:                exit(1);
        !            17:        }
        !            18: 
        !            19:        if ((timeout_env = getenv(TIMEOUT_ENV)) != NULL)
        !            20:                timeout_secs = atoi(timeout_env);
        !            21:        else
        !            22:                timeout_secs = DEFAULT_TIMEOUT_SECS;
        !            23: 
        !            24:        if ((pid = fork()) < 0) {
        !            25:                fprintf(stderr, "TESTRUN ERROR: fork failed: %s\n", strerror(errno));
        !            26:                exit(1);
        !            27:        }
        !            28: 
        !            29:        if (pid == 0) {
        !            30:                argv[0] = "sh";
        !            31:                execvp(argv[0], argv);
        !            32:                fprintf(stderr, "TESTRUN ERROR: failed to exec %s: %s\n", argv[0], strerror(errno));
        !            33:                _exit(1);
        !            34:        }
        !            35: 
        !            36:        while (1) {
        !            37:                int ret = waitpid(pid, &status, WNOHANG);
        !            38:                if (ret > 0)
        !            39:                        break;
        !            40:                if (ret < 0) {
        !            41:                        if (errno == EINTR)
        !            42:                                continue;
        !            43:                        fprintf(stderr, "TESTRUN ERROR: waitpid failed: %s\n", strerror(errno));
        !            44:                        exit(1);
        !            45:                }
        !            46:                if (slept++ > timeout_secs) {
        !            47:                        fprintf(stderr, "TESTRUN TIMEOUT: test took over %d seconds.\n", timeout_secs);
        !            48:                        if (kill(pid, SIGTERM) < 0)
        !            49:                                fprintf(stderr, "TESTRUN ERROR: failed to kill pid %d: %s\n", (int)pid, strerror(errno));
        !            50:                        else
        !            51:                                fprintf(stderr, "TESTRUN INFO: killed pid %d\n", (int)pid);
        !            52:                        exit(1);
        !            53:                }
        !            54:                sleep(1);
        !            55:        }
        !            56: 
        !            57:        if (!WIFEXITED(status))
        !            58:                exit(255);
        !            59: 
        !            60:        return WEXITSTATUS(status);
        !            61: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>