node/deps/uv/test/task.h

185 lines
6.1 KiB
C
Raw Normal View History

2011-05-13 10:16:40 +08:00
/* 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 TASK_H_
#define TASK_H_
#include <stdio.h>
2012-01-23 20:35:36 +08:00
#include <stddef.h>
2011-05-13 10:16:40 +08:00
#include <stdlib.h>
2012-10-31 06:06:03 +08:00
#if defined(_MSC_VER) && _MSC_VER < 1600
2013-07-17 03:04:31 +08:00
# include "stdint-msvc2008.h"
2012-10-31 06:06:03 +08:00
#else
# include <stdint.h>
#endif
#define TEST_PORT 9123
#define TEST_PORT_2 9124
2011-05-13 10:16:40 +08:00
2011-07-15 05:28:52 +08:00
#ifdef _WIN32
# define TEST_PIPENAME "\\\\.\\pipe\\uv-test"
2011-07-21 06:19:31 +08:00
# define TEST_PIPENAME_2 "\\\\.\\pipe\\uv-test2"
2011-07-15 05:28:52 +08:00
#else
2011-07-19 07:26:37 +08:00
# define TEST_PIPENAME "/tmp/uv-test-sock"
2011-07-21 06:19:31 +08:00
# define TEST_PIPENAME_2 "/tmp/uv-test-sock2"
2011-07-15 05:28:52 +08:00
#endif
2013-06-27 01:48:10 +08:00
#ifdef _WIN32
# include <io.h>
# ifndef S_IRUSR
# define S_IRUSR _S_IREAD
# endif
# ifndef S_IWUSR
# define S_IWUSR _S_IWRITE
# endif
#endif
2012-01-23 20:35:36 +08:00
#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
#define container_of(ptr, type, member) \
((type *) ((char *) (ptr) - offsetof(type, member)))
2011-10-21 06:25:57 +08:00
2011-07-15 05:28:52 +08:00
typedef enum {
TCP = 0,
2012-01-17 07:15:34 +08:00
UDP,
2011-07-15 05:28:52 +08:00
PIPE
} stream_type;
2011-05-13 10:16:40 +08:00
/* Log to stderr. */
2011-07-21 06:19:31 +08:00
#define LOG(...) \
do { \
fprintf(stderr, "%s", __VA_ARGS__); \
fflush(stderr); \
} while (0)
#define LOGF(...) \
do { \
fprintf(stderr, __VA_ARGS__); \
fflush(stderr); \
} while (0)
2011-05-13 10:16:40 +08:00
/* Die with fatal error. */
#define FATAL(msg) \
do { \
fprintf(stderr, \
"Fatal error in %s on line %d: %s\n", \
__FILE__, \
__LINE__, \
msg); \
2011-07-21 06:19:31 +08:00
fflush(stderr); \
2011-05-13 10:16:40 +08:00
abort(); \
} while (0)
/* Have our own assert, so we are sure it does not get optimized away in
* a release build.
*/
#define ASSERT(expr) \
do { \
if (!(expr)) { \
fprintf(stderr, \
"Assertion failed in %s on line %d: %s\n", \
__FILE__, \
__LINE__, \
#expr); \
abort(); \
} \
} while (0)
2012-10-18 00:33:40 +08:00
/* This macro cleans up the main loop. This is used to avoid valgrind
* warnings about memory being "leaked" by the main event loop.
*/
#define MAKE_VALGRIND_HAPPY() \
uv_loop_delete(uv_default_loop())
2011-05-13 10:16:40 +08:00
/* Just sugar for wrapping the main() for a task or helper. */
2013-01-11 20:49:45 +08:00
#define TEST_IMPL(name) \
int run_test_##name(void); \
int run_test_##name(void)
2011-05-13 10:16:40 +08:00
2013-01-11 20:49:45 +08:00
#define BENCHMARK_IMPL(name) \
int run_benchmark_##name(void); \
int run_benchmark_##name(void)
2011-05-13 10:16:40 +08:00
2013-01-11 20:49:45 +08:00
#define HELPER_IMPL(name) \
int run_helper_##name(void); \
int run_helper_##name(void)
2011-05-13 10:16:40 +08:00
/* Pause the calling thread for a number of milliseconds. */
void uv_sleep(int msec);
2012-07-21 01:01:46 +08:00
/* Format big numbers nicely. WARNING: leaks memory. */
const char* fmt(double d);
2013-05-11 06:30:53 +08:00
/* Reserved test exit codes. */
enum test_status {
TEST_OK = 0,
TEST_TODO,
TEST_SKIP
};
#define RETURN_OK() \
do { \
return TEST_OK; \
} while (0)
#define RETURN_TODO(explanation) \
do { \
LOGF("%s\n", explanation); \
return TEST_TODO; \
} while (0)
#define RETURN_SKIP(explanation) \
do { \
LOGF("%s\n", explanation); \
return TEST_SKIP; \
} while (0)
2013-08-07 05:35:33 +08:00
#ifdef _WIN32
#include <stdarg.h>
/* Emulate snprintf() on Windows, _snprintf() doesn't zero-terminate the buffer
* on overflow...
*/
static int snprintf(char* buf, size_t len, const char* fmt, ...) {
va_list ap;
int n;
va_start(ap, fmt);
n = _vsprintf_p(buf, len, fmt, ap);
va_end(ap);
/* It's a sad fact of life that no one ever checks the return value of
* snprintf(). Zero-terminating the buffer hopefully reduces the risk
* of gaping security holes.
*/
if (n < 0)
if (len > 0)
buf[0] = '\0';
return n;
}
#endif
2011-05-13 10:16:40 +08:00
#endif /* TASK_H_ */