node/deps/uv/test/task.h

147 lines
5.4 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
# include "uv-private/stdint-msvc2008.h"
#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
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)
2011-05-13 10:16:40 +08:00
#endif /* TASK_H_ */