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
aa1d0322
Commit
aa1d0322
authored
Mar 04, 2009
by
Jacek Caban
Committed by
Alexandre Julliard
Mar 05, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
urlmon: Added ftp protocol tests.
parent
3e84960c
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
157 additions
and
36 deletions
+157
-36
protocol.c
dlls/urlmon/tests/protocol.c
+157
-36
No files found.
dlls/urlmon/tests/protocol.c
View file @
aa1d0322
...
...
@@ -110,7 +110,7 @@ static const WCHAR emptyW[] = {0};
static
HRESULT
expect_hrResult
;
static
LPCWSTR
file_name
,
http_url
,
expect_wsz
;
static
IInternetProtocol
*
http
_protocol
=
NULL
;
static
IInternetProtocol
*
async
_protocol
=
NULL
;
static
BOOL
first_data_notif
=
FALSE
,
http_is_first
=
FALSE
,
http_post_test
=
FALSE
;
static
int
state
=
0
,
prot_state
;
...
...
@@ -128,6 +128,7 @@ static enum {
FILE_TEST
,
HTTP_TEST
,
HTTPS_TEST
,
FTP_TEST
,
MK_TEST
,
BIND_TEST
}
tested_protocol
;
...
...
@@ -135,13 +136,20 @@ static enum {
static
const
WCHAR
protocol_names
[][
10
]
=
{
{
'f'
,
'i'
,
'l'
,
'e'
,
0
},
{
'h'
,
't'
,
't'
,
'p'
,
0
},
{
'h'
,
't'
,
't'
,
'p'
,
's'
,
0
},
{
'f'
,
't'
,
'p'
,
0
},
{
'm'
,
'k'
,
0
},
{
't'
,
'e'
,
's'
,
't'
,
0
}
};
static
const
WCHAR
binding_urls
[][
30
]
=
{
static
const
WCHAR
binding_urls
[][
1
30
]
=
{
{
'f'
,
'i'
,
'l'
,
'e'
,
':'
,
't'
,
'e'
,
's'
,
't'
,
'.'
,
'h'
,
't'
,
'm'
,
'l'
,
0
},
{
'h'
,
't'
,
't'
,
'p'
,
':'
,
'/'
,
'/'
,
't'
,
'e'
,
's'
,
't'
,
'/'
,
't'
,
'e'
,
's'
,
't'
,
'.'
,
'h'
,
't'
,
'm'
,
'l'
,
0
},
{
'h'
,
't'
,
't'
,
'p'
,
's'
,
':'
,
'/'
,
'/'
,
'w'
,
'w'
,
'w'
,
'.'
,
'c'
,
'o'
,
'd'
,
'e'
,
'w'
,
'e'
,
'a'
,
'v'
,
'e'
,
'r'
,
's'
,
'.'
,
'c'
,
'o'
,
'm'
,
'/'
,
't'
,
'e'
,
's'
,
't'
,
'.'
,
'h'
,
't'
,
'm'
,
'l'
,
0
},
{
'f'
,
't'
,
'p'
,
':'
,
'/'
,
'/'
,
'f'
,
't'
,
'p'
,
'.'
,
'w'
,
'i'
,
'n'
,
'e'
,
'h'
,
'q'
,
'.'
,
'o'
,
'r'
,
'g'
,
'/'
,
'p'
,
'u'
,
'b'
,
'/'
,
'o'
,
't'
,
'h'
,
'e'
,
'r'
,
'/'
,
'w'
,
'i'
,
'n'
,
'e'
,
'l'
,
'o'
,
'g'
,
'o'
,
'.'
,
'x'
,
'c'
,
'f'
,
'.'
,
't'
,
'a'
,
'r'
,
'.'
,
'b'
,
'z'
,
'2'
,
0
},
{
'm'
,
'k'
,
':'
,
't'
,
'e'
,
's'
,
't'
,
0
},
{
't'
,
'e'
,
's'
,
't'
,
':'
,
'/'
,
'/'
,
'f'
,
'i'
,
'l'
,
'e'
,
'.'
,
'h'
,
't'
,
'm'
,
'l'
,
0
}
};
...
...
@@ -356,6 +364,7 @@ static HRESULT WINAPI ProtocolSink_Switch(IInternetProtocolSink *iface, PROTOCOL
}
if
(
!
state
)
{
if
(
tested_protocol
==
HTTP_TEST
||
tested_protocol
==
HTTPS_TEST
||
tested_protocol
==
FTP_TEST
)
{
if
(
http_is_first
)
{
CLEAR_CALLED
(
ReportProgress_FINDINGRESOURCE
);
CLEAR_CALLED
(
ReportProgress_CONNECTING
);
...
...
@@ -365,7 +374,12 @@ static HRESULT WINAPI ProtocolSink_Switch(IInternetProtocolSink *iface, PROTOCOL
/* IE7 does call this */
CLEAR_CALLED
(
ReportProgress_CONNECTING
);
}
}
if
(
tested_protocol
==
FTP_TEST
)
todo_wine
CHECK_CALLED
(
ReportProgress_SENDINGREQUEST
);
else
CHECK_CALLED
(
ReportProgress_SENDINGREQUEST
);
if
(
tested_protocol
==
HTTP_TEST
||
tested_protocol
==
HTTPS_TEST
)
{
SET_EXPECT
(
OnResponse
);
if
(
tested_protocol
==
HTTPS_TEST
)
SET_EXPECT
(
ReportProgress_ACCEPTRANGES
);
...
...
@@ -373,14 +387,19 @@ static HRESULT WINAPI ProtocolSink_Switch(IInternetProtocolSink *iface, PROTOCOL
if
(
bindf
&
BINDF_NEEDFILE
)
SET_EXPECT
(
ReportProgress_CACHEFILENAMEAVAILABLE
);
}
}
SET_EXPECT
(
ReportData
);
hres
=
IInternetProtocol_Continue
(
http
_protocol
,
pProtocolData
);
hres
=
IInternetProtocol_Continue
(
async
_protocol
,
pProtocolData
);
ok
(
hres
==
S_OK
,
"Continue failed: %08x
\n
"
,
hres
);
if
(
tested_protocol
==
FTP_TEST
)
CLEAR_CALLED
(
ReportData
);
else
CHECK_CALLED
(
ReportData
);
if
(
!
state
)
{
state
=
1
;
if
(
tested_protocol
==
HTTP_TEST
||
tested_protocol
==
HTTPS_TEST
)
{
CHECK_CALLED
(
OnResponse
);
if
(
tested_protocol
==
HTTPS_TEST
)
CHECK_CALLED
(
ReportProgress_ACCEPTRANGES
);
...
...
@@ -388,6 +407,7 @@ static HRESULT WINAPI ProtocolSink_Switch(IInternetProtocolSink *iface, PROTOCOL
if
(
bindf
&
BINDF_NEEDFILE
)
CHECK_CALLED
(
ReportProgress_CACHEFILENAMEAVAILABLE
);
}
}
SetEvent
(
event_complete
);
...
...
@@ -451,7 +471,7 @@ static HRESULT WINAPI ProtocolSink_ReportProgress(IInternetProtocolSink *iface,
ok
(
szStatusText
!=
NULL
,
"szStatusText == NULL
\n
"
);
break
;
case
BINDSTATUS_SENDINGREQUEST
:
CHECK_EXPECT
(
ReportProgress_SENDINGREQUEST
);
CHECK_EXPECT
2
(
ReportProgress_SENDINGREQUEST
);
if
(
tested_protocol
==
FILE_TEST
)
{
ok
(
szStatusText
!=
NULL
,
"szStatusText == NULL
\n
"
);
if
(
szStatusText
)
...
...
@@ -508,7 +528,7 @@ static HRESULT WINAPI ProtocolSink_ReportData(IInternetProtocolSink *iface, DWOR
ok
(
ulProgressMax
==
13
,
"ulProgressMax=%d, expected 13
\n
"
,
ulProgressMax
);
ok
(
grfBSCF
==
(
BSCF_FIRSTDATANOTIFICATION
|
BSCF_LASTDATANOTIFICATION
),
"grcfBSCF = %08x
\n
"
,
grfBSCF
);
}
else
if
(
!
binding_test
&&
(
tested_protocol
==
HTTP_TEST
||
tested_protocol
==
HTTPS_TEST
))
{
}
else
if
(
!
binding_test
&&
(
tested_protocol
==
HTTP_TEST
||
tested_protocol
==
HTTPS_TEST
||
tested_protocol
==
FTP_TEST
))
{
if
(
!
(
grfBSCF
&
BSCF_LASTDATANOTIFICATION
)
||
(
grfBSCF
&
BSCF_DATAFULLYAVAILABLE
))
CHECK_EXPECT
(
ReportData
);
else
if
(
http_post_test
)
...
...
@@ -570,9 +590,12 @@ static HRESULT WINAPI ProtocolSink_ReportResult(IInternetProtocolSink *iface, HR
{
CHECK_EXPECT
(
ReportResult
);
if
(
tested_protocol
==
FTP_TEST
)
ok
(
hrResult
==
E_PENDING
||
hrResult
==
S_OK
,
"hrResult = %08x, expected E_PENDING or S_OK
\n
"
,
hrResult
);
else
ok
(
hrResult
==
expect_hrResult
,
"hrResult = %08x, expected: %08x
\n
"
,
hrResult
,
expect_hrResult
);
if
(
SUCCEEDED
(
hrResult
))
if
(
SUCCEEDED
(
hrResult
)
||
tested_protocol
==
FTP_TEST
)
ok
(
dwError
==
ERROR_SUCCESS
,
"dwError = %d, expected ERROR_SUCCESS
\n
"
,
dwError
);
else
ok
(
dwError
!=
ERROR_SUCCESS
,
"dwError == ERROR_SUCCESS
\n
"
);
...
...
@@ -1529,7 +1552,7 @@ static BOOL http_protocol_start(LPCWSTR url, BOOL is_first)
if
(
http_post_test
)
SET_EXPECT
(
GetBindString_POST_COOKIE
);
hres
=
IInternetProtocol_Start
(
http
_protocol
,
url
,
&
protocol_sink
,
&
bind_info
,
0
,
0
);
hres
=
IInternetProtocol_Start
(
async
_protocol
,
url
,
&
protocol_sink
,
&
bind_info
,
0
,
0
);
ok
(
hres
==
S_OK
,
"Start failed: %08x
\n
"
,
hres
);
if
(
FAILED
(
hres
))
return
FALSE
;
...
...
@@ -1558,6 +1581,35 @@ static BOOL http_protocol_start(LPCWSTR url, BOOL is_first)
return
TRUE
;
}
static
void
test_protocol_terminate
(
IInternetProtocol
*
protocol
)
{
BYTE
buf
[
3600
];
DWORD
cb
;
HRESULT
hres
;
hres
=
IInternetProtocol_LockRequest
(
protocol
,
0
);
ok
(
hres
==
S_OK
,
"LockRequest failed: %08x
\n
"
,
hres
);
hres
=
IInternetProtocol_Read
(
protocol
,
buf
,
1
,
&
cb
);
ok
(
hres
==
S_FALSE
,
"Read failed: %08x
\n
"
,
hres
);
hres
=
IInternetProtocol_Terminate
(
protocol
,
0
);
ok
(
hres
==
S_OK
,
"Terminate failed: %08x
\n
"
,
hres
);
/* This wait is to give the internet handles being freed in Terminate
* enough time to actually terminate in all cases. Internet handles
* terminate asynchronously and native reuses the main InternetOpen
* handle. The only case in which this seems to be necessary is on
* wine with native wininet and urlmon, resulting in the next time
* test_http_protocol_url being called the first data notification actually
* being an extra last data notification from the previous connection
* about once out of every ten times. */
Sleep
(
100
);
hres
=
IInternetProtocol_UnlockRequest
(
protocol
);
ok
(
hres
==
S_OK
,
"UnlockRequest failed: %08x
\n
"
,
hres
);
}
/* is_first refers to whether this is the first call to this function
* _for this url_ */
static
void
test_http_protocol_url
(
LPCWSTR
url
,
BOOL
is_https
,
BOOL
is_first
)
...
...
@@ -1588,13 +1640,14 @@ static void test_http_protocol_url(LPCWSTR url, BOOL is_https, BOOL is_first)
return
;
hres
=
IClassFactory_CreateInstance
(
factory
,
NULL
,
&
IID_IInternetProtocol
,
(
void
**
)
&
http
_protocol
);
(
void
**
)
&
async
_protocol
);
ok
(
hres
==
S_OK
,
"Could not get IInternetProtocol: %08x
\n
"
,
hres
);
if
(
SUCCEEDED
(
hres
))
{
BYTE
buf
[
3600
];
DWORD
cb
;
ULONG
ref
;
test_priority
(
http
_protocol
);
test_priority
(
async
_protocol
);
SET_EXPECT
(
ReportProgress_FINDINGRESOURCE
);
SET_EXPECT
(
ReportProgress_CONNECTING
);
...
...
@@ -1616,7 +1669,7 @@ static void test_http_protocol_url(LPCWSTR url, BOOL is_https, BOOL is_first)
SET_EXPECT
(
ReportResult
);
expect_hrResult
=
S_OK
;
hres
=
IInternetProtocol_Read
(
http
_protocol
,
buf
,
1
,
&
cb
);
hres
=
IInternetProtocol_Read
(
async
_protocol
,
buf
,
1
,
&
cb
);
ok
((
hres
==
E_PENDING
&&
cb
==
0
)
||
(
hres
==
S_OK
&&
cb
==
1
),
"Read failed: %08x (%d bytes)
\n
"
,
hres
,
cb
);
...
...
@@ -1631,9 +1684,9 @@ static void test_http_protocol_url(LPCWSTR url, BOOL is_https, BOOL is_first)
SET_EXPECT
(
Switch
);
else
SET_EXPECT
(
ReportData
);
hres
=
IInternetProtocol_Read
(
http
_protocol
,
buf
,
sizeof
(
buf
),
&
cb
);
hres
=
IInternetProtocol_Read
(
async
_protocol
,
buf
,
sizeof
(
buf
),
&
cb
);
if
(
hres
==
E_PENDING
)
{
hres
=
IInternetProtocol_Read
(
http
_protocol
,
buf
,
1
,
&
cb
);
hres
=
IInternetProtocol_Read
(
async
_protocol
,
buf
,
1
,
&
cb
);
ok
((
hres
==
E_PENDING
&&
cb
==
0
)
||
(
hres
==
S_OK
&&
cb
==
1
),
"Read failed: %08x (%d bytes)
\n
"
,
hres
,
cb
);
WaitForSingleObject
(
event_complete
,
INFINITE
);
...
...
@@ -1641,7 +1694,7 @@ static void test_http_protocol_url(LPCWSTR url, BOOL is_https, BOOL is_first)
CHECK_CALLED
(
Switch
);
else
CHECK_CALLED
(
ReportData
);
}
else
{
}
else
{
if
(
bindf
&
BINDF_FROMURLMON
)
CHECK_NOT_CALLED
(
Switch
);
else
...
...
@@ -1652,29 +1705,9 @@ static void test_http_protocol_url(LPCWSTR url, BOOL is_https, BOOL is_first)
ok
(
hres
==
S_FALSE
,
"Read failed: %08x
\n
"
,
hres
);
CHECK_CALLED
(
ReportResult
);
hres
=
IInternetProtocol_LockRequest
(
http_protocol
,
0
);
ok
(
hres
==
S_OK
,
"LockRequest failed: %08x
\n
"
,
hres
);
hres
=
IInternetProtocol_Read
(
http_protocol
,
buf
,
1
,
&
cb
);
ok
(
hres
==
S_FALSE
,
"Read failed: %08x
\n
"
,
hres
);
hres
=
IInternetProtocol_Terminate
(
http_protocol
,
0
);
ok
(
hres
==
S_OK
,
"Terminate failed: %08x
\n
"
,
hres
);
/* This wait is to give the internet handles being freed in Terminate
* enough time to actually terminate in all cases. Internet handles
* terminate asynchronously and native reuses the main InternetOpen
* handle. The only case in which this seems to be necessary is on
* wine with native wininet and urlmon, resulting in the next time
* test_http_protocol_url being called the first data notification actually
* being an extra last data notification from the previous connection
* about once out of every ten times. */
Sleep
(
100
);
hres
=
IInternetProtocol_UnlockRequest
(
http_protocol
);
ok
(
hres
==
S_OK
,
"UnlockRequest failed: %08x
\n
"
,
hres
);
IInternetProtocol_Release
(
http_protocol
);
test_protocol_terminate
(
async_protocol
);
ref
=
IInternetProtocol_Release
(
async_protocol
);
ok
(
!
ref
,
"ref=%x
\n
"
,
hres
);
}
IClassFactory_Release
(
factory
);
...
...
@@ -1724,6 +1757,93 @@ static void test_https_protocol(void)
test_http_protocol_url
(
codeweavers_url
,
TRUE
,
TRUE
);
}
static
void
test_ftp_protocol
(
void
)
{
IInternetProtocolInfo
*
protocol_info
;
IClassFactory
*
factory
;
IUnknown
*
unk
;
BYTE
buf
[
4096
];
ULONG
ref
;
DWORD
cb
;
HRESULT
hres
;
static
const
WCHAR
ftp_urlW
[]
=
{
'f'
,
't'
,
'p'
,
':'
,
'/'
,
'/'
,
'f'
,
't'
,
'p'
,
'.'
,
'w'
,
'i'
,
'n'
,
'e'
,
'h'
,
'q'
,
'.'
,
'o'
,
'r'
,
'g'
,
'/'
,
'p'
,
'u'
,
'b'
,
'/'
,
'o'
,
't'
,
'h'
,
'e'
,
'r'
,
'/'
,
'w'
,
'i'
,
'n'
,
'e'
,
'l'
,
'o'
,
'g'
,
'o'
,
'.'
,
'x'
,
'c'
,
'f'
,
'.'
,
't'
,
'a'
,
'r'
,
'.'
,
'b'
,
'z'
,
'2'
,
0
};
trace
(
"Testing ftp protocol...
\n
"
);
bindf
=
BINDF_ASYNCHRONOUS
|
BINDF_ASYNCSTORAGE
|
BINDF_PULLDATA
|
BINDF_FROMURLMON
|
BINDF_NOWRITECACHE
;
state
=
0
;
tested_protocol
=
FTP_TEST
;
first_data_notif
=
TRUE
;
expect_hrResult
=
E_PENDING
;
hres
=
CoGetClassObject
(
&
CLSID_FtpProtocol
,
CLSCTX_INPROC_SERVER
,
NULL
,
&
IID_IUnknown
,
(
void
**
)
&
unk
);
ok
(
hres
==
S_OK
,
"CoGetClassObject failed: %08x
\n
"
,
hres
);
if
(
FAILED
(
hres
))
return
;
hres
=
IUnknown_QueryInterface
(
unk
,
&
IID_IInternetProtocolInfo
,
(
void
**
)
&
protocol_info
);
ok
(
hres
==
E_NOINTERFACE
,
"Could not get IInternetProtocolInfo interface: %08x, expected E_NOINTERFACE
\n
"
,
hres
);
hres
=
IUnknown_QueryInterface
(
unk
,
&
IID_IClassFactory
,
(
void
**
)
&
factory
);
ok
(
hres
==
S_OK
,
"Could not get IClassFactory interface
\n
"
);
IUnknown_Release
(
unk
);
if
(
FAILED
(
hres
))
return
;
hres
=
IClassFactory_CreateInstance
(
factory
,
NULL
,
&
IID_IInternetProtocol
,
(
void
**
)
&
async_protocol
);
IClassFactory_Release
(
factory
);
ok
(
hres
==
S_OK
,
"Could not get IInternetProtocol: %08x
\n
"
,
hres
);
test_priority
(
async_protocol
);
SET_EXPECT
(
GetBindInfo
);
SET_EXPECT
(
GetBindString_USER_AGENT
);
SET_EXPECT
(
ReportProgress_FINDINGRESOURCE
);
SET_EXPECT
(
ReportProgress_CONNECTING
);
SET_EXPECT
(
ReportProgress_SENDINGREQUEST
);
SET_EXPECT
(
Switch
);
hres
=
IInternetProtocol_Start
(
async_protocol
,
ftp_urlW
,
&
protocol_sink
,
&
bind_info
,
0
,
0
);
ok
(
hres
==
S_OK
,
"Start failed: %08x
\n
"
,
hres
);
CHECK_CALLED
(
GetBindInfo
);
todo_wine
CHECK_NOT_CALLED
(
GetBindString_USER_AGENT
);
SET_EXPECT
(
ReportResult
);
hres
=
IInternetProtocol_Read
(
async_protocol
,
buf
,
1
,
&
cb
);
ok
((
hres
==
E_PENDING
&&
cb
==
0
)
||
(
hres
==
S_OK
&&
cb
==
1
),
"Read failed: %08x (%d bytes)
\n
"
,
hres
,
cb
);
WaitForSingleObject
(
event_complete
,
INFINITE
);
CHECK_CALLED
(
Switch
);
while
(
1
)
{
SET_EXPECT
(
Switch
);
hres
=
IInternetProtocol_Read
(
async_protocol
,
buf
,
sizeof
(
buf
),
&
cb
);
if
(
hres
==
E_PENDING
)
{
WaitForSingleObject
(
event_complete
,
INFINITE
);
CHECK_CALLED
(
Switch
);
}
else
{
CHECK_NOT_CALLED
(
Switch
);
if
(
cb
==
0
)
break
;
}
}
ok
(
hres
==
S_FALSE
,
"Read failed: %08x
\n
"
,
hres
);
CHECK_CALLED
(
ReportResult
);
test_protocol_terminate
(
async_protocol
);
ref
=
IInternetProtocol_Release
(
async_protocol
);
ok
(
!
ref
,
"ref=%d
\n
"
,
ref
);
}
static
void
test_mk_protocol
(
void
)
{
IInternetProtocolInfo
*
protocol_info
;
...
...
@@ -2011,6 +2131,7 @@ START_TEST(protocol)
test_file_protocol
();
test_http_protocol
();
test_https_protocol
();
test_ftp_protocol
();
test_mk_protocol
();
test_CreateBinding
();
test_binding
(
FILE_TEST
);
...
...
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