[URLMON_WINETEST] Sync with Wine Staging 3.3. CORE-14434

This commit is contained in:
Amine Khaldi 2018-03-23 12:35:59 +01:00
parent 143d4fdbd2
commit 7f95c14153
7 changed files with 375 additions and 134 deletions

View file

@ -5,10 +5,6 @@
* Unit tests for data structure packing * Unit tests for data structure packing
*/ */
#define WIN32_NO_STATUS
#define _INC_WINDOWS
#define COM_NO_WINDOWS_H
#ifndef __REACTOS__ #ifndef __REACTOS__
#define WINVER 0x0501 #define WINVER 0x0501
#define _WIN32_IE 0x0501 #define _WIN32_IE 0x0501
@ -18,12 +14,11 @@
#define WINE_NOWINSOCK #define WINE_NOWINSOCK
#include <stdarg.h> #include <stdarg.h>
#include <windef.h> #include "windef.h"
#include <winbase.h> #include "winbase.h"
#include <objbase.h> #include "urlmon.h"
#include <urlmon.h>
#include <wine/test.h> #include "wine/test.h"
/*********************************************************************** /***********************************************************************
* Compatibility macros * Compatibility macros

View file

@ -16,27 +16,22 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#define WIN32_NO_STATUS
#define _INC_WINDOWS
#define COM_NO_WINDOWS_H
#define COBJMACROS #define COBJMACROS
#define CONST_VTABLE #define CONST_VTABLE
#define NONAMELESSUNION #define NONAMELESSUNION
#include <wine/test.h> #include <wine/test.h>
//#include <stdarg.h> #include <stdarg.h>
//#include <stddef.h> #include <stddef.h>
#include <stdio.h> #include <stdio.h>
//#include "windef.h" #include "windef.h"
//#include "winbase.h" #include "winbase.h"
#include <winreg.h> #include "ole2.h"
#include <winnls.h> #include "urlmon.h"
#include <ole2.h>
//#include "urlmon.h"
#include <initguid.h> #include "initguid.h"
#include "wine/heap.h"
DEFINE_GUID(CLSID_AboutProtocol, 0x3050F406, 0x98B5, 0x11CF, 0xBB,0x82, 0x00,0xAA,0x00,0xBD,0xCE,0x0B); DEFINE_GUID(CLSID_AboutProtocol, 0x3050F406, 0x98B5, 0x11CF, 0xBB,0x82, 0x00,0xAA,0x00,0xBD,0xCE,0x0B);
@ -94,11 +89,6 @@ static int strcmp_wa(const WCHAR *strw, const char *stra)
return lstrcmpW(strw, buf); return lstrcmpW(strw, buf);
} }
static void heap_free(void *mem)
{
HeapFree(GetProcessHeap(), 0, mem);
}
static WCHAR *a2w(const char *str) static WCHAR *a2w(const char *str)
{ {
WCHAR *ret; WCHAR *ret;
@ -2342,7 +2332,7 @@ static void test_bsc_marshaling(void)
rem_bindinfo.stgmedData.tymed = TYMED_HGLOBAL; rem_bindinfo.stgmedData.tymed = TYMED_HGLOBAL;
buf = GlobalAlloc(0, sizeof(5)); buf = GlobalAlloc(0, 5);
strcpy(buf, "test"); strcpy(buf, "test");
rem_bindinfo.stgmedData.u.hGlobal = buf; rem_bindinfo.stgmedData.u.hGlobal = buf;
rem_bindinfo.cbstgmedData = 5; rem_bindinfo.cbstgmedData = 5;
@ -2559,7 +2549,7 @@ static void test_bsc_marshaling(void)
rem_bindinfo.stgmedData.tymed = TYMED_HGLOBAL; rem_bindinfo.stgmedData.tymed = TYMED_HGLOBAL;
buf = GlobalAlloc(0, sizeof(5)); buf = GlobalAlloc(0, 5);
strcpy(buf, "test"); strcpy(buf, "test");
rem_bindinfo.stgmedData.u.hGlobal = buf; rem_bindinfo.stgmedData.u.hGlobal = buf;
rem_bindinfo.cbstgmedData = 5; rem_bindinfo.cbstgmedData = 5;

View file

@ -16,23 +16,18 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#define WIN32_NO_STATUS
#define _INC_WINDOWS
#define COM_NO_WINDOWS_H
#define COBJMACROS #define COBJMACROS
#define CONST_VTABLE #define CONST_VTABLE
#include <wine/test.h> #include <wine/test.h>
//#include <stdarg.h> #include <stdarg.h>
#include <stdio.h> #include <stdio.h>
//#include "windef.h" #include "windef.h"
//#include "winbase.h" #include "winbase.h"
#include <winnls.h> #include "ole2.h"
#include <ole2.h> #include "urlmon.h"
#include <urlmon.h> #include "wininet.h"
#include <wininet.h>
static HRESULT (WINAPI *pCoInternetGetSession)(DWORD, IInternetSession **, DWORD); static HRESULT (WINAPI *pCoInternetGetSession)(DWORD, IInternetSession **, DWORD);
static HRESULT (WINAPI *pReleaseBindInfo)(BINDINFO*); static HRESULT (WINAPI *pReleaseBindInfo)(BINDINFO*);
@ -945,6 +940,39 @@ static HRESULT WINAPI ProtocolSink_ReportProgress(IInternetProtocolSink *iface,
return S_OK; return S_OK;
} }
static void test_http_info(IInternetProtocol *protocol)
{
IWinInetHttpInfo *info;
char buf[1024];
DWORD size, len;
HRESULT hres;
static const WCHAR connectionW[] = {'c','o','n','n','e','c','t','i','o','n',0};
hres = IInternetProtocol_QueryInterface(protocol, &IID_IWinInetHttpInfo, (void**)&info);
ok(hres == S_OK, "Could not get IWinInterHttpInfo iface: %08x\n", hres);
size = sizeof(buf);
strcpy(buf, "connection");
hres = IWinInetHttpInfo_QueryInfo(info, HTTP_QUERY_CUSTOM, buf, &size, NULL, NULL);
if(tested_protocol != FTP_TEST) {
ok(hres == S_OK, "QueryInfo failed: %08x\n", hres);
ok(!strcmp(buf, "Keep-Alive"), "buf = %s\n", buf);
len = strlen(buf);
ok(size == len, "size = %u, expected %u\n", size, len);
size = sizeof(buf);
memcpy(buf, connectionW, sizeof(connectionW));
hres = IWinInetHttpInfo_QueryInfo(info, HTTP_QUERY_CUSTOM, buf, &size, NULL, NULL);
ok(hres == S_FALSE, "QueryInfo returned %08x\n", hres);
}else {
ok(hres == S_FALSE, "QueryInfo failed: %08x\n", hres);
}
IWinInetHttpInfo_Release(info);
}
static HRESULT WINAPI ProtocolSink_ReportData(IInternetProtocolSink *iface, DWORD grfBSCF, static HRESULT WINAPI ProtocolSink_ReportData(IInternetProtocolSink *iface, DWORD grfBSCF,
ULONG ulProgress, ULONG ulProgressMax) ULONG ulProgress, ULONG ulProgressMax)
{ {
@ -1076,6 +1104,9 @@ static HRESULT WINAPI ProtocolSink_ReportData(IInternetProtocolSink *iface, DWOR
"grcfBSCF = %08x\n", grfBSCF); "grcfBSCF = %08x\n", grfBSCF);
} }
if((grfBSCF & BSCF_FIRSTDATANOTIFICATION) && !binding_test)
test_http_info(async_protocol);
if(!(bindf & BINDF_FROMURLMON) && if(!(bindf & BINDF_FROMURLMON) &&
!(grfBSCF & BSCF_LASTDATANOTIFICATION)) { !(grfBSCF & BSCF_LASTDATANOTIFICATION)) {
if(state == STATE_CONNECTING) { if(state == STATE_CONNECTING) {
@ -3140,19 +3171,6 @@ static void test_protocol_terminate(IInternetProtocol *protocol)
ok(hres == S_OK, "UnlockRequest failed: %08x\n", hres); ok(hres == S_OK, "UnlockRequest failed: %08x\n", hres);
} }
static void test_http_info(IInternetProtocol *protocol)
{
IWinInetHttpInfo *info;
HRESULT hres;
hres = IInternetProtocol_QueryInterface(protocol, &IID_IWinInetHttpInfo, (void**)&info);
ok(hres == S_OK, "Could not get IWinInterHttpInfo iface: %08x\n", hres);
/* TODO */
IWinInetHttpInfo_Release(info);
}
/* is_first refers to whether this is the first call to this function /* is_first refers to whether this is the first call to this function
* _for this url_ */ * _for this url_ */
static void test_http_protocol_url(LPCWSTR url, int prot, DWORD flags, DWORD tymed) static void test_http_protocol_url(LPCWSTR url, int prot, DWORD flags, DWORD tymed)
@ -3194,7 +3212,6 @@ static void test_http_protocol_url(LPCWSTR url, int prot, DWORD flags, DWORD tym
ULONG ref; ULONG ref;
test_priority(async_protocol); test_priority(async_protocol);
test_http_info(async_protocol);
SET_EXPECT(ReportProgress_COOKIE_SENT); SET_EXPECT(ReportProgress_COOKIE_SENT);
if(http_is_first) { if(http_is_first) {
@ -3463,7 +3480,6 @@ static void test_ftp_protocol(void)
ok(hres == S_OK, "Could not get IInternetProtocol: %08x\n", hres); ok(hres == S_OK, "Could not get IInternetProtocol: %08x\n", hres);
test_priority(async_protocol); test_priority(async_protocol);
test_http_info(async_protocol);
SET_EXPECT(GetBindInfo); SET_EXPECT(GetBindInfo);
SET_EXPECT(ReportProgress_FINDINGRESOURCE); SET_EXPECT(ReportProgress_FINDINGRESOURCE);

View file

@ -18,31 +18,27 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#define WIN32_NO_STATUS
#define _INC_WINDOWS
#define COM_NO_WINDOWS_H
#define COBJMACROS #define COBJMACROS
#define CONST_VTABLE #define CONST_VTABLE
#define NONAMELESSUNION
/* needed for IInternetZoneManagerEx2 */ /* needed for IInternetZoneManagerEx2 */
#ifdef __REACTOS__
#undef _WIN32_IE #undef _WIN32_IE
#endif
#define _WIN32_IE 0x0700 #define _WIN32_IE 0x0700
#include <wine/test.h> #include <wine/test.h>
//#include <stdarg.h> #include <stdarg.h>
//#include <stddef.h> #include <stddef.h>
#include <stdio.h> #include <stdio.h>
//#include "windef.h" #include "windef.h"
//#include "winbase.h" #include "winbase.h"
#include <winreg.h> #include "ole2.h"
#include <winnls.h> #include "urlmon.h"
#include <ole2.h>
//#include "urlmon.h"
//#include "initguid.h" #include "initguid.h"
#include <wine/heap.h>
#define URLZONE_CUSTOM URLZONE_USER_MIN+1 #define URLZONE_CUSTOM URLZONE_USER_MIN+1
#define URLZONE_CUSTOM2 URLZONE_CUSTOM+1 #define URLZONE_CUSTOM2 URLZONE_CUSTOM+1
@ -184,11 +180,6 @@ static int strcmp_w(const WCHAR *str1, const WCHAR *str2)
return memcmp(str1, str2, len1*sizeof(WCHAR)); return memcmp(str1, str2, len1*sizeof(WCHAR));
} }
static inline void heap_free(void *mem)
{
HeapFree(GetProcessHeap(), 0, mem);
}
static inline LPWSTR a2w(LPCSTR str) static inline LPWSTR a2w(LPCSTR str)
{ {
LPWSTR ret = NULL; LPWSTR ret = NULL;

View file

@ -16,23 +16,18 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#define WIN32_NO_STATUS
#define _INC_WINDOWS
#define COM_NO_WINDOWS_H
#define COBJMACROS #define COBJMACROS
#define CONST_VTABLE #define CONST_VTABLE
#include <wine/test.h> #include <wine/test.h>
//#include <stdarg.h> #include <stdarg.h>
//#include <stddef.h> #include <stddef.h>
//#include "windef.h" #include "windef.h"
//#include "winbase.h" #include "winbase.h"
#include <winnls.h> #include "ole2.h"
#include <ole2.h> #include "urlmon.h"
//#include "urlmon.h" #include "wininet.h"
#include <wininet.h>
#define DEFINE_EXPECT(func) \ #define DEFINE_EXPECT(func) \
static BOOL expect_ ## func = FALSE, called_ ## func = FALSE static BOOL expect_ ## func = FALSE, called_ ## func = FALSE

View file

@ -18,28 +18,22 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#define WIN32_NO_STATUS
#define _INC_WINDOWS
#define COM_NO_WINDOWS_H
#include <wine/test.h> #include <wine/test.h>
//#include <stdarg.h> #include <stdarg.h>
//#include <stddef.h> #include <stddef.h>
#define COBJMACROS #define COBJMACROS
#define CONST_VTABLE #define CONST_VTABLE
#define WIN32_LEAN_AND_MEAN #define WIN32_LEAN_AND_MEAN
//#include "windef.h" #include "windef.h"
//#include "winbase.h" #include "winbase.h"
#include <winreg.h> #include "urlmon.h"
#include <winnls.h> #include "shlwapi.h"
#include <ole2.h> #include "wininet.h"
//#include "urlmon.h" #include "strsafe.h"
#include <shlwapi.h> #include "initguid.h"
#include <wininet.h> #include <wine/heap.h>
#include <strsafe.h>
#include <initguid.h>
DEFINE_GUID(CLSID_CUri, 0xDF2FCE13, 0x25EC, 0x45BB, 0x9D,0x4C, 0xCE,0xCD,0x47,0xC2,0x43,0x0C); DEFINE_GUID(CLSID_CUri, 0xDF2FCE13, 0x25EC, 0x45BB, 0x9D,0x4C, 0xCE,0xCD,0x47,0xC2,0x43,0x0C);
@ -4805,6 +4799,266 @@ static const uri_properties uri_tests[] = {
{URL_SCHEME_FILE,S_OK,FALSE}, {URL_SCHEME_FILE,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE} {URLZONE_INVALID,E_NOTIMPL,FALSE}
} }
},
/* Path with Unicode characters. Unicode characters should not be encoded */
{/* "http://127.0.0.1/测试/test.txt" with Chinese in UTF-8 encoding */
"http://127.0.0.1/\xE6\xB5\x8B\xE8\xAF\x95/test.txt", 0, S_OK, FALSE,
{
{"http://127.0.0.1/\xE6\xB5\x8B\xE8\xAF\x95/test.txt",S_OK,FALSE},
{"127.0.0.1",S_OK,FALSE},
{"http://127.0.0.1/\xE6\xB5\x8B\xE8\xAF\x95/test.txt",S_OK,FALSE},
{"",S_FALSE,FALSE},
{".txt",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"127.0.0.1",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"/\xE6\xB5\x8B\xE8\xAF\x95/test.txt",S_OK,FALSE},
{"/\xE6\xB5\x8B\xE8\xAF\x95/test.txt",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"http://127.0.0.1/\xE6\xB5\x8B\xE8\xAF\x95/test.txt",S_OK,FALSE},
{"http",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE}
},
{
{Uri_HOST_IPV4,S_OK,FALSE},
{80,S_OK,FALSE},
{URL_SCHEME_HTTP,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
},
{ "file:\xE6\xB5\x8B\xE8\xAF\x95.html", 0, S_OK, FALSE,
{
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"file:\xE6\xB5\x8B\xE8\xAF\x95.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{".html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"\xE6\xB5\x8B\xE8\xAF\x95.html",S_OK,FALSE},
{"\xE6\xB5\x8B\xE8\xAF\x95.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"file:\xE6\xB5\x8B\xE8\xAF\x95.html",S_OK,FALSE},
{"file",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE}
},
{
{Uri_HOST_UNKNOWN,S_OK,FALSE},
{0,S_FALSE,FALSE},
{URL_SCHEME_FILE,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
},
/* Username with Unicode characters. Unicode characters should not be encoded */
{ "ftp://\xE6\xB5\x8B\xE8\xAF\x95:wine@ftp.winehq.org:9999/dir/foobar.txt", 0, S_OK, FALSE,
{
{"ftp://\xE6\xB5\x8B\xE8\xAF\x95:wine@ftp.winehq.org:9999/dir/foobar.txt",S_OK,FALSE},
{"\xE6\xB5\x8B\xE8\xAF\x95:wine@ftp.winehq.org:9999",S_OK,FALSE},
{"ftp://ftp.winehq.org:9999/dir/foobar.txt",S_OK,FALSE},
{"winehq.org",S_OK,FALSE},
{".txt",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"ftp.winehq.org",S_OK,FALSE},
{"wine",S_OK,FALSE},
{"/dir/foobar.txt",S_OK,FALSE},
{"/dir/foobar.txt",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"ftp://\xE6\xB5\x8B\xE8\xAF\x95:wine@ftp.winehq.org:9999/dir/foobar.txt",S_OK,FALSE},
{"ftp",S_OK,FALSE},
{"\xE6\xB5\x8B\xE8\xAF\x95:wine",S_OK,FALSE},
{"\xE6\xB5\x8B\xE8\xAF\x95",S_OK,FALSE}
},
{
{Uri_HOST_DNS,S_OK,FALSE},
{9999,S_OK,FALSE},
{URL_SCHEME_FTP,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
},
/* Password with Unicode characters. Unicode characters should not be encoded */
{ "ftp://winepass:\xE6\xB5\x8B\xE8\xAF\x95@ftp.winehq.org:9999/dir/foobar.txt", 0, S_OK, FALSE,
{
{"ftp://winepass:\xE6\xB5\x8B\xE8\xAF\x95@ftp.winehq.org:9999/dir/foobar.txt",S_OK,FALSE},
{"winepass:\xE6\xB5\x8B\xE8\xAF\x95@ftp.winehq.org:9999",S_OK,FALSE},
{"ftp://ftp.winehq.org:9999/dir/foobar.txt",S_OK,FALSE},
{"winehq.org",S_OK,FALSE},
{".txt",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"ftp.winehq.org",S_OK,FALSE},
{"\xE6\xB5\x8B\xE8\xAF\x95",S_OK,FALSE},
{"/dir/foobar.txt",S_OK,FALSE},
{"/dir/foobar.txt",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"ftp://winepass:\xE6\xB5\x8B\xE8\xAF\x95@ftp.winehq.org:9999/dir/foobar.txt",S_OK,FALSE},
{"ftp",S_OK,FALSE},
{"winepass:\xE6\xB5\x8B\xE8\xAF\x95",S_OK,FALSE},
{"winepass",S_OK,FALSE}
},
{
{Uri_HOST_DNS,S_OK,FALSE},
{9999,S_OK,FALSE},
{URL_SCHEME_FTP,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
},
/* Query with Unicode characters. Unicode characters should not be encoded */
{ "http://www.winehq.org/tests/..?query=\xE6\xB5\x8B\xE8\xAF\x95&return=y", 0, S_OK, FALSE,
{
{"http://www.winehq.org/?query=\xE6\xB5\x8B\xE8\xAF\x95&return=y",S_OK,FALSE},
{"www.winehq.org",S_OK,FALSE},
{"http://www.winehq.org/?query=\xE6\xB5\x8B\xE8\xAF\x95&return=y",S_OK,FALSE},
{"winehq.org",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"www.winehq.org",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"/",S_OK,FALSE},
{"/?query=\xE6\xB5\x8B\xE8\xAF\x95&return=y",S_OK,FALSE},
{"?query=\xE6\xB5\x8B\xE8\xAF\x95&return=y",S_OK,FALSE},
{"http://www.winehq.org/tests/..?query=\xE6\xB5\x8B\xE8\xAF\x95&return=y",S_OK,FALSE},
{"http",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE}
},
{
{Uri_HOST_DNS,S_OK,FALSE},
{80,S_OK,FALSE},
{URL_SCHEME_HTTP,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE},
}
},
/* Fragment with Unicode characters. Unicode characters should not be encoded */
{ "http://www.winehq.org/tests/#\xE6\xB5\x8B\xE8\xAF\x95", 0, S_OK, FALSE,
{
{"http://www.winehq.org/tests/#\xE6\xB5\x8B\xE8\xAF\x95",S_OK,FALSE},
{"www.winehq.org",S_OK,FALSE},
{"http://www.winehq.org/tests/#\xE6\xB5\x8B\xE8\xAF\x95",S_OK,FALSE},
{"winehq.org",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"#\xE6\xB5\x8B\xE8\xAF\x95",S_OK,FALSE},
{"www.winehq.org",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"/tests/",S_OK,FALSE},
{"/tests/",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"http://www.winehq.org/tests/#\xE6\xB5\x8B\xE8\xAF\x95",S_OK,FALSE},
{"http",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE}
},
{
{Uri_HOST_DNS,S_OK,FALSE},
{80,S_OK,FALSE},
{URL_SCHEME_HTTP,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE},
}
},
/* ZERO WIDTH JOINER as non-printing Unicode characters should not be encoded if not preprocessed. */
{ "file:a\xE2\x80\x8D.html", Uri_CREATE_NO_PRE_PROCESS_HTML_URI, S_OK, FALSE,
{
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"file:a\xE2\x80\x8D.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{".html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"a\xE2\x80\x8D.html",S_OK,FALSE},
{"a\xE2\x80\x8D.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"file:a\xE2\x80\x8D.html",S_OK,FALSE},
{"file",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE}
},
{
{Uri_HOST_UNKNOWN,S_OK,FALSE},
{0,S_FALSE,FALSE},
{URL_SCHEME_FILE,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
},
/* LEFT-TO-RIGHT MARK as non-printing Unicode characters should not be encoded if not preprocessed. */
{ "file:ab\xE2\x80\x8E.html", Uri_CREATE_NO_PRE_PROCESS_HTML_URI, S_OK, FALSE,
{
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"file:ab\xE2\x80\x8D.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{".html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"ab\xE2\x80\x8D.html",S_OK,FALSE},
{"ab\xE2\x80\x8D.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"file:ab\xE2\x80\x8D.html",S_OK,FALSE},
{"file",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE}
},
{
{Uri_HOST_UNKNOWN,S_OK,FALSE},
{0,S_FALSE,FALSE},
{URL_SCHEME_FILE,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
},
/* Invalid Unicode characters should not be filtered */
{ "file:ab\xc3\x28.html", 0, S_OK, FALSE,
{
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"file:ab\xc3\x28.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{".html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"ab\xc3\x28.html",S_OK,FALSE},
{"ab\xc3\x28.html",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"file:ab\xc3\x28.html",S_OK,FALSE},
{"file",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE}
},
{
{Uri_HOST_UNKNOWN,S_OK,FALSE},
{0,S_FALSE,FALSE},
{URL_SCHEME_FILE,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
},
/* Make sure % encoded unicode characters are not decoded. */
{ "ftp://%E6%B5%8B%E8%AF%95:%E6%B5%8B%E8%AF%95@ftp.google.com/", 0, S_OK, FALSE,
{
{"ftp://%E6%B5%8B%E8%AF%95:%E6%B5%8B%E8%AF%95@ftp.google.com/",S_OK,FALSE},
{"%E6%B5%8B%E8%AF%95:%E6%B5%8B%E8%AF%95@ftp.google.com",S_OK,FALSE},
{"ftp://ftp.google.com/",S_OK,FALSE},
{"google.com",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"",S_FALSE,FALSE},
{"ftp.google.com",S_OK,FALSE},
{"%E6%B5%8B%E8%AF%95",S_OK,FALSE},
{"/",S_OK,FALSE},
{"/",S_OK,FALSE},
{"",S_FALSE,FALSE},
{"ftp://%E6%B5%8B%E8%AF%95:%E6%B5%8B%E8%AF%95@ftp.google.com/",S_OK,FALSE},
{"ftp",S_OK,FALSE},
{"%E6%B5%8B%E8%AF%95:%E6%B5%8B%E8%AF%95",S_OK,FALSE},
{"%E6%B5%8B%E8%AF%95",S_OK,FALSE}
},
{
{Uri_HOST_DNS,S_OK,FALSE},
{21,S_OK,FALSE},
{URL_SCHEME_FTP,S_OK,FALSE},
{URLZONE_INVALID,E_NOTIMPL,FALSE}
}
} }
}; };
@ -7396,6 +7650,9 @@ static const uri_parse_test uri_parse_tests[] = {
{"file:///c:/te%XX t/",0,PARSE_PATH_FROM_URL,0,"c:\\te%XX t\\",S_OK,FALSE}, {"file:///c:/te%XX t/",0,PARSE_PATH_FROM_URL,0,"c:\\te%XX t\\",S_OK,FALSE},
{"file://server/test",0,PARSE_PATH_FROM_URL,0,"\\\\server\\test",S_OK,FALSE}, {"file://server/test",0,PARSE_PATH_FROM_URL,0,"\\\\server\\test",S_OK,FALSE},
{"http://google.com/",0,PARSE_PATH_FROM_URL,0,"",E_INVALIDARG,FALSE}, {"http://google.com/",0,PARSE_PATH_FROM_URL,0,"",E_INVALIDARG,FALSE},
{"file:/c:/dir/test.mp3",0,PARSE_PATH_FROM_URL,0,"c:\\dir\\test.mp3",S_OK},
{"file:/c:/test.mp3",0,PARSE_PATH_FROM_URL,0,"c:\\test.mp3",S_OK},
{"file://c:\\test.mp3",0,PARSE_PATH_FROM_URL,0,"c:\\test.mp3",S_OK},
/* PARSE_URL_FROM_PATH tests. */ /* PARSE_URL_FROM_PATH tests. */
/* This function almost seems to useless (just returns the absolute uri). */ /* This function almost seems to useless (just returns the absolute uri). */
@ -7432,24 +7689,14 @@ static inline LPWSTR a2w(LPCSTR str) {
LPWSTR ret = NULL; LPWSTR ret = NULL;
if(str) { if(str) {
DWORD len = MultiByteToWideChar(CP_ACP, 0, str, -1, NULL, 0); DWORD len = MultiByteToWideChar(CP_UTF8, 0, str, -1, NULL, 0);
ret = HeapAlloc(GetProcessHeap(), 0, len*sizeof(WCHAR)); ret = HeapAlloc(GetProcessHeap(), 0, len*sizeof(WCHAR));
MultiByteToWideChar(CP_ACP, 0, str, -1, ret, len); MultiByteToWideChar(CP_UTF8, 0, str, -1, ret, len);
} }
return ret; return ret;
} }
static inline void* __WINE_ALLOC_SIZE(1) heap_alloc(size_t size)
{
return HeapAlloc(GetProcessHeap(), 0, size);
}
static inline BOOL heap_free(void *mem)
{
return HeapFree(GetProcessHeap(), 0, mem);
}
static inline DWORD strcmp_aw(LPCSTR strA, LPCWSTR strB) { static inline DWORD strcmp_aw(LPCSTR strA, LPCWSTR strB) {
LPWSTR strAW = a2w(strA); LPWSTR strAW = a2w(strA);
DWORD ret = lstrcmpW(strAW, strB); DWORD ret = lstrcmpW(strAW, strB);
@ -8113,8 +8360,12 @@ static void test_IUri_GetPropertyLength(void) {
for(j = Uri_PROPERTY_STRING_START; j <= Uri_PROPERTY_STRING_LAST; ++j) { for(j = Uri_PROPERTY_STRING_START; j <= Uri_PROPERTY_STRING_LAST; ++j) {
DWORD expectedLen, receivedLen; DWORD expectedLen, receivedLen;
uri_str_property prop = test.str_props[j]; uri_str_property prop = test.str_props[j];
LPWSTR expectedValueW;
expectedLen = lstrlenA(prop.value); expectedLen = lstrlenA(prop.value);
/* Value may be unicode encoded */
expectedValueW = a2w(prop.value);
expectedLen = lstrlenW(expectedValueW);
/* This won't be necessary once GetPropertyLength is implemented. */ /* This won't be necessary once GetPropertyLength is implemented. */
receivedLen = -1; receivedLen = -1;
@ -10573,11 +10824,11 @@ static void test_CoInternetParseIUri(void) {
if(SUCCEEDED(hr)) { if(SUCCEEDED(hr)) {
DWORD len = lstrlenA(test.property); DWORD len = lstrlenA(test.property);
ok(!strcmp_aw(test.property, result) || (test.property2 && !strcmp_aw(test.property2, result)), ok(!strcmp_aw(test.property, result) || (test.property2 && !strcmp_aw(test.property2, result)),
"Error: Expected %s but got %s instead on uri_parse_tests[%d].\n", "Error: Expected %s but got %s instead on uri_parse_tests[%d] - %s.\n",
test.property, wine_dbgstr_w(result), i); test.property, wine_dbgstr_w(result), i, wine_dbgstr_w(uriW));
ok(len == result_len || (test.property2 && lstrlenA(test.property2) == result_len), ok(len == result_len || (test.property2 && lstrlenA(test.property2) == result_len),
"Error: Expected %d, but got %d instead on uri_parse_tests[%d].\n", "Error: Expected %d, but got %d instead on uri_parse_tests[%d] - %s.\n",
len, result_len, i); len, result_len, i, wine_dbgstr_w(uriW));
} else { } else {
ok(!result_len, ok(!result_len,
"Error: Expected 'result_len' to be 0, but was %d on uri_parse_tests[%d].\n", "Error: Expected 'result_len' to be 0, but was %d on uri_parse_tests[%d].\n",

View file

@ -19,29 +19,21 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#define WIN32_NO_STATUS #include <stdarg.h>
#define _INC_WINDOWS
#define COM_NO_WINDOWS_H
//#include <stdarg.h>
#include <stdio.h> #include <stdio.h>
#define COBJMACROS #define COBJMACROS
#define NONAMELESSUNION #define NONAMELESSUNION
#define CONST_VTABLE #define CONST_VTABLE
#include <windef.h> #include "windef.h"
#include <winbase.h> #include "winbase.h"
#include <winnls.h> #include "initguid.h"
#include <winreg.h> #include "urlmon.h"
#include <wingdi.h> #include "wininet.h"
#include <objbase.h> #include "mshtml.h"
//#include "initguid.h"
//#include "urlmon.h"
#include <wininet.h>
#include <mshtml.h>
#include <wine/test.h> #include "wine/test.h"
static HRESULT (WINAPI *pCreateAsyncBindCtxEx)(IBindCtx *, DWORD, static HRESULT (WINAPI *pCreateAsyncBindCtxEx)(IBindCtx *, DWORD,
IBindStatusCallback *, IEnumFORMATETC *, IBindCtx **, DWORD); IBindStatusCallback *, IEnumFORMATETC *, IBindCtx **, DWORD);
@ -190,6 +182,7 @@ static HRESULT abort_hres;
static BOOL have_IHttpNegotiate2, use_bscex, is_async_prot; static BOOL have_IHttpNegotiate2, use_bscex, is_async_prot;
static BOOL test_redirect, use_cache_file, callback_read, no_callback, test_abort; static BOOL test_redirect, use_cache_file, callback_read, no_callback, test_abort;
static WCHAR cache_file_name[MAX_PATH]; static WCHAR cache_file_name[MAX_PATH];
static WCHAR http_cache_file[MAX_PATH];
static BOOL only_check_prot_args = FALSE; static BOOL only_check_prot_args = FALSE;
static BOOL invalid_cn_accepted = FALSE; static BOOL invalid_cn_accepted = FALSE;
static BOOL abort_start = FALSE; static BOOL abort_start = FALSE;
@ -1935,6 +1928,14 @@ static HRESULT WINAPI statusclb_OnStopBinding(IBindStatusCallbackEx *iface, HRES
ok( WaitForSingleObject(complete_event2, 90000) == WAIT_OBJECT_0, "wait timed out\n" ); ok( WaitForSingleObject(complete_event2, 90000) == WAIT_OBJECT_0, "wait timed out\n" );
} }
if(test_protocol == HTTP_TEST && !emulate_protocol && http_cache_file[0]) {
HANDLE file = CreateFileW(http_cache_file, DELETE, FILE_SHARE_DELETE, NULL,
OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
ok(file == INVALID_HANDLE_VALUE, "expected INVALID_HANDLE_VALUE, got %p\n", file);
ok(GetLastError() == ERROR_SHARING_VIOLATION, "expected ERROR_SHARING_VIOLATION, got %u\n", GetLastError());
http_cache_file[0] = 0;
}
return S_OK; return S_OK;
} }
@ -2091,6 +2092,8 @@ static HRESULT WINAPI statusclb_OnDataAvailable(IBindStatusCallbackEx *iface, DW
else if(emulate_protocol) else if(emulate_protocol)
ok(!lstrcmpW(pstgmed->u.lpszFileName, cache_fileW), ok(!lstrcmpW(pstgmed->u.lpszFileName, cache_fileW),
"unexpected file name %s\n", wine_dbgstr_w(pstgmed->u.lpszFileName)); "unexpected file name %s\n", wine_dbgstr_w(pstgmed->u.lpszFileName));
else if(test_protocol == HTTP_TEST)
lstrcpyW(http_cache_file, pstgmed->u.lpszFileName);
else else
ok(pstgmed->u.lpszFileName != NULL, "lpszFileName == NULL\n"); ok(pstgmed->u.lpszFileName != NULL, "lpszFileName == NULL\n");
} }