xref: /netbsd-src/external/mit/libuv/dist/test/test-not-readable-nor-writable-on-read-error.c (revision 5f2f42719cd62ff11fd913b40b7ce19f07c4fd25)
1*5f2f4271Schristos /* Copyright the libuv project contributors. All rights reserved.
2*5f2f4271Schristos  *
3*5f2f4271Schristos  * Permission is hereby granted, free of charge, to any person obtaining a copy
4*5f2f4271Schristos  * of this software and associated documentation files (the "Software"), to
5*5f2f4271Schristos  * deal in the Software without restriction, including without limitation the
6*5f2f4271Schristos  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
7*5f2f4271Schristos  * sell copies of the Software, and to permit persons to whom the Software is
8*5f2f4271Schristos  * furnished to do so, subject to the following conditions:
9*5f2f4271Schristos  *
10*5f2f4271Schristos  * The above copyright notice and this permission notice shall be included in
11*5f2f4271Schristos  * all copies or substantial portions of the Software.
12*5f2f4271Schristos  *
13*5f2f4271Schristos  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14*5f2f4271Schristos  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15*5f2f4271Schristos  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16*5f2f4271Schristos  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17*5f2f4271Schristos  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
18*5f2f4271Schristos  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
19*5f2f4271Schristos  * IN THE SOFTWARE.
20*5f2f4271Schristos  */
21*5f2f4271Schristos 
22*5f2f4271Schristos #include "uv.h"
23*5f2f4271Schristos #include "task.h"
24*5f2f4271Schristos 
25*5f2f4271Schristos static uv_loop_t loop;
26*5f2f4271Schristos static uv_tcp_t tcp_client;
27*5f2f4271Schristos static uv_connect_t connect_req;
28*5f2f4271Schristos static uv_write_t write_req;
29*5f2f4271Schristos static char reset_me_cmd[] = {'Q', 'S', 'H'};
30*5f2f4271Schristos 
31*5f2f4271Schristos static int connect_cb_called;
32*5f2f4271Schristos static int read_cb_called;
33*5f2f4271Schristos static int write_cb_called;
34*5f2f4271Schristos static int close_cb_called;
35*5f2f4271Schristos 
write_cb(uv_write_t * req,int status)36*5f2f4271Schristos static void write_cb(uv_write_t* req, int status) {
37*5f2f4271Schristos   write_cb_called++;
38*5f2f4271Schristos   ASSERT(status == 0);
39*5f2f4271Schristos }
40*5f2f4271Schristos 
alloc_cb(uv_handle_t * handle,size_t suggested_size,uv_buf_t * buf)41*5f2f4271Schristos static void alloc_cb(uv_handle_t* handle,
42*5f2f4271Schristos                      size_t suggested_size,
43*5f2f4271Schristos                      uv_buf_t* buf) {
44*5f2f4271Schristos   static char slab[64];
45*5f2f4271Schristos   buf->base = slab;
46*5f2f4271Schristos   buf->len = sizeof(slab);
47*5f2f4271Schristos }
48*5f2f4271Schristos 
close_cb(uv_handle_t * handle)49*5f2f4271Schristos static void close_cb(uv_handle_t* handle) {
50*5f2f4271Schristos   close_cb_called++;
51*5f2f4271Schristos }
52*5f2f4271Schristos 
read_cb(uv_stream_t * handle,ssize_t nread,const uv_buf_t * buf)53*5f2f4271Schristos static void read_cb(uv_stream_t* handle, ssize_t nread, const uv_buf_t* buf) {
54*5f2f4271Schristos   read_cb_called++;
55*5f2f4271Schristos 
56*5f2f4271Schristos   ASSERT((nread < 0) && (nread != UV_EOF));
57*5f2f4271Schristos   ASSERT(0 == uv_is_writable(handle));
58*5f2f4271Schristos   ASSERT(0 == uv_is_readable(handle));
59*5f2f4271Schristos 
60*5f2f4271Schristos   uv_close((uv_handle_t*) handle, close_cb);
61*5f2f4271Schristos }
62*5f2f4271Schristos 
connect_cb(uv_connect_t * req,int status)63*5f2f4271Schristos static void connect_cb(uv_connect_t* req, int status) {
64*5f2f4271Schristos   int r;
65*5f2f4271Schristos   uv_buf_t reset_me;
66*5f2f4271Schristos 
67*5f2f4271Schristos   connect_cb_called++;
68*5f2f4271Schristos   ASSERT(status == 0);
69*5f2f4271Schristos 
70*5f2f4271Schristos   r = uv_read_start((uv_stream_t*) &tcp_client, alloc_cb, read_cb);
71*5f2f4271Schristos   ASSERT(r == 0);
72*5f2f4271Schristos 
73*5f2f4271Schristos   reset_me = uv_buf_init(reset_me_cmd, sizeof(reset_me_cmd));
74*5f2f4271Schristos 
75*5f2f4271Schristos   r = uv_write(&write_req,
76*5f2f4271Schristos                (uv_stream_t*) &tcp_client,
77*5f2f4271Schristos                &reset_me,
78*5f2f4271Schristos                1,
79*5f2f4271Schristos                write_cb);
80*5f2f4271Schristos 
81*5f2f4271Schristos   ASSERT(r == 0);
82*5f2f4271Schristos }
83*5f2f4271Schristos 
TEST_IMPL(not_readable_nor_writable_on_read_error)84*5f2f4271Schristos TEST_IMPL(not_readable_nor_writable_on_read_error) {
85*5f2f4271Schristos   struct sockaddr_in sa;
86*5f2f4271Schristos   ASSERT(0 == uv_ip4_addr("127.0.0.1", TEST_PORT, &sa));
87*5f2f4271Schristos   ASSERT(0 == uv_loop_init(&loop));
88*5f2f4271Schristos   ASSERT(0 == uv_tcp_init(&loop, &tcp_client));
89*5f2f4271Schristos 
90*5f2f4271Schristos   ASSERT(0 == uv_tcp_connect(&connect_req,
91*5f2f4271Schristos                              &tcp_client,
92*5f2f4271Schristos                              (const struct sockaddr*) &sa,
93*5f2f4271Schristos                              connect_cb));
94*5f2f4271Schristos 
95*5f2f4271Schristos   ASSERT(0 == uv_run(&loop, UV_RUN_DEFAULT));
96*5f2f4271Schristos 
97*5f2f4271Schristos   ASSERT(connect_cb_called == 1);
98*5f2f4271Schristos   ASSERT(read_cb_called == 1);
99*5f2f4271Schristos   ASSERT(write_cb_called == 1);
100*5f2f4271Schristos   ASSERT(close_cb_called == 1);
101*5f2f4271Schristos 
102*5f2f4271Schristos   MAKE_VALGRIND_HAPPY();
103*5f2f4271Schristos   return 0;
104*5f2f4271Schristos }
105