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
36389080
Commit
36389080
authored
Jul 26, 2011
by
Hans Leidekker
Committed by
Alexandre Julliard
Jul 26, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winhttp: Add some parameter checks.
parent
ca9ab005
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
88 additions
and
6 deletions
+88
-6
request.c
dlls/winhttp/request.c
+9
-1
winhttp.c
dlls/winhttp/tests/winhttp.c
+79
-5
No files found.
dlls/winhttp/request.c
View file @
36389080
...
...
@@ -2443,7 +2443,7 @@ static HRESULT WINAPI winhttp_request_Open(
TRACE
(
"%p, %s, %s, %s
\n
"
,
request
,
debugstr_w
(
method
),
debugstr_w
(
url
),
debugstr_variant
(
&
async
));
if
(
!
method
)
return
E_INVALIDARG
;
if
(
!
method
||
!
url
)
return
E_INVALIDARG
;
memset
(
&
uc
,
0
,
sizeof
(
uc
)
);
uc
.
dwStructSize
=
sizeof
(
uc
);
...
...
@@ -2667,6 +2667,7 @@ static HRESULT WINAPI winhttp_request_get_Status(
TRACE
(
"%p, %p
\n
"
,
request
,
status
);
if
(
!
status
)
return
E_INVALIDARG
;
if
(
request
->
state
<
REQUEST_STATE_SENT
)
{
return
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
);
...
...
@@ -2692,6 +2693,7 @@ static HRESULT WINAPI winhttp_request_get_StatusText(
TRACE
(
"%p, %p
\n
"
,
request
,
status
);
if
(
!
status
)
return
E_INVALIDARG
;
if
(
request
->
state
<
REQUEST_STATE_SENT
)
{
return
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
);
...
...
@@ -2808,6 +2810,11 @@ static HRESULT WINAPI winhttp_request_get_ResponseText(
TRACE
(
"%p, %p
\n
"
,
request
,
body
);
if
(
!
body
)
return
E_INVALIDARG
;
if
(
request
->
state
<
REQUEST_STATE_SENT
)
{
return
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
);
}
if
((
err
=
request_read_body
(
request
,
INFINITE
)))
return
HRESULT_FROM_WIN32
(
err
);
if
((
err
=
request_get_codepage
(
request
,
&
codepage
)))
return
HRESULT_FROM_WIN32
(
err
);
...
...
@@ -2830,6 +2837,7 @@ static HRESULT WINAPI winhttp_request_get_ResponseBody(
TRACE
(
"%p, %p
\n
"
,
request
,
body
);
if
(
!
body
)
return
E_INVALIDARG
;
if
((
err
=
request_read_body
(
request
,
INFINITE
)))
return
HRESULT_FROM_WIN32
(
err
);
if
(
!
(
sa
=
SafeArrayCreateVector
(
VT_UI1
,
0
,
request
->
offset
)))
return
E_OUTOFMEMORY
;
...
...
dlls/winhttp/tests/winhttp.c
View file @
36389080
...
...
@@ -2114,7 +2114,7 @@ static void test_IWinHttpRequest(void)
static
const
WCHAR
bypas_listW
[]
=
{
'b'
,
'y'
,
'p'
,
'a'
,
's'
,
's'
,
'l'
,
'i'
,
's'
,
't'
,
0
};
HRESULT
hr
;
IWinHttpRequest
*
req
;
BSTR
method
,
url
,
username
,
password
,
response
=
NULL
,
status_text
=
NULL
;
BSTR
method
,
url
,
username
,
password
,
response
=
NULL
,
status_text
=
NULL
,
headers
=
NULL
;
VARIANT
async
,
empty
,
timeout
,
body
,
proxy_server
,
bypass_list
;
VARIANT_BOOL
succeeded
;
LONG
status
;
...
...
@@ -2126,6 +2126,9 @@ static void test_IWinHttpRequest(void)
VariantInit
(
&
empty
);
V_VT
(
&
empty
)
=
VT_ERROR
;
V_VT
(
&
async
)
=
VT_BOOL
;
V_BOOL
(
&
async
)
=
VARIANT_FALSE
;
hr
=
IWinHttpRequest_Open
(
req
,
NULL
,
NULL
,
empty
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
...
...
@@ -2133,6 +2136,9 @@ static void test_IWinHttpRequest(void)
hr
=
IWinHttpRequest_Open
(
req
,
method
,
NULL
,
empty
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_Open
(
req
,
method
,
NULL
,
async
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
url
=
SysAllocString
(
url1W
);
hr
=
IWinHttpRequest_Open
(
req
,
NULL
,
url
,
empty
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
...
...
@@ -2152,10 +2158,6 @@ static void test_IWinHttpRequest(void)
hr
=
CoCreateInstance
(
&
CLSID_WinHttpRequest
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IWinHttpRequest
,
(
void
**
)
&
req
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
VariantInit
(
&
async
);
V_VT
(
&
async
)
=
VT_BOOL
;
V_BOOL
(
&
async
)
=
VARIANT_FALSE
;
SysFreeString
(
url
);
url
=
SysAllocString
(
url2W
);
hr
=
IWinHttpRequest_Open
(
req
,
method
,
url
,
async
);
...
...
@@ -2188,12 +2190,27 @@ static void test_IWinHttpRequest(void)
hr
=
CoCreateInstance
(
&
CLSID_WinHttpRequest
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IWinHttpRequest
,
(
void
**
)
&
req
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
&
response
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_Status
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_Status
(
req
,
&
status
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_StatusText
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_StatusText
(
req
,
&
status_text
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseBody
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_SetTimeouts
(
req
,
10000
,
10000
,
10000
,
10000
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
...
...
@@ -2213,6 +2230,12 @@ static void test_IWinHttpRequest(void)
hr
=
IWinHttpRequest_SetProxy
(
req
,
HTTPREQUEST_PROXYSETTING_DIRECT
,
proxy_server
,
bypass_list
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_GetAllResponseHeaders
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_GetAllResponseHeaders
(
req
,
&
headers
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
SysFreeString
(
method
);
method
=
SysAllocString
(
method1W
);
SysFreeString
(
url
);
...
...
@@ -2220,12 +2243,21 @@ static void test_IWinHttpRequest(void)
hr
=
IWinHttpRequest_Open
(
req
,
method
,
url
,
async
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
&
response
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_Status
(
req
,
&
status
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_StatusText
(
req
,
&
status_text
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseBody
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_SetTimeouts
(
req
,
10000
,
10000
,
10000
,
10000
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
...
...
@@ -2237,9 +2269,15 @@ static void test_IWinHttpRequest(void)
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
password
=
SysAllocString
(
passwordW
);
hr
=
IWinHttpRequest_SetCredentials
(
req
,
NULL
,
password
,
0xdeadbeef
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_SetCredentials
(
req
,
username
,
password
,
0xdeadbeef
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_SetCredentials
(
req
,
NULL
,
password
,
HTTPREQUEST_SETCREDENTIALS_FOR_SERVER
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_SetCredentials
(
req
,
username
,
password
,
HTTPREQUEST_SETCREDENTIALS_FOR_SERVER
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
...
...
@@ -2256,22 +2294,41 @@ static void test_IWinHttpRequest(void)
hr
=
IWinHttpRequest_SetProxy
(
req
,
HTTPREQUEST_PROXYSETTING_DIRECT
,
proxy_server
,
bypass_list
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_GetAllResponseHeaders
(
req
,
&
headers
);
ok
(
hr
==
HRESULT_FROM_WIN32
(
ERROR_WINHTTP_CANNOT_CALL_BEFORE_SEND
),
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_Send
(
req
,
empty
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_Send
(
req
,
empty
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
&
response
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
SysFreeString
(
response
);
hr
=
IWinHttpRequest_get_Status
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
status
=
0
;
hr
=
IWinHttpRequest_get_Status
(
req
,
&
status
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
trace
(
"%d
\n
"
,
status
);
hr
=
IWinHttpRequest_get_StatusText
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_StatusText
(
req
,
&
status_text
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
trace
(
"%s
\n
"
,
wine_dbgstr_w
(
status_text
));
SysFreeString
(
status_text
);
hr
=
IWinHttpRequest_get_ResponseBody
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_SetCredentials
(
req
,
username
,
password
,
HTTPREQUEST_SETCREDENTIALS_FOR_SERVER
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
...
...
@@ -2281,6 +2338,13 @@ static void test_IWinHttpRequest(void)
hr
=
IWinHttpRequest_SetProxy
(
req
,
HTTPREQUEST_PROXYSETTING_DIRECT
,
proxy_server
,
bypass_list
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_GetAllResponseHeaders
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_GetAllResponseHeaders
(
req
,
&
headers
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
SysFreeString
(
headers
);
VariantInit
(
&
timeout
);
V_VT
(
&
timeout
)
=
VT_I4
;
V_I4
(
&
timeout
)
=
10
;
...
...
@@ -2306,10 +2370,16 @@ static void test_IWinHttpRequest(void)
hr
=
IWinHttpRequest_Send
(
req
,
empty
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_get_ResponseText
(
req
,
&
response
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
SysFreeString
(
response
);
hr
=
IWinHttpRequest_get_ResponseBody
(
req
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"got %08x
\n
"
,
hr
);
VariantInit
(
&
body
);
V_VT
(
&
body
)
=
VT_ERROR
;
hr
=
IWinHttpRequest_get_ResponseBody
(
req
,
&
body
);
...
...
@@ -2325,6 +2395,10 @@ static void test_IWinHttpRequest(void)
hr
=
IWinHttpRequest_SetProxy
(
req
,
HTTPREQUEST_PROXYSETTING_DIRECT
,
proxy_server
,
bypass_list
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
hr
=
IWinHttpRequest_GetAllResponseHeaders
(
req
,
&
headers
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
SysFreeString
(
headers
);
hr
=
IWinHttpRequest_Send
(
req
,
empty
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
...
...
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