4 * Copyright 2010 Thomas Mullaly
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
22 * IUri testing framework goals:
25 * - invalid args (IUri, uri string)
26 * - Test parsing for components when no canonicalization occurs
27 * - Test parsing for components when canonicalization occurs.
31 #include <wine/test.h>
41 static HRESULT (WINAPI *pCreateUri)(LPCWSTR, DWORD, DWORD_PTR, IUri**);
43 static const WCHAR http_urlW[] = { 'h','t','t','p',':','/','/','w','w','w','.','w','i','n','e','h','q',
44 '.','o','r','g','/',0};
46 typedef struct _uri_create_flag_test {
49 } uri_create_flag_test;
51 static const uri_create_flag_test invalid_flag_tests[] = {
52 /* Set of invalid flag combinations to test for. */
53 {Uri_CREATE_DECODE_EXTRA_INFO | Uri_CREATE_NO_DECODE_EXTRA_INFO, E_INVALIDARG},
54 {Uri_CREATE_CANONICALIZE | Uri_CREATE_NO_CANONICALIZE, E_INVALIDARG},
55 {Uri_CREATE_CRACK_UNKNOWN_SCHEMES | Uri_CREATE_NO_CRACK_UNKNOWN_SCHEMES, E_INVALIDARG},
56 {Uri_CREATE_PRE_PROCESS_HTML_URI | Uri_CREATE_NO_PRE_PROCESS_HTML_URI, E_INVALIDARG},
57 {Uri_CREATE_IE_SETTINGS | Uri_CREATE_NO_IE_SETTINGS, E_INVALIDARG}
61 * Simple tests to make sure the CreateUri function handles invalid flag combinations
64 static void test_CreateUri_InvalidFlags(void) {
67 for(i = 0; i < sizeof(invalid_flag_tests)/sizeof(invalid_flag_tests[0]); ++i) {
69 IUri *uri = (void*) 0xdeadbeef;
71 hr = pCreateUri(http_urlW, invalid_flag_tests[i].flags, 0, &uri);
73 ok(hr == invalid_flag_tests[i].expected, "Error: CreateUri returned 0x%08x, expected 0x%08x, flags=0x%08x\n",
74 hr, invalid_flag_tests[i].expected, invalid_flag_tests[i].flags);
76 todo_wine { ok(uri == NULL, "Error: expected the IUri to be NULL, but it was %p instead\n", uri); }
80 static void test_CreateUri_InvalidArgs(void) {
82 IUri *uri = (void*) 0xdeadbeef;
84 hr = pCreateUri(http_urlW, 0, 0, NULL);
85 ok(hr == E_INVALIDARG, "Error: CreateUri returned 0x%08x, expected 0x%08x\n", hr, E_INVALIDARG);
87 hr = pCreateUri(NULL, 0, 0, &uri);
88 ok(hr == E_INVALIDARG, "Error: CreateUri returned 0x%08x, expected 0x%08x\n", hr, E_INVALIDARG);
89 ok(uri == NULL, "Error: Expected the IUri to be NULL, but it was %p instead\n", uri);
95 hurlmon = GetModuleHandle("urlmon.dll");
96 pCreateUri = (void*) GetProcAddress(hurlmon, "CreateUri");
99 win_skip("CreateUri is not present, skipping tests.\n");
103 trace("test CreateUri invalid flags...\n");
104 test_CreateUri_InvalidFlags();
106 trace("test CreateUri invalid args...\n");
107 test_CreateUri_InvalidArgs();