Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
8178f8fc
Commit
8178f8fc
authored
May 25, 2007
by
Damjan Jovanovic
Committed by
Alexandre Julliard
May 25, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ws2_32: Simplify some socket tests by adding a function that generates a pair of connected sockets.
parent
622bad5d
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
57 additions
and
111 deletions
+57
-111
sock.c
dlls/ws2_32/tests/sock.c
+57
-111
No files found.
dlls/ws2_32/tests/sock.c
View file @
8178f8fc
...
@@ -146,6 +146,57 @@ static int client_id;
...
@@ -146,6 +146,57 @@ static int client_id;
/**************** General utility functions ***************/
/**************** General utility functions ***************/
static
int
tcp_socketpair
(
SOCKET
*
src
,
SOCKET
*
dst
)
{
SOCKET
server
=
INVALID_SOCKET
;
struct
sockaddr_in
addr
;
int
len
;
int
ret
;
*
src
=
INVALID_SOCKET
;
*
dst
=
INVALID_SOCKET
;
*
src
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
*
src
==
INVALID_SOCKET
)
goto
end
;
server
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
server
==
INVALID_SOCKET
)
goto
end
;
memset
(
&
addr
,
0
,
sizeof
(
addr
));
addr
.
sin_family
=
AF_INET
;
addr
.
sin_addr
.
s_addr
=
inet_addr
(
"127.0.0.1"
);
ret
=
bind
(
server
,
(
struct
sockaddr
*
)
&
addr
,
sizeof
(
addr
));
if
(
ret
!=
0
)
goto
end
;
len
=
sizeof
(
addr
);
ret
=
getsockname
(
server
,
(
struct
sockaddr
*
)
&
addr
,
&
len
);
if
(
ret
!=
0
)
goto
end
;
ret
=
listen
(
server
,
1
);
if
(
ret
!=
0
)
goto
end
;
ret
=
connect
(
*
src
,
(
struct
sockaddr
*
)
&
addr
,
sizeof
(
addr
));
if
(
ret
!=
0
)
goto
end
;
len
=
sizeof
(
addr
);
*
dst
=
accept
(
server
,
(
struct
sockaddr
*
)
&
addr
,
&
len
);
end:
if
(
server
!=
INVALID_SOCKET
)
closesocket
(
server
);
if
(
*
src
!=
INVALID_SOCKET
&&
*
dst
!=
INVALID_SOCKET
)
return
0
;
closesocket
(
*
src
);
closesocket
(
*
dst
);
return
-
1
;
}
static
void
set_so_opentype
(
BOOL
overlapped
)
static
void
set_so_opentype
(
BOOL
overlapped
)
{
{
int
optval
=
!
overlapped
,
newval
,
len
=
sizeof
(
int
);
int
optval
=
!
overlapped
,
newval
,
len
=
sizeof
(
int
);
...
@@ -1635,68 +1686,17 @@ static DWORD WINAPI drain_socket_thread(LPVOID arg)
...
@@ -1635,68 +1686,17 @@ static DWORD WINAPI drain_socket_thread(LPVOID arg)
static
void
test_send
(
void
)
static
void
test_send
(
void
)
{
{
SOCKET
src
=
INVALID_SOCKET
;
SOCKET
src
=
INVALID_SOCKET
;
SOCKET
server
=
INVALID_SOCKET
;
SOCKET
dst
=
INVALID_SOCKET
;
SOCKET
dst
=
INVALID_SOCKET
;
HANDLE
hThread
=
NULL
;
HANDLE
hThread
=
NULL
;
struct
sockaddr_in
addr
;
int
len
;
const
int
buflen
=
1024
*
1024
;
const
int
buflen
=
1024
*
1024
;
char
*
buffer
=
NULL
;
char
*
buffer
=
NULL
;
int
ret
;
int
ret
;
DWORD
id
;
DWORD
id
;
src
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
tcp_socketpair
(
&
src
,
&
dst
)
!=
0
)
if
(
src
==
INVALID_SOCKET
)
{
ok
(
0
,
"socket failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
server
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
server
==
INVALID_SOCKET
)
{
ok
(
0
,
"socket failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
memset
(
&
addr
,
0
,
sizeof
(
addr
));
addr
.
sin_family
=
AF_INET
;
addr
.
sin_addr
.
s_addr
=
inet_addr
(
"127.0.0.1"
);
ret
=
bind
(
server
,
(
struct
sockaddr
*
)
&
addr
,
sizeof
(
addr
));
if
(
ret
!=
0
)
{
ok
(
0
,
"bind failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
len
=
sizeof
(
addr
);
ret
=
getsockname
(
server
,
(
struct
sockaddr
*
)
&
addr
,
&
len
);
if
(
ret
!=
0
)
{
ok
(
0
,
"getsockname failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
ret
=
listen
(
server
,
1
);
if
(
ret
!=
0
)
{
ok
(
0
,
"listen failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
ret
=
connect
(
src
,
(
struct
sockaddr
*
)
&
addr
,
sizeof
(
addr
));
if
(
ret
!=
0
)
{
ok
(
0
,
"connect failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
len
=
sizeof
(
addr
);
dst
=
accept
(
server
,
(
struct
sockaddr
*
)
&
addr
,
&
len
);
if
(
dst
==
INVALID_SOCKET
)
{
{
ok
(
0
,
"
accept failed, error %d
\n
"
,
WSAGetLastError
()
);
ok
(
0
,
"
creating socket pair failed, skipping test
\n
"
);
goto
end
;
return
;
}
}
hThread
=
CreateThread
(
NULL
,
0
,
drain_socket_thread
,
&
dst
,
0
,
&
id
);
hThread
=
CreateThread
(
NULL
,
0
,
drain_socket_thread
,
&
dst
,
0
,
&
id
);
...
@@ -1722,8 +1722,6 @@ static void test_send(void)
...
@@ -1722,8 +1722,6 @@ static void test_send(void)
end:
end:
if
(
src
!=
INVALID_SOCKET
)
if
(
src
!=
INVALID_SOCKET
)
closesocket
(
src
);
closesocket
(
src
);
if
(
server
!=
INVALID_SOCKET
)
closesocket
(
server
);
if
(
dst
!=
INVALID_SOCKET
)
if
(
dst
!=
INVALID_SOCKET
)
closesocket
(
dst
);
closesocket
(
dst
);
if
(
hThread
!=
NULL
)
if
(
hThread
!=
NULL
)
...
@@ -1734,68 +1732,18 @@ end:
...
@@ -1734,68 +1732,18 @@ end:
static
void
test_write_events
(
void
)
static
void
test_write_events
(
void
)
{
{
SOCKET
src
=
INVALID_SOCKET
;
SOCKET
src
=
INVALID_SOCKET
;
SOCKET
server
=
INVALID_SOCKET
;
SOCKET
dst
=
INVALID_SOCKET
;
SOCKET
dst
=
INVALID_SOCKET
;
HANDLE
hThread
=
NULL
;
HANDLE
hThread
=
NULL
;
HANDLE
hEvent
=
INVALID_HANDLE_VALUE
;
HANDLE
hEvent
=
INVALID_HANDLE_VALUE
;
struct
sockaddr_in
addr
;
int
len
;
int
len
;
u_long
one
=
1
;
u_long
one
=
1
;
int
ret
;
int
ret
;
DWORD
id
;
DWORD
id
;
src
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
tcp_socketpair
(
&
src
,
&
dst
)
!=
0
)
if
(
src
==
INVALID_SOCKET
)
{
ok
(
0
,
"socket failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
server
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
server
==
INVALID_SOCKET
)
{
ok
(
0
,
"socket failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
memset
(
&
addr
,
0
,
sizeof
(
addr
));
addr
.
sin_family
=
AF_INET
;
addr
.
sin_addr
.
s_addr
=
inet_addr
(
"127.0.0.1"
);
ret
=
bind
(
server
,
(
struct
sockaddr
*
)
&
addr
,
sizeof
(
addr
));
if
(
ret
!=
0
)
{
ok
(
0
,
"bind failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
len
=
sizeof
(
addr
);
ret
=
getsockname
(
server
,
(
struct
sockaddr
*
)
&
addr
,
&
len
);
if
(
ret
!=
0
)
{
ok
(
0
,
"getsockname failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
ret
=
listen
(
server
,
1
);
if
(
ret
!=
0
)
{
ok
(
0
,
"listen failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
ret
=
connect
(
src
,
(
struct
sockaddr
*
)
&
addr
,
sizeof
(
addr
));
if
(
ret
!=
0
)
{
ok
(
0
,
"connect failed, error %d
\n
"
,
WSAGetLastError
());
goto
end
;
}
len
=
sizeof
(
addr
);
dst
=
accept
(
server
,
(
struct
sockaddr
*
)
&
addr
,
&
len
);
if
(
dst
==
INVALID_SOCKET
)
{
{
ok
(
0
,
"
accept failed, error %d
\n
"
,
WSAGetLastError
()
);
ok
(
0
,
"
creating socket pair failed, skipping test
\n
"
);
goto
end
;
return
;
}
}
hThread
=
CreateThread
(
NULL
,
0
,
drain_socket_thread
,
&
dst
,
0
,
&
id
);
hThread
=
CreateThread
(
NULL
,
0
,
drain_socket_thread
,
&
dst
,
0
,
&
id
);
...
@@ -1863,8 +1811,6 @@ static void test_write_events(void)
...
@@ -1863,8 +1811,6 @@ static void test_write_events(void)
end:
end:
if
(
src
!=
INVALID_SOCKET
)
if
(
src
!=
INVALID_SOCKET
)
closesocket
(
src
);
closesocket
(
src
);
if
(
server
!=
INVALID_SOCKET
)
closesocket
(
server
);
if
(
dst
!=
INVALID_SOCKET
)
if
(
dst
!=
INVALID_SOCKET
)
closesocket
(
dst
);
closesocket
(
dst
);
if
(
hThread
!=
NULL
)
if
(
hThread
!=
NULL
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment