Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
ad0f483d
Commit
ad0f483d
authored
Sep 05, 2023
by
Hans Leidekker
Committed by
Alexandre Julliard
Sep 12, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
iphlpapi/tests: Call GetAdaptersAddresses() in a loop.
Wine-Bug:
https://bugs.winehq.org/show_bug.cgi?id=54588
parent
5f7016d3
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
24 additions
and
13 deletions
+24
-13
iphlpapi.c
dlls/iphlpapi/tests/iphlpapi.c
+24
-13
No files found.
dlls/iphlpapi/tests/iphlpapi.c
View file @
ad0f483d
...
@@ -2080,16 +2080,32 @@ static void test_CreateSortedAddressPairs(void)
...
@@ -2080,16 +2080,32 @@ static void test_CreateSortedAddressPairs(void)
FreeMibTable
(
pair
);
FreeMibTable
(
pair
);
}
}
static
IP_ADAPTER_ADDRESSES
*
get_adapters
(
ULONG
flags
)
{
ULONG
err
,
size
=
4096
;
IP_ADAPTER_ADDRESSES
*
tmp
,
*
ret
;
if
(
!
(
ret
=
malloc
(
size
)))
return
NULL
;
err
=
GetAdaptersAddresses
(
AF_UNSPEC
,
flags
,
NULL
,
ret
,
&
size
);
while
(
err
==
ERROR_BUFFER_OVERFLOW
)
{
if
(
!
(
tmp
=
realloc
(
ret
,
size
)))
break
;
ret
=
tmp
;
err
=
GetAdaptersAddresses
(
AF_UNSPEC
,
flags
,
NULL
,
ret
,
&
size
);
}
if
(
err
==
ERROR_SUCCESS
)
return
ret
;
free
(
ret
);
return
NULL
;
}
static
DWORD
get_interface_index
(
void
)
static
DWORD
get_interface_index
(
void
)
{
{
DWORD
size
=
0
,
ret
=
0
;
DWORD
ret
=
0
;
IP_ADAPTER_ADDRESSES
*
buf
,
*
aa
;
IP_ADAPTER_ADDRESSES
*
buf
,
*
aa
;
if
(
GetAdaptersAddresses
(
AF_UNSPEC
,
0
,
NULL
,
NULL
,
&
size
)
!=
ERROR_BUFFER_OVERFLOW
)
buf
=
get_adapters
(
0
);
return
0
;
if
(
!
buf
)
return
0
;
buf
=
malloc
(
size
);
GetAdaptersAddresses
(
AF_UNSPEC
,
0
,
NULL
,
buf
,
&
size
);
for
(
aa
=
buf
;
aa
;
aa
=
aa
->
Next
)
for
(
aa
=
buf
;
aa
;
aa
=
aa
->
Next
)
{
{
if
(
aa
->
IfType
==
IF_TYPE_ETHERNET_CSMACD
)
if
(
aa
->
IfType
==
IF_TYPE_ETHERNET_CSMACD
)
...
@@ -2455,7 +2471,7 @@ static void test_GetUnicastIpAddressEntry(void)
...
@@ -2455,7 +2471,7 @@ static void test_GetUnicastIpAddressEntry(void)
{
{
IP_ADAPTER_ADDRESSES
*
aa
,
*
ptr
;
IP_ADAPTER_ADDRESSES
*
aa
,
*
ptr
;
MIB_UNICASTIPADDRESS_ROW
row
;
MIB_UNICASTIPADDRESS_ROW
row
;
DWORD
ret
,
size
;
DWORD
ret
;
if
(
!
pGetUnicastIpAddressEntry
)
if
(
!
pGetUnicastIpAddressEntry
)
{
{
...
@@ -2498,13 +2514,8 @@ static void test_GetUnicastIpAddressEntry(void)
...
@@ -2498,13 +2514,8 @@ static void test_GetUnicastIpAddressEntry(void)
ret
=
pGetUnicastIpAddressEntry
(
&
row
);
ret
=
pGetUnicastIpAddressEntry
(
&
row
);
ok
(
ret
==
ERROR_FILE_NOT_FOUND
,
"got %lu
\n
"
,
ret
);
ok
(
ret
==
ERROR_FILE_NOT_FOUND
,
"got %lu
\n
"
,
ret
);
ret
=
GetAdaptersAddresses
(
AF_UNSPEC
,
GAA_FLAG_INCLUDE_ALL_INTERFACES
,
NULL
,
NULL
,
&
size
);
ptr
=
get_adapters
(
GAA_FLAG_INCLUDE_ALL_INTERFACES
);
ok
(
ret
==
ERROR_BUFFER_OVERFLOW
,
"expected ERROR_BUFFER_OVERFLOW, got %lu
\n
"
,
ret
);
ok
(
ptr
!=
NULL
,
"can't get adapters
\n
"
);
if
(
ret
!=
ERROR_BUFFER_OVERFLOW
)
return
;
ptr
=
malloc
(
size
);
ret
=
GetAdaptersAddresses
(
AF_UNSPEC
,
GAA_FLAG_INCLUDE_ALL_INTERFACES
,
NULL
,
ptr
,
&
size
);
ok
(
!
ret
,
"expected ERROR_SUCCESS got %lu
\n
"
,
ret
);
for
(
aa
=
ptr
;
!
ret
&&
aa
;
aa
=
aa
->
Next
)
for
(
aa
=
ptr
;
!
ret
&&
aa
;
aa
=
aa
->
Next
)
{
{
...
...
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