libuv 1.47.0.

git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@4615 ed5197a5-7fde-0310-b194-c3ffbd925b24
This commit is contained in:
2023-11-07 17:30:39 +00:00
parent 889773c38d
commit ee9cb63327
226 changed files with 6648 additions and 6444 deletions

View File

@ -28,7 +28,7 @@
#define CHECK_HANDLE(handle) \
ASSERT((uv_udp_t*)(handle) == &server || (uv_udp_t*)(handle) == &client)
ASSERT_NE((uv_udp_t*)(handle) == &server || (uv_udp_t*)(handle) == &client, 0)
#if defined(__APPLE__) || \
defined(_AIX) || \
@ -58,7 +58,7 @@ static void alloc_cb(uv_handle_t* handle,
uv_buf_t* buf) {
static char slab[65536];
CHECK_HANDLE(handle);
ASSERT(suggested_size <= sizeof(slab));
ASSERT_LE(suggested_size, sizeof(slab));
buf->base = slab;
buf->len = sizeof(slab);
}
@ -72,7 +72,7 @@ static void close_cb(uv_handle_t* handle) {
static void sv_send_cb(uv_udp_send_t* req, int status) {
ASSERT_NOT_NULL(req);
ASSERT(status == 0);
ASSERT_OK(status);
CHECK_HANDLE(req->handle);
sv_send_cb_called++;
@ -88,7 +88,7 @@ static int do_send(uv_udp_send_t* send_req) {
buf = uv_buf_init("PING", 4);
ASSERT(0 == uv_ip6_addr(MULTICAST_ADDR, TEST_PORT, &addr));
ASSERT_OK(uv_ip6_addr(MULTICAST_ADDR, TEST_PORT, &addr));
/* client sends "PING" */
return uv_udp_send(send_req,
@ -106,7 +106,7 @@ static void cl_recv_cb(uv_udp_t* handle,
const struct sockaddr* addr,
unsigned flags) {
CHECK_HANDLE(handle);
ASSERT(flags == 0);
ASSERT_OK(flags);
if (nread < 0) {
ASSERT(0 && "unexpected error");
@ -119,7 +119,7 @@ static void cl_recv_cb(uv_udp_t* handle,
}
ASSERT_NOT_NULL(addr);
ASSERT(nread == 4);
ASSERT_EQ(4, nread);
ASSERT(!memcmp("PING", buf->base, nread));
cl_recv_cb_called++;
@ -132,16 +132,16 @@ static void cl_recv_cb(uv_udp_t* handle,
char source_addr[64];
r = uv_ip6_name((const struct sockaddr_in6*)addr, source_addr, sizeof(source_addr));
ASSERT(r == 0);
ASSERT_OK(r);
r = uv_udp_set_membership(&server, MULTICAST_ADDR, INTERFACE_ADDR, UV_LEAVE_GROUP);
ASSERT(r == 0);
ASSERT_OK(r);
r = uv_udp_set_source_membership(&server, MULTICAST_ADDR, INTERFACE_ADDR, source_addr, UV_JOIN_GROUP);
ASSERT(r == 0);
ASSERT_OK(r);
r = do_send(&req_ss);
ASSERT(r == 0);
ASSERT_OK(r);
}
}
@ -172,17 +172,17 @@ TEST_IMPL(udp_multicast_join6) {
if (!can_ipv6_external())
RETURN_SKIP("No external IPv6 interface available");
ASSERT(0 == uv_ip6_addr("::", TEST_PORT, &addr));
ASSERT_OK(uv_ip6_addr("::", TEST_PORT, &addr));
r = uv_udp_init(uv_default_loop(), &server);
ASSERT(r == 0);
ASSERT_OK(r);
r = uv_udp_init(uv_default_loop(), &client);
ASSERT(r == 0);
ASSERT_OK(r);
/* bind to the desired port */
r = uv_udp_bind(&server, (const struct sockaddr*) &addr, 0);
ASSERT(r == 0);
ASSERT_OK(r);
r = uv_udp_set_membership(&server, MULTICAST_ADDR, INTERFACE_ADDR, UV_JOIN_GROUP);
if (r == UV_ENODEV) {
@ -190,28 +190,28 @@ TEST_IMPL(udp_multicast_join6) {
RETURN_SKIP("No ipv6 multicast route");
}
ASSERT(r == 0);
ASSERT_OK(r);
/* TODO(gengjiawen): Fix test on QEMU. */
#if defined(__QEMU__)
RETURN_SKIP("Test does not currently work in QEMU");
#endif
r = uv_udp_recv_start(&server, alloc_cb, cl_recv_cb);
ASSERT(r == 0);
ASSERT_OK(r);
r = do_send(&req);
ASSERT(r == 0);
ASSERT_OK(r);
ASSERT(close_cb_called == 0);
ASSERT(cl_recv_cb_called == 0);
ASSERT(sv_send_cb_called == 0);
ASSERT_OK(close_cb_called);
ASSERT_OK(cl_recv_cb_called);
ASSERT_OK(sv_send_cb_called);
/* run the loop till all events are processed */
uv_run(uv_default_loop(), UV_RUN_DEFAULT);
ASSERT(cl_recv_cb_called == 2);
ASSERT(sv_send_cb_called == 2);
ASSERT(close_cb_called == 2);
ASSERT_EQ(2, cl_recv_cb_called);
ASSERT_EQ(2, sv_send_cb_called);
ASSERT_EQ(2, close_cb_called);
MAKE_VALGRIND_HAPPY(uv_default_loop());
return 0;