Commit 72c8b283 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

urlmon: Added IInternetProtocolEx support to http protocol handler.

parent 8205f627
...@@ -2149,6 +2149,7 @@ static IClassFactory mimefilter_cf = { &MimeFilterCFVtbl }; ...@@ -2149,6 +2149,7 @@ static IClassFactory mimefilter_cf = { &MimeFilterCFVtbl };
#define TEST_REDIRECT 0x0080 #define TEST_REDIRECT 0x0080
#define TEST_ABORT 0x0100 #define TEST_ABORT 0x0100
#define TEST_ASYNCREQ 0x0200 #define TEST_ASYNCREQ 0x0200
#define TEST_USEIURI 0x0400
static void init_test(int prot, DWORD flags) static void init_test(int prot, DWORD flags)
{ {
...@@ -2565,11 +2566,17 @@ static void test_file_protocol(void) { ...@@ -2565,11 +2566,17 @@ static void test_file_protocol(void) {
test_file_protocol_fail(); test_file_protocol_fail();
} }
static BOOL http_protocol_start(LPCWSTR url) static BOOL http_protocol_start(LPCWSTR url, BOOL use_iuri)
{ {
static BOOL got_user_agent = FALSE; static BOOL got_user_agent = FALSE;
IUri *uri = NULL;
HRESULT hres; HRESULT hres;
if(use_iuri && pCreateUri) {
hres = pCreateUri(url, 0, 0, &uri);
ok(hres == S_OK, "CreateUri failed: %08x\n", hres);
}
SET_EXPECT(GetBindInfo); SET_EXPECT(GetBindInfo);
if (!(bindf & BINDF_FROMURLMON)) if (!(bindf & BINDF_FROMURLMON))
SET_EXPECT(ReportProgress_DIRECTBIND); SET_EXPECT(ReportProgress_DIRECTBIND);
...@@ -2585,8 +2592,21 @@ static BOOL http_protocol_start(LPCWSTR url) ...@@ -2585,8 +2592,21 @@ static BOOL http_protocol_start(LPCWSTR url)
SET_EXPECT(Stream_Seek); SET_EXPECT(Stream_Seek);
} }
hres = IInternetProtocol_Start(async_protocol, url, &protocol_sink, &bind_info, 0, 0); if(uri) {
ok(hres == S_OK, "Start failed: %08x\n", hres); IInternetProtocolEx *protocolex;
hres = IInternetProtocol_QueryInterface(async_protocol, &IID_IInternetProtocolEx, (void**)&protocolex);
ok(hres == S_OK, "Could not get IInternetProtocolEx iface: %08x\n", hres);
hres = IInternetProtocolEx_StartEx(protocolex, uri, &protocol_sink, &bind_info, 0, 0);
ok(hres == S_OK, "Start failed: %08x\n", hres);
IInternetProtocolEx_Release(protocolex);
IUri_Release(uri);
}else {
hres = IInternetProtocol_Start(async_protocol, url, &protocol_sink, &bind_info, 0, 0);
ok(hres == S_OK, "Start failed: %08x\n", hres);
}
if(FAILED(hres)) if(FAILED(hres))
return FALSE; return FALSE;
...@@ -2714,7 +2734,7 @@ static void test_http_protocol_url(LPCWSTR url, int prot, DWORD flags, DWORD tym ...@@ -2714,7 +2734,7 @@ static void test_http_protocol_url(LPCWSTR url, int prot, DWORD flags, DWORD tym
SET_EXPECT(Switch); SET_EXPECT(Switch);
} }
if(!http_protocol_start(url)) if(!http_protocol_start(url, (flags & TEST_USEIURI) != 0))
return; return;
if(!direct_read && !test_abort) if(!direct_read && !test_abort)
...@@ -2837,7 +2857,7 @@ static void test_http_protocol(void) ...@@ -2837,7 +2857,7 @@ static void test_http_protocol(void)
trace("Testing http protocol (direct read)...\n"); trace("Testing http protocol (direct read)...\n");
bindf = BINDF_ASYNCHRONOUS | BINDF_ASYNCSTORAGE | BINDF_PULLDATA | BINDF_FROMURLMON; bindf = BINDF_ASYNCHRONOUS | BINDF_ASYNCSTORAGE | BINDF_PULLDATA | BINDF_FROMURLMON;
test_http_protocol_url(winehq_url, HTTP_TEST, TEST_DIRECT_READ, TYMED_NULL); test_http_protocol_url(winehq_url, HTTP_TEST, TEST_DIRECT_READ|TEST_USEIURI, TYMED_NULL);
trace("Testing http protocol (redirected)...\n"); trace("Testing http protocol (redirected)...\n");
bindf = BINDF_ASYNCHRONOUS | BINDF_ASYNCSTORAGE | BINDF_PULLDATA | BINDF_FROMURLMON; bindf = BINDF_ASYNCHRONOUS | BINDF_ASYNCSTORAGE | BINDF_PULLDATA | BINDF_FROMURLMON;
...@@ -3376,6 +3396,9 @@ START_TEST(protocol) ...@@ -3376,6 +3396,9 @@ START_TEST(protocol)
return; return;
} }
if(!pCreateUri)
win_skip("CreateUri not supported\n");
OleInitialize(NULL); OleInitialize(NULL);
event_complete = CreateEvent(NULL, FALSE, FALSE, NULL); event_complete = CreateEvent(NULL, FALSE, FALSE, NULL);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment