libuv-svace-build
199 строк · 5.1 Кб
1/* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
2*
3* Permission is hereby granted, free of charge, to any person obtaining a copy
4* of this software and associated documentation files (the "Software"), to
5* deal in the Software without restriction, including without limitation the
6* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
7* sell copies of the Software, and to permit persons to whom the Software is
8* furnished to do so, subject to the following conditions:
9*
10* The above copyright notice and this permission notice shall be included in
11* all copies or substantial portions of the Software.
12*
13* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
18* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
19* IN THE SOFTWARE.
20*/
21
22#include "uv.h"
23#include "task.h"
24#include <stdio.h>
25#include <stdlib.h>
26
27
28#ifdef _WIN32
29# define BAD_PIPENAME "bad-pipe"
30#else
31# define BAD_PIPENAME "/path/to/unix/socket/that/really/should/not/be/there"
32#endif
33
34
35static int close_cb_called = 0;
36static int connect_cb_called = 0;
37
38
39static void close_cb(uv_handle_t* handle) {
40ASSERT_NOT_NULL(handle);
41close_cb_called++;
42}
43
44
45TEST_IMPL(pipe_bind_error_addrinuse) {
46uv_pipe_t server1, server2;
47int r;
48
49r = uv_pipe_init(uv_default_loop(), &server1, 0);
50ASSERT_OK(r);
51r = uv_pipe_bind(&server1, TEST_PIPENAME);
52ASSERT_OK(r);
53
54r = uv_pipe_init(uv_default_loop(), &server2, 0);
55ASSERT_OK(r);
56r = uv_pipe_bind(&server2, TEST_PIPENAME);
57ASSERT_EQ(r, UV_EADDRINUSE);
58
59r = uv_listen((uv_stream_t*)&server1, SOMAXCONN, NULL);
60ASSERT_OK(r);
61r = uv_listen((uv_stream_t*)&server2, SOMAXCONN, NULL);
62ASSERT_EQ(r, UV_EINVAL);
63
64uv_close((uv_handle_t*)&server1, close_cb);
65uv_close((uv_handle_t*)&server2, close_cb);
66
67uv_run(uv_default_loop(), UV_RUN_DEFAULT);
68
69ASSERT_EQ(2, close_cb_called);
70
71MAKE_VALGRIND_HAPPY(uv_default_loop());
72return 0;
73}
74
75
76TEST_IMPL(pipe_bind_error_addrnotavail) {
77uv_pipe_t server;
78int r;
79
80r = uv_pipe_init(uv_default_loop(), &server, 0);
81ASSERT_OK(r);
82
83r = uv_pipe_bind(&server, BAD_PIPENAME);
84ASSERT_EQ(r, UV_EACCES);
85
86uv_close((uv_handle_t*)&server, close_cb);
87
88uv_run(uv_default_loop(), UV_RUN_DEFAULT);
89
90ASSERT_EQ(1, close_cb_called);
91
92MAKE_VALGRIND_HAPPY(uv_default_loop());
93return 0;
94}
95
96
97TEST_IMPL(pipe_bind_error_inval) {
98uv_pipe_t server;
99int r;
100
101r = uv_pipe_init(uv_default_loop(), &server, 0);
102ASSERT_OK(r);
103r = uv_pipe_bind(&server, TEST_PIPENAME);
104ASSERT_OK(r);
105r = uv_pipe_bind(&server, TEST_PIPENAME_2);
106ASSERT_EQ(r, UV_EINVAL);
107
108uv_close((uv_handle_t*)&server, close_cb);
109
110uv_run(uv_default_loop(), UV_RUN_DEFAULT);
111
112ASSERT_EQ(1, close_cb_called);
113
114MAKE_VALGRIND_HAPPY(uv_default_loop());
115return 0;
116}
117
118
119TEST_IMPL(pipe_listen_without_bind) {
120#if defined(NO_SELF_CONNECT)
121RETURN_SKIP(NO_SELF_CONNECT);
122#endif
123uv_pipe_t server;
124int r;
125
126r = uv_pipe_init(uv_default_loop(), &server, 0);
127ASSERT_OK(r);
128
129r = uv_listen((uv_stream_t*)&server, SOMAXCONN, NULL);
130ASSERT_EQ(r, UV_EINVAL);
131
132uv_close((uv_handle_t*)&server, close_cb);
133
134uv_run(uv_default_loop(), UV_RUN_DEFAULT);
135
136ASSERT_EQ(1, close_cb_called);
137
138MAKE_VALGRIND_HAPPY(uv_default_loop());
139return 0;
140}
141
142TEST_IMPL(pipe_bind_or_listen_error_after_close) {
143uv_pipe_t server;
144
145ASSERT_OK(uv_pipe_init(uv_default_loop(), &server, 0));
146uv_close((uv_handle_t*) &server, NULL);
147
148ASSERT_EQ(uv_pipe_bind(&server, TEST_PIPENAME), UV_EINVAL);
149
150ASSERT_EQ(uv_listen((uv_stream_t*) &server, SOMAXCONN, NULL), UV_EINVAL);
151
152ASSERT_OK(uv_run(uv_default_loop(), UV_RUN_DEFAULT));
153
154MAKE_VALGRIND_HAPPY(uv_default_loop());
155return 0;
156}
157
158
159static void connect_overlong_cb(uv_connect_t* connect_req, int status) {
160ASSERT_EQ(status, UV_EINVAL);
161connect_cb_called++;
162uv_close((uv_handle_t*) connect_req->handle, close_cb);
163}
164
165
166TEST_IMPL(pipe_overlong_path) {
167uv_pipe_t pipe;
168uv_connect_t req;
169
170ASSERT_OK(uv_pipe_init(uv_default_loop(), &pipe, 0));
171
172#ifndef _WIN32
173char path[512];
174memset(path, '@', sizeof(path));
175ASSERT_EQ(UV_EINVAL,
176uv_pipe_bind2(&pipe, path, sizeof(path), UV_PIPE_NO_TRUNCATE));
177ASSERT_EQ(UV_EINVAL,
178uv_pipe_connect2(&req,
179&pipe,
180path,
181sizeof(path),
182UV_PIPE_NO_TRUNCATE,
183(uv_connect_cb) abort));
184ASSERT_OK(uv_run(uv_default_loop(), UV_RUN_DEFAULT));
185#endif
186
187ASSERT_EQ(UV_EINVAL, uv_pipe_bind(&pipe, ""));
188uv_pipe_connect(&req,
189&pipe,
190"",
191(uv_connect_cb) connect_overlong_cb);
192ASSERT_OK(uv_run(uv_default_loop(), UV_RUN_DEFAULT));
193ASSERT_EQ(1, connect_cb_called);
194ASSERT_EQ(1, close_cb_called);
195
196MAKE_VALGRIND_HAPPY(uv_default_loop());
197return 0;
198
199}
200