Git conversion: Make reactos the root directory, move rosapps, rostests, wallpapers...
[reactos.git] / rostests / winetests / shell32 / assoc.c
diff --git a/rostests/winetests/shell32/assoc.c b/rostests/winetests/shell32/assoc.c
deleted file mode 100644 (file)
index 2cd06d2..0000000
+++ /dev/null
@@ -1,331 +0,0 @@
-/* Unit test suite for various shell Association objects
- *
- * Copyright 2012 Detlef Riekenberg
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
- */
-
-#define COBJMACROS
-
-#include <stdarg.h>
-
-#include "shlwapi.h"
-#include "shlguid.h"
-#include "shobjidl.h"
-
-#include "wine/test.h"
-
-
-static void test_IQueryAssociations_QueryInterface(void)
-{
-    IQueryAssociations *qa;
-    IQueryAssociations *qa2;
-    IUnknown *unk;
-    HRESULT hr;
-
-    hr = CoCreateInstance(&CLSID_QueryAssociations, NULL, CLSCTX_INPROC_SERVER, &IID_IQueryAssociations, (void*)&qa);
-    ok(hr == S_OK, "got 0x%08x\n", hr);
-
-    hr = IQueryAssociations_QueryInterface(qa, &IID_IQueryAssociations, (void**)&qa2);
-    ok(hr == S_OK, "QueryInterface (IQueryAssociations) returned 0x%x\n", hr);
-    if (SUCCEEDED(hr)) {
-        IQueryAssociations_Release(qa2);
-    }
-
-    hr = IQueryAssociations_QueryInterface(qa, &IID_IUnknown, (void**)&unk);
-    ok(hr == S_OK, "QueryInterface (IUnknown) returned 0x%x\n", hr);
-    if (SUCCEEDED(hr)) {
-        IUnknown_Release(unk);
-    }
-
-    hr = IQueryAssociations_QueryInterface(qa, &IID_IUnknown, NULL);
-    ok(hr == E_POINTER, "got 0x%x (expected E_POINTER)\n", hr);
-
-    IQueryAssociations_Release(qa);
-}
-
-
-static void test_IApplicationAssociationRegistration_QueryInterface(IApplicationAssociationRegistration *appreg)
-{
-    IApplicationAssociationRegistration *appreg2;
-    IUnknown *unk;
-    HRESULT hr;
-
-    hr = IApplicationAssociationRegistration_QueryInterface(appreg, &IID_IApplicationAssociationRegistration,
-       (void**)&appreg2);
-    ok(hr == S_OK, "QueryInterface (IApplicationAssociationRegistration) returned 0x%x\n", hr);
-    if (SUCCEEDED(hr)) {
-        IApplicationAssociationRegistration_Release(appreg2);
-    }
-
-    hr = IApplicationAssociationRegistration_QueryInterface(appreg, &IID_IUnknown, (void**)&unk);
-    ok(hr == S_OK, "QueryInterface (IUnknown) returned 0x%x\n", hr);
-    if (SUCCEEDED(hr)) {
-        IUnknown_Release(unk);
-    }
-
-    hr = IApplicationAssociationRegistration_QueryInterface(appreg, &IID_IUnknown, NULL);
-    ok(hr == E_POINTER, "got 0x%x (expected E_POINTER)\n", hr);
-}
-
-struct assoc_getstring_test
-{
-    const WCHAR *key;
-    ASSOCF       flags;
-    ASSOCSTR     str;
-    DWORD        len;
-    HRESULT      hr;
-    HRESULT      brokenhr;
-};
-
-static const WCHAR httpW[] = {'h','t','t','p',0};
-static const WCHAR badW[] = {'b','a','d','b','a','d',0};
-
-static struct assoc_getstring_test getstring_tests[] =
-{
-    { httpW, 0, ASSOCSTR_EXECUTABLE, 2, 0x8007007a /* E_NOT_SUFFICIENT_BUFFER */, S_OK },
-    { httpW, ASSOCF_NOTRUNCATE, ASSOCSTR_EXECUTABLE, 2, E_POINTER },
-    { NULL }
-};
-
-static void getstring_test(LPCWSTR assocName, HKEY progIdKey, ASSOCSTR str, LPCWSTR expected_string, int line)
-{
-    IQueryAssociations *assoc;
-    HRESULT hr;
-    WCHAR *buffer = NULL;
-    DWORD len;
-
-    hr = CoCreateInstance(&CLSID_QueryAssociations, NULL, CLSCTX_INPROC_SERVER, &IID_IQueryAssociations, (void*)&assoc);
-    ok_(__FILE__, line)(hr == S_OK, "failed to create IQueryAssociations, 0x%x\n", hr);
-    hr = IQueryAssociations_Init(assoc, ASSOCF_NONE, assocName, progIdKey, NULL);
-    ok_(__FILE__, line)(hr == S_OK, "IQueryAssociations::Init failed, 0x%x\n", hr);
-
-    hr = IQueryAssociations_GetString(assoc, ASSOCF_NONE, str, NULL, NULL, &len);
-    if (expected_string) {
-        ok_(__FILE__, line)(hr == S_FALSE, "GetString returned 0x%x, expected S_FALSE\n", hr);
-        if (hr != S_FALSE) {
-            /* don't try to allocate memory using uninitialized len */
-            IQueryAssociations_Release(assoc);
-            return;
-        }
-
-        buffer = HeapAlloc(GetProcessHeap(), 0, len * sizeof(WCHAR));
-        ok_(__FILE__, line)(buffer != NULL, "out of memory\n");
-        hr = IQueryAssociations_GetString(assoc, 0, str, NULL, buffer, &len);
-        ok_(__FILE__, line)(hr == S_OK, "GetString returned 0x%x, expected S_OK\n", hr);
-
-        ok_(__FILE__, line)(lstrcmpW(buffer, expected_string) == 0, "GetString returned %s, expected %s\n",
-                wine_dbgstr_w(buffer), wine_dbgstr_w(expected_string));
-    } else {
-        ok_(__FILE__, line)(FAILED(hr), "GetString returned 0x%x, expected failure\n", hr);
-    }
-
-    IQueryAssociations_Release(assoc);
-    HeapFree(GetProcessHeap(), 0, buffer);
-}
-
-static void test_IQueryAssociations_GetString(void)
-{
-    static WCHAR test_extensionW[] = {'.','t','e','s','t',0};
-    static WCHAR test_progidW[] = {'t','e','s','t','f','i','l','e',0};
-    static WCHAR DefaultIconW[] = {'D','e','f','a','u','l','t','I','c','o','n',0};
-    /* folder.ico, why not */
-    static WCHAR test_iconW[] = {'s','h','e','l','l','3','2','.','d','l','l',',','1',0};
-    HKEY test_extension_key;
-    HKEY test_progid_key;
-    HKEY test_defaulticon_key;
-    LRESULT r;
-
-    struct assoc_getstring_test *ptr = getstring_tests;
-    IQueryAssociations *assoc;
-    HRESULT hr;
-    DWORD len;
-    int i = 0;
-
-    r = RegCreateKeyExW(HKEY_CLASSES_ROOT, test_extensionW, 0, NULL, 0, KEY_ALL_ACCESS, NULL, &test_extension_key, NULL);
-    if (r == ERROR_ACCESS_DENIED)
-    {
-        win_skip("Not enough permissions to create a test key.\n");
-        return;
-    }
-
-    ok(r == ERROR_SUCCESS, "RegCreateKeyExW(HKCR, \".test\") failed: 0x%lx\n", r);
-    r = RegSetValueExW(test_extension_key, NULL, 0, REG_SZ, (PBYTE)test_progidW, sizeof(test_progidW));
-    ok(r == ERROR_SUCCESS, "RegSetValueExW(HKCR\\.test, NULL, \"testfile\") failed: 0x%lx\n", r);
-
-    /* adding progid key with no information should fail to return information */
-    r = RegCreateKeyExW(HKEY_CLASSES_ROOT, test_progidW, 0, NULL, 0, KEY_ALL_ACCESS, NULL, &test_progid_key, NULL);
-    ok(r == ERROR_SUCCESS, "RegCreateKeyExW(HKCR, \"testfile\") failed: 0x%lx\n", r);
-    getstring_test(test_extensionW, NULL, ASSOCSTR_DEFAULTICON, NULL, __LINE__);
-    getstring_test(test_progidW, NULL, ASSOCSTR_DEFAULTICON, NULL, __LINE__);
-    getstring_test(NULL, test_progid_key, ASSOCSTR_DEFAULTICON, NULL, __LINE__);
-
-    /* adding information to the progid should return that information */
-    r = RegCreateKeyExW(test_progid_key, DefaultIconW, 0, NULL, 0, KEY_ALL_ACCESS, NULL, &test_defaulticon_key, NULL);
-    ok(r == ERROR_SUCCESS, "RegCreateKeyExW(HKCR\\testfile\\DefaultIcon) failed: 0x%lx\n", r);
-    r = RegSetValueExW(test_defaulticon_key, NULL, 0, REG_SZ, (PBYTE)test_iconW, sizeof(test_iconW));
-    ok(r == ERROR_SUCCESS, "RegSetValueExW(HKCR\\testfile\\DefaultIcon, NULL, \"folder.ico\") failed: 0x%lx\n", r);
-    getstring_test(test_extensionW, NULL, ASSOCSTR_DEFAULTICON, test_iconW, __LINE__);
-    getstring_test(test_progidW, NULL, ASSOCSTR_DEFAULTICON, test_iconW, __LINE__);
-    getstring_test(NULL, test_progid_key, ASSOCSTR_DEFAULTICON, test_iconW, __LINE__);
-
-    RegDeleteKeyW(test_progid_key, DefaultIconW);
-    RegDeleteKeyW(HKEY_CLASSES_ROOT, test_progidW);
-    RegDeleteKeyW(HKEY_CLASSES_ROOT, test_extensionW);
-
-    hr = CoCreateInstance(&CLSID_QueryAssociations, NULL, CLSCTX_INPROC_SERVER, &IID_IQueryAssociations, (void*)&assoc);
-    ok(hr == S_OK, "failed to create object, 0x%x\n", hr);
-
-    hr = IQueryAssociations_Init(assoc, ASSOCF_NONE, httpW, NULL, NULL);
-    ok(hr == S_OK, "Init failed, 0x%x\n", hr);
-
-    len = 0;
-    hr = IQueryAssociations_GetString(assoc, ASSOCF_NONE, ASSOCSTR_EXECUTABLE, NULL, NULL, &len);
-    ok(hr == S_FALSE, "got 0x%08x\n", hr);
-    ok(len > 0, "got wrong needed length, %d\n", len);
-
-    while (ptr->key)
-    {
-        WCHAR buffW[MAX_PATH];
-        DWORD len;
-
-        hr = IQueryAssociations_Init(assoc, ASSOCF_NONE, ptr->key, NULL, NULL);
-        ok(hr == S_OK, "%d: Init failed, 0x%x\n", i, hr);
-
-        len = ptr->len;
-        buffW[0] = ptr->flags & ASSOCF_NOTRUNCATE ? 0x1 : 0;
-        hr = IQueryAssociations_GetString(assoc, ptr->flags, ptr->str, NULL, buffW, &len);
-        if (hr != ptr->hr)
-            ok(broken(hr == ptr->brokenhr), "%d: GetString failed, 0x%08x\n", i, hr);
-        else
-        {
-            ok(hr == ptr->hr, "%d: GetString failed, 0x%08x\n", i, hr);
-            ok(len > ptr->len, "%d: got needed length %d\n", i, len);
-        }
-
-        /* even with ASSOCF_NOTRUNCATE it's null terminated */
-        if ((ptr->flags & ASSOCF_NOTRUNCATE) && (ptr->len > 0))
-            ok(buffW[0] == 0 || broken(buffW[0] == 0x1) /* pre win7 */, "%d: got %x\n", i, buffW[0]);
-
-        if (!(ptr->flags & ASSOCF_NOTRUNCATE) && ptr->len && FAILED(ptr->hr))
-            ok(buffW[0] != 0, "%d: got %x\n", i, buffW[0]);
-
-        i++;
-        ptr++;
-    }
-
-    IQueryAssociations_Release(assoc);
-}
-
-static void test_IQueryAssociations_Init(void)
-{
-    IQueryAssociations *assoc;
-    HRESULT hr;
-    DWORD len;
-
-    hr = CoCreateInstance(&CLSID_QueryAssociations, NULL, CLSCTX_INPROC_SERVER, &IID_IQueryAssociations, (void*)&assoc);
-    ok(hr == S_OK, "failed to create object, 0x%x\n", hr);
-
-    hr = IQueryAssociations_Init(assoc, ASSOCF_NONE, NULL, NULL, NULL);
-    ok(hr == E_INVALIDARG, "Init failed, 0x%08x\n", hr);
-
-    hr = IQueryAssociations_Init(assoc, ASSOCF_NONE, httpW, NULL, NULL);
-    ok(hr == S_OK, "Init failed, 0x%08x\n", hr);
-
-    hr = IQueryAssociations_Init(assoc, ASSOCF_NONE, badW, NULL, NULL);
-    ok(hr == S_OK || broken(hr == S_FALSE) /* pre-vista */, "Init failed, 0x%08x\n", hr);
-
-    len = 0;
-    hr = IQueryAssociations_GetString(assoc, ASSOCF_NONE, ASSOCSTR_EXECUTABLE, NULL, NULL, &len);
-    ok(hr == HRESULT_FROM_WIN32(ERROR_NO_ASSOCIATION) || broken(hr == E_FAIL) /* pre-vista */, "got 0x%08x\n", hr);
-
-    IQueryAssociations_Release(assoc);
-}
-
-static void test_IApplicationAssociationRegistration_QueryCurrentDefault(IApplicationAssociationRegistration *appreg)
-{
-    static const WCHAR emptyW[] = {0};
-    static const WCHAR txtW[] = {'.','t','x','t',0};
-    static const WCHAR spacetxtW[] = {' ','.','t','x','t',0};
-    HRESULT hr;
-    LPWSTR assocprog = NULL;
-
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, emptyW, AT_URLPROTOCOL, AL_EFFECTIVE, &assocprog);
-    ok(hr == E_INVALIDARG, "got 0x%x\n", hr);
-
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, emptyW, AT_FILEEXTENSION, AL_EFFECTIVE, &assocprog);
-    ok(hr == E_INVALIDARG, "got 0x%x\n", hr);
-
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, spacetxtW, AT_FILEEXTENSION, AL_EFFECTIVE, &assocprog);
-    ok(hr == E_INVALIDARG || hr == HRESULT_FROM_WIN32(ERROR_NO_ASSOCIATION) /*Win8*/, "got 0x%x\n", hr);
-
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, httpW, AT_URLPROTOCOL, AL_EFFECTIVE, NULL);
-    ok(hr == E_INVALIDARG, "got 0x%x\n", hr);
-
-    /* AT_FILEEXTENSION must start with a period */
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, txtW, AT_FILEEXTENSION, AL_EFFECTIVE, &assocprog);
-    ok(hr == S_OK, "got 0x%x\n", hr);
-    trace("%s\n", wine_dbgstr_w(assocprog));
-    CoTaskMemFree(assocprog);
-
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, emptyW, AT_STARTMENUCLIENT, AL_EFFECTIVE, &assocprog);
-    ok(hr == HRESULT_FROM_WIN32(ERROR_NO_ASSOCIATION), "got 0x%x\n", hr);
-
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, emptyW, AT_MIMETYPE, AL_EFFECTIVE, &assocprog);
-    ok(hr == HRESULT_FROM_WIN32(ERROR_NO_ASSOCIATION), "got 0x%x\n", hr);
-
-    hr = IApplicationAssociationRegistration_QueryCurrentDefault(appreg, httpW, AT_URLPROTOCOL, AL_EFFECTIVE, &assocprog);
-    todo_wine ok(hr == S_OK, "got 0x%x\n", hr);
-    trace("%s\n", wine_dbgstr_w(assocprog));
-
-    CoTaskMemFree(assocprog);
-}
-
-START_TEST(assoc)
-{
-    IQueryAssociations *qa;
-    IApplicationAssociationRegistration *appreg = NULL;
-    HRESULT hr;
-
-    CoInitialize(NULL);
-
-    /* this works since XP */
-    hr = CoCreateInstance(&CLSID_QueryAssociations, NULL, CLSCTX_INPROC_SERVER, &IID_IQueryAssociations, (void*)&qa);
-    if (hr == S_OK)
-    {
-        test_IQueryAssociations_QueryInterface();
-        test_IQueryAssociations_GetString();
-        test_IQueryAssociations_Init();
-
-        IQueryAssociations_Release(qa);
-    }
-    else
-        win_skip("IQueryAssociations not supported, 0x%x\n", hr);
-
-    /* this works since Vista */
-    hr = CoCreateInstance(&CLSID_ApplicationAssociationRegistration, NULL, CLSCTX_INPROC_SERVER,
-                          &IID_IApplicationAssociationRegistration, (LPVOID*)&appreg);
-    if (hr == S_OK)
-    {
-        test_IApplicationAssociationRegistration_QueryInterface(appreg);
-        test_IApplicationAssociationRegistration_QueryCurrentDefault(appreg);
-
-        IApplicationAssociationRegistration_Release(appreg);
-    }
-    else
-        win_skip("IApplicationAssociationRegistration not supported: 0x%x\n", hr);
-
-    CoUninitialize();
-}