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