[2/2] sxs/tests: Add tests for CreateAssemblyNameObject.

Hans Leidekker hans at codeweavers.com
Fri Mar 16 10:13:13 CDT 2012


---
 configure.ac               |    3 +-
 dlls/sxs/tests/Makefile.in |    8 ++
 dlls/sxs/tests/name.c      |  228 ++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 238 insertions(+), 1 deletions(-)
 create mode 100644 dlls/sxs/tests/Makefile.in
 create mode 100644 dlls/sxs/tests/name.c

diff --git a/configure.ac b/configure.ac
index 472ef12..ac990cb 100644
--- a/configure.ac
+++ b/configure.ac
@@ -2827,7 +2827,8 @@ WINE_CONFIG_DLL(stress.dll16,enable_win16)
 WINE_CONFIG_LIB(strmbase)
 WINE_CONFIG_LIB(strmiids)
 WINE_CONFIG_DLL(svrapi)
-WINE_CONFIG_DLL(sxs)
+WINE_CONFIG_DLL(sxs,,[implib])
+WINE_CONFIG_TEST(dlls/sxs/tests)
 WINE_CONFIG_DLL(system.drv16,enable_win16)
 WINE_CONFIG_DLL(t2embed)
 WINE_CONFIG_DLL(tapi32,,[implib])
diff --git a/dlls/sxs/tests/Makefile.in b/dlls/sxs/tests/Makefile.in
new file mode 100644
index 0000000..2f8be9c
--- /dev/null
+++ b/dlls/sxs/tests/Makefile.in
@@ -0,0 +1,8 @@
+TESTDLL   = sxs.dll
+IMPORTS   = sxs
+
+C_SRCS = \
+	cache.c \
+	name.c
+
+ at MAKE_TEST_RULES@
diff --git a/dlls/sxs/tests/name.c b/dlls/sxs/tests/name.c
new file mode 100644
index 0000000..96fbbb9
--- /dev/null
+++ b/dlls/sxs/tests/name.c
@@ -0,0 +1,228 @@
+/*
+ * Copyright 2012 Hans Leidekker for CodeWeavers
+ *
+ * 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
+ */
+
+#include <stdio.h>
+
+#define COBJMACROS
+
+#include <windows.h>
+#include <winsxs.h>
+#include <corerror.h>
+
+#include "wine/test.h"
+
+static const WCHAR wine1W[] =
+    {'w','i','n','e',0};
+static const WCHAR wine2W[] =
+    {'w','i','n','e',',','v','e','r','s','i','o','n','=','\"','0','1','.','2','.','3','.','4','\"',',',
+     't','y','p','e','=','\"','w','i','n','3','2','\"',',',
+     'p','r','o','c','e','s','s','o','r','A','r','c','h','i','t','e','c','t','u','r','e','=',
+     '\"','x','8','6','\"',',','p','u','b','l','i','c','K','e','y','T','o','k','e','n','=',
+     '\"','1','2','3','4','5','6','7','8','9','0','A','B','C','D','E','F','\"',0};
+static const WCHAR wine3W[] =
+    {'w','i','n','e',',','v','e','r','s','i','o','n','=','\"','1','.','2','.','3','.','4','\"',0};
+static const WCHAR wine4W[] =
+    {'w','i','n','e',',','v','e','r','s','i','o','n','=','1','.','2','.','3','.','4',0};
+static const WCHAR wine5W[] =
+    {'w','i','n','e',',',' ','v','e','r','s','i','o','n','=','\"','1','.','2','.','3','.','4','\"',0};
+static const WCHAR wine6W[] =
+    {'w','i','n','e',',','v','e','r','s','i','o','n',' ','=','\"','1','.','2','.','3','.','4','\"',0};
+static const WCHAR wine7W[] =
+    {'w','i','n','e',',','v','e','r','s','i','o','n','=',' ','\"','1','.','2','.','3','.','4','\"',0};
+static const WCHAR wine8W[] =
+    {'w','i','n','e',' ',',','v','e','r','s','i','o','n','=','\"','1','.','2','.','3','.','4','\"',0};
+static const WCHAR wine9W[] =
+    {'w','i','n','e',',','v','e','r','s','i','o','n',0};
+static const WCHAR wine10W[] =
+    {'w','i','n','e',',','t','y','p','e','=','\"','\"',0};
+static const WCHAR wine11W[] =
+    {'w','i','n','e',',','t','y','p','e','=','\"','w','i','n','3','2',0};
+
+static void test_CreateAssemblyNameObject( void )
+{
+    static const WCHAR emptyW[] = {0};
+    IAssemblyName *name;
+    HRESULT hr;
+
+    hr = CreateAssemblyNameObject( NULL, wine1W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok(hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr);
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = NULL;
+    hr = CreateAssemblyNameObject( &name, wine1W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == S_OK, "expected S_OK got %08x\n", hr );
+    ok( name != NULL, "expected non-NULL name\n" );
+    IAssemblyName_Release( name );
+
+    hr = CreateAssemblyNameObject( NULL, wine1W, CANOF_SET_DEFAULT_VALUES, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, CANOF_SET_DEFAULT_VALUES, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, CANOF_SET_DEFAULT_VALUES, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, CANOF_SET_DEFAULT_VALUES, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, CANOF_SET_DEFAULT_VALUES, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine1W, CANOF_SET_DEFAULT_VALUES, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    hr = CreateAssemblyNameObject( NULL, wine1W, 0, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, 0, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, 0, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, 0, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, 0, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine1W, 0, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+
+    hr = CreateAssemblyNameObject( NULL, wine1W, CANOF_SET_DEFAULT_VALUES|CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, CANOF_SET_DEFAULT_VALUES|CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, CANOF_SET_DEFAULT_VALUES|CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, NULL, CANOF_SET_DEFAULT_VALUES|CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, emptyW, CANOF_SET_DEFAULT_VALUES|CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine1W, CANOF_SET_DEFAULT_VALUES|CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = NULL;
+    hr = CreateAssemblyNameObject( &name, wine3W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == S_OK, "expected S_OK got %08x\n", hr );
+    ok( name != NULL, "expected non-NULL name\n" );
+    IAssemblyName_Release( name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine4W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine5W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == HRESULT_FROM_WIN32( ERROR_SXS_INVALID_ASSEMBLY_IDENTITY_ATTRIBUTE_NAME ),
+        "expected ERROR_SXS_INVALID_ASSEMBLY_IDENTITY_ATTRIBUTE_NAME got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine6W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == HRESULT_FROM_WIN32( ERROR_SXS_INVALID_ASSEMBLY_IDENTITY_ATTRIBUTE_NAME ),
+        "expected ERROR_SXS_INVALID_ASSEMBLY_IDENTITY_ATTRIBUTE_NAME got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine7W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = NULL;
+    hr = CreateAssemblyNameObject( &name, wine8W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == S_OK, "expected S_OK got %08x\n", hr );
+    ok( name != NULL, "expected non-NULL name\n" );
+    IAssemblyName_Release( name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine9W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+
+    name = NULL;
+    hr = CreateAssemblyNameObject( &name, wine10W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == S_OK, "expected S_OK got %08x\n", hr );
+    ok( name != NULL, "expected non-NULL name\n" );
+    IAssemblyName_Release( name );
+
+    name = (IAssemblyName *)0xdeadbeef;
+    hr = CreateAssemblyNameObject( &name, wine11W, CANOF_PARSE_DISPLAY_NAME, NULL );
+    ok( hr == E_INVALIDARG, "expected E_INVALIDARG got %08x\n", hr );
+    ok( !name, "expected NULL got %p\n", name );
+}
+
+START_TEST(name)
+{
+    test_CreateAssemblyNameObject();
+}
-- 
1.7.9.1






More information about the wine-patches mailing list