diff options
Diffstat (limited to 'test/src')
-rw-r--r-- | test/src/test-list.h | 1 | ||||
-rw-r--r-- | test/src/test-strerror.c | 35 |
2 files changed, 36 insertions, 0 deletions
diff --git a/test/src/test-list.h b/test/src/test-list.h index 591b858..abb7cda 100644 --- a/test/src/test-list.h +++ b/test/src/test-list.h @@ -6,6 +6,7 @@ V(uv_link_observer_t) \ V(close_depth) \ V(stop_read_on_error) \ + V(strerror) \ #define TEST_DECL(N) void test__##N(); diff --git a/test/src/test-strerror.c b/test/src/test-strerror.c new file mode 100644 index 0000000..c3b44c2 --- /dev/null +++ b/test/src/test-strerror.c @@ -0,0 +1,35 @@ +#include <sys/socket.h> +#include <unistd.h> + +#include "test-common.h" + +static uv_link_t st_link; + +static int close_cb_called; + + +const char* test_strerror(uv_link_t* l, int err) { + CHECK_EQ(l, &st_link, "link == st_link"); + return "Description"; +} + + +static uv_link_methods_t methods = { + .strerror = test_strerror, + .close = uv_link_default_close +}; + +static void close_cb(uv_link_t* l) { + close_cb_called++; +} + + +TEST_IMPL(strerror) { + CHECK_EQ(uv_link_init(&st_link, &methods), 0, "uv_link_init()"); + + CHECK_EQ(strcmp(uv_link_strerror(&st_link, -1), "Description"), 0, + "error description should match"); + + uv_link_close(&st_link, close_cb); + CHECK_EQ(close_cb_called, 1, "close_cb must be called"); +} |