123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- /* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to
- * deal in the Software without restriction, including without limitation the
- * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
- * sell copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
- * IN THE SOFTWARE.
- */
- #ifndef RUNNER_H_
- #define RUNNER_H_
- #include <stdio.h> /* FILE */
- /*
- * The maximum number of processes (main + helpers) that a test / benchmark
- * can have.
- */
- #define MAX_PROCESSES 8
- /*
- * Struct to store both tests and to define helper processes for tasks.
- */
- typedef struct {
- char *task_name;
- char *process_name;
- int (*main)(void);
- int is_helper;
- int show_output;
- } task_entry_t, bench_entry_t;
- /*
- * Macros used by test-list.h and benchmark-list.h.
- */
- #define TASK_LIST_START \
- task_entry_t TASKS[] = {
- #define TASK_LIST_END \
- { 0, 0, 0, 0, 0 } \
- };
- #define TEST_DECLARE(name) \
- int run_test_##name(void);
- #define TEST_ENTRY(name) \
- { #name, #name, &run_test_##name, 0, 0 },
- #define TEST_OUTPUT_ENTRY(name) \
- { #name, #name, &run_test_##name, 0, 1 },
- #define BENCHMARK_DECLARE(name) \
- int run_benchmark_##name(void);
- #define BENCHMARK_ENTRY(name) \
- { #name, #name, &run_benchmark_##name, 0, 0 },
- #define HELPER_DECLARE(name) \
- int run_helper_##name(void);
- #define HELPER_ENTRY(task_name, name) \
- { #task_name, #name, &run_helper_##name, 1, 0 },
- #define TEST_HELPER HELPER_ENTRY
- #define BENCHMARK_HELPER HELPER_ENTRY
- #define PATHMAX 1024
- extern char executable_path[PATHMAX];
- /*
- * Include platform-dependent definitions
- */
- #ifdef _WIN32
- # include "runner-win.h"
- #else
- # include "runner-unix.h"
- #endif
- /* The array that is filled by test-list.h or benchmark-list.h */
- extern task_entry_t TASKS[];
- /*
- * Run all tests.
- */
- int run_tests(int timeout, int benchmark_output);
- /*
- * Run a single test. Starts up any helpers.
- */
- int run_test(const char* test,
- int timeout,
- int benchmark_output,
- int test_count);
- /*
- * Run a test part, i.e. the test or one of its helpers.
- */
- int run_test_part(const char* test, const char* part);
- /*
- * Print tests in sorted order to `stream`. Used by `./run-tests --list`.
- */
- void print_tests(FILE* stream);
- /*
- * Stuff that should be implemented by test-runner-<platform>.h
- * All functions return 0 on success, -1 on failure, unless specified
- * otherwise.
- */
- /* Do platform-specific initialization. */
- void platform_init(int argc, char** argv);
- /* Invoke "argv[0] test-name [test-part]". Store process info in *p. */
- /* Make sure that all stdio output of the processes is buffered up. */
- int process_start(char *name, char* part, process_info_t *p, int is_helper);
- /* Wait for all `n` processes in `vec` to terminate. */
- /* Time out after `timeout` msec, or never if timeout == -1 */
- /* Return 0 if all processes are terminated, -1 on error, -2 on timeout. */
- int process_wait(process_info_t *vec, int n, int timeout);
- /* Returns the number of bytes in the stdio output buffer for process `p`. */
- long int process_output_size(process_info_t *p);
- /* Copy the contents of the stdio output buffer to `fd`. */
- int process_copy_output(process_info_t *p, int fd);
- /* Copy the last line of the stdio output buffer to `buffer` */
- int process_read_last_line(process_info_t *p,
- char * buffer,
- size_t buffer_len);
- /* Return the name that was specified when `p` was started by process_start */
- char* process_get_name(process_info_t *p);
- /* Terminate process `p`. */
- int process_terminate(process_info_t *p);
- /* Return the exit code of process p. */
- /* On error, return -1. */
- int process_reap(process_info_t *p);
- /* Clean up after terminating process `p` (e.g. free the output buffer etc.). */
- void process_cleanup(process_info_t *p);
- /* Move the console cursor one line up and back to the first column. */
- void rewind_cursor(void);
- /* trigger output as tap */
- extern int tap_output;
- #endif /* RUNNER_H_ */
|