Alexandre Julliard : kernel32/tests: Add tests for window settings namespaces.
Alexandre Julliard
julliard at winehq.org
Tue Mar 27 16:08:50 CDT 2018
Module: wine
Branch: master
Commit: 7d16575df660a256f05efaf46d91c720e0a01c46
URL: https://source.winehq.org/git/wine.git/?a=commit;h=7d16575df660a256f05efaf46d91c720e0a01c46
Author: Alexandre Julliard <julliard at winehq.org>
Date: Tue Mar 27 13:36:20 2018 +0200
kernel32/tests: Add tests for window settings namespaces.
Signed-off-by: Alexandre Julliard <julliard at winehq.org>
---
dlls/kernel32/tests/actctx.c | 109 +++++++++++++++++++++++++++++++++++++++++--
1 file changed, 105 insertions(+), 4 deletions(-)
diff --git a/dlls/kernel32/tests/actctx.c b/dlls/kernel32/tests/actctx.c
index b63abac..8c9ac79 100644
--- a/dlls/kernel32/tests/actctx.c
+++ b/dlls/kernel32/tests/actctx.c
@@ -464,10 +464,46 @@ static const char settings_manifest[] =
" <application xmlns=\"urn:schemas-microsoft-com:asm.v3\">"
" <windowsSettings>"
" <dpiAware xmlns=\"http://schemas.microsoft.com/SMI/2005/WindowsSettings\">true</dpiAware>"
+" <dpiAwareness xmlns=\"http://schemas.microsoft.com/SMI/2016/WindowsSettings\">true</dpiAwareness>"
" </windowsSettings>"
" </application>"
"</assembly>";
+static const char settings_manifest2[] =
+"<assembly xmlns=\"urn:schemas-microsoft-com:asm.v1\" manifestVersion=\"1.0\">"
+" <assemblyIdentity version=\"1.0.0.0\" name=\"Wine.Test\" type=\"win32\"></assemblyIdentity>"
+" <application xmlns=\"urn:schemas-microsoft-com:asm.v3\""
+" xmlns:ws05=\"http://schemas.microsoft.com/SMI/2005/WindowsSettings\""
+" xmlns:ws11=\"http://schemas.microsoft.com/SMI/2011/WindowsSettings\""
+" xmlns:ws16=\"http://schemas.microsoft.com/SMI/2016/WindowsSettings\""
+" xmlns:ws17=\"http://schemas.microsoft.com/SMI/2017/WindowsSettings\">"
+" <windowsSettings>"
+" <ws05:autoElevate>true</ws05:autoElevate>"
+" <ws05:disableTheming>true</ws05:disableTheming>"
+" <ws11:disableWindowFiltering>true</ws11:disableWindowFiltering>"
+" <ws05:dpiAware>true</ws05:dpiAware>"
+" <ws16:dpiAwareness>true</ws16:dpiAwareness>"
+" <ws17:gdiScaling>true</ws17:gdiScaling>"
+" <ws17:highResolutionScrollingAware>true</ws17:highResolutionScrollingAware>"
+" <ws16:longPathAware>true</ws16:longPathAware>"
+" <ws17:magicFutureSetting>true</ws17:magicFutureSetting>"
+" <ws11:printerDriverIsolation>true</ws11:printerDriverIsolation>"
+" <ws17:ultraHighResolutionScrollingAware>true</ws17:ultraHighResolutionScrollingAware>"
+" </windowsSettings>"
+" </application>"
+"</assembly>";
+
+/* broken manifest found in some binaries: asmv3 namespace is used but not declared */
+static const char settings_manifest3[] =
+"<assembly xmlns=\"urn:schemas-microsoft-com:asm.v1\" manifestVersion=\"1.0\">"
+" <assemblyIdentity version=\"1.0.0.0\" name=\"Wine.Test\" type=\"win32\"></assemblyIdentity>"
+" <asmv3:application>"
+" <asmv3:windowsSettings xmlns=\"http://schemas.microsoft.com/SMI/2005/WindowsSettings\">"
+" <dpiAware>true</dpiAware>"
+" </asmv3:windowsSettings>"
+" </asmv3:application>"
+"</assembly>";
+
DEFINE_GUID(VISTA_COMPAT_GUID, 0xe2011457, 0x1546, 0x43c5, 0xa5, 0xfe, 0x00, 0x8d, 0xee, 0xe3, 0xd3, 0xf0);
DEFINE_GUID(WIN7_COMPAT_GUID, 0x35138b9a, 0x5d96, 0x4fbd, 0x8e, 0x2d, 0xa2, 0x44, 0x02, 0x25, 0xf9, 0x3a);
DEFINE_GUID(WIN8_COMPAT_GUID, 0x4a2f28e3, 0x53b9, 0x4441, 0xba, 0x9c, 0xd6, 0x9d, 0x4a, 0x4a, 0x6e, 0x38);
@@ -2964,9 +3000,11 @@ static void test_compatibility(void)
static void test_settings(void)
{
static const WCHAR dpiAwareW[] = {'d','p','i','A','w','a','r','e',0};
+ static const WCHAR dpiAwarenessW[] = {'d','p','i','A','w','a','r','e','n','e','s','s',0};
static const WCHAR dummyW[] = {'d','u','m','m','y',0};
static const WCHAR trueW[] = {'t','r','u','e',0};
- static const WCHAR namespaceW[] = {'h','t','t','p',':','/','/','s','c','h','e','m','a','s','.','m','i','c','r','o','s','o','f','t','.','c','o','m','/','S','M','I','/','2','0','0','5','/','W','i','n','d','o','w','s','S','e','t','t','i','n','g','s',0};
+ static const WCHAR namespace2005W[] = {'h','t','t','p',':','/','/','s','c','h','e','m','a','s','.','m','i','c','r','o','s','o','f','t','.','c','o','m','/','S','M','I','/','2','0','0','5','/','W','i','n','d','o','w','s','S','e','t','t','i','n','g','s',0};
+ static const WCHAR namespace2016W[] = {'h','t','t','p',':','/','/','s','c','h','e','m','a','s','.','m','i','c','r','o','s','o','f','t','.','c','o','m','/','S','M','I','/','2','0','1','6','/','W','i','n','d','o','w','s','S','e','t','t','i','n','g','s',0};
WCHAR buffer[80];
SIZE_T size;
HANDLE handle;
@@ -3001,26 +3039,60 @@ static void test_settings(void)
size = 0xdead;
memset( buffer, 0xcc, sizeof(buffer) );
ret = pQueryActCtxSettingsW( 0, handle, NULL, dummyW, buffer, 80, &size );
- ok( !ret, "QueryActCtxSettingsW failed err %u\n", GetLastError() );
+ ok( !ret, "QueryActCtxSettingsW succeeded\n" );
ok( GetLastError() == ERROR_SXS_KEY_NOT_FOUND, "wrong error %u\n", GetLastError() );
ok( buffer[0] == 0xcccc, "got %s\n", wine_dbgstr_w(buffer) );
SetLastError( 0xdeadbeef );
size = 0xdead;
memset( buffer, 0xcc, sizeof(buffer) );
- ret = pQueryActCtxSettingsW( 0, handle, namespaceW, dpiAwareW, buffer, 80, &size );
+ ret = pQueryActCtxSettingsW( 0, handle, namespace2005W, dpiAwareW, buffer, 80, &size );
ok( ret, "QueryActCtxSettingsW failed err %u\n", GetLastError() );
ok( !lstrcmpW( buffer, trueW ), "got %s\n", wine_dbgstr_w(buffer) );
ok( size == sizeof(trueW)/sizeof(WCHAR), "wrong len %lu\n", size );
SetLastError( 0xdeadbeef );
size = 0xdead;
memset( buffer, 0xcc, sizeof(buffer) );
- ret = pQueryActCtxSettingsW( 0, handle, namespaceW, dpiAwareW, buffer, lstrlenW(trueW) + 1, &size );
+ ret = pQueryActCtxSettingsW( 0, handle, namespace2005W, dpiAwareW, buffer, lstrlenW(trueW) + 1, &size );
ok( ret, "QueryActCtxSettingsW failed err %u\n", GetLastError() );
ok( !lstrcmpW( buffer, trueW ), "got %s\n", wine_dbgstr_w(buffer) );
ok( size == sizeof(trueW)/sizeof(WCHAR), "wrong len %lu\n", size );
SetLastError( 0xdeadbeef );
size = 0xdead;
memset( buffer, 0xcc, sizeof(buffer) );
+ ret = pQueryActCtxSettingsW( 0, handle, namespace2016W, dpiAwareW, buffer, lstrlenW(trueW) + 1, &size );
+ ok( !ret, "QueryActCtxSettingsW succeeded\n" );
+ ok( GetLastError() == ERROR_SXS_KEY_NOT_FOUND || broken( GetLastError() == ERROR_INVALID_PARAMETER ),
+ "wrong error %u\n", GetLastError() );
+ ok( buffer[0] == 0xcccc, "got %s\n", wine_dbgstr_w(buffer) );
+ SetLastError( 0xdeadbeef );
+ size = 0xdead;
+ memset( buffer, 0xcc, sizeof(buffer) );
+ ret = pQueryActCtxSettingsW( 0, handle, NULL, dpiAwarenessW, buffer, lstrlenW(trueW) + 1, &size );
+ ok( !ret, "QueryActCtxSettingsW succeeded\n" );
+ ok( GetLastError() == ERROR_SXS_KEY_NOT_FOUND, "wrong error %u\n", GetLastError() );
+ ok( buffer[0] == 0xcccc, "got %s\n", wine_dbgstr_w(buffer) );
+ SetLastError( 0xdeadbeef );
+ size = 0xdead;
+ memset( buffer, 0xcc, sizeof(buffer) );
+ ret = pQueryActCtxSettingsW( 0, handle, namespace2005W, dpiAwarenessW, buffer, lstrlenW(trueW) + 1, &size );
+ ok( !ret, "QueryActCtxSettingsW succeeded\n" );
+ ok( GetLastError() == ERROR_SXS_KEY_NOT_FOUND, "wrong error %u\n", GetLastError() );
+ ok( buffer[0] == 0xcccc, "got %s\n", wine_dbgstr_w(buffer) );
+ SetLastError( 0xdeadbeef );
+ size = 0xdead;
+ memset( buffer, 0xcc, sizeof(buffer) );
+ ret = pQueryActCtxSettingsW( 0, handle, namespace2016W, dpiAwarenessW, buffer, lstrlenW(trueW) + 1, &size );
+ ok( ret || broken( GetLastError() == ERROR_INVALID_PARAMETER ),
+ "QueryActCtxSettingsW failed err %u\n", GetLastError() );
+ if (ret)
+ {
+ ok( !lstrcmpW( buffer, trueW ), "got %s\n", wine_dbgstr_w(buffer) );
+ ok( size == sizeof(trueW)/sizeof(WCHAR), "wrong len %lu\n", size );
+ }
+ else ok( buffer[0] == 0xcccc, "got %s\n", wine_dbgstr_w(buffer) );
+ SetLastError( 0xdeadbeef );
+ size = 0xdead;
+ memset( buffer, 0xcc, sizeof(buffer) );
ret = pQueryActCtxSettingsW( 0, handle, NULL, dpiAwareW, buffer, lstrlenW(trueW), &size );
ok( ret, "QueryActCtxSettingsW failed err %u\n", GetLastError() );
ok( !lstrcmpW( buffer, trueW ), "got %s\n", wine_dbgstr_w(buffer) );
@@ -3034,6 +3106,35 @@ static void test_settings(void)
ok( buffer[0] == 0xcccc, "got %s\n", wine_dbgstr_w(buffer) );
ok( size == sizeof(trueW)/sizeof(WCHAR), "wrong len %lu\n", size );
pReleaseActCtx(handle);
+
+ create_manifest_file( "manifest_settings2.manifest", settings_manifest2, -1, NULL, NULL );
+ handle = test_create("manifest_settings2.manifest");
+ ok( handle != INVALID_HANDLE_VALUE || broken( handle == INVALID_HANDLE_VALUE ), /* <= vista */
+ "handle == INVALID_HANDLE_VALUE, error %u\n", GetLastError() );
+ DeleteFileA( "manifest_settings2.manifest" );
+ if (handle != INVALID_HANDLE_VALUE)
+ {
+ SetLastError( 0xdeadbeef );
+ size = 0xdead;
+ memset( buffer, 0xcc, sizeof(buffer) );
+ ret = pQueryActCtxSettingsW( 0, handle, NULL, dpiAwareW, buffer, 80, &size );
+ ok( ret, "QueryActCtxSettingsW failed err %u\n", GetLastError() );
+ ok( !lstrcmpW( buffer, trueW ), "got %s\n", wine_dbgstr_w(buffer) );
+ ok( size == lstrlenW( buffer ) + 1, "wrong len %lu\n", size );
+ pReleaseActCtx(handle);
+ }
+
+ create_manifest_file( "manifest_settings3.manifest", settings_manifest3, -1, NULL, NULL );
+ handle = test_create("manifest_settings3.manifest");
+ ok( handle != INVALID_HANDLE_VALUE, "handle == INVALID_HANDLE_VALUE, error %u\n", GetLastError() );
+ DeleteFileA( "manifest_settings3.manifest" );
+ SetLastError( 0xdeadbeef );
+ size = 0xdead;
+ memset( buffer, 0xcc, sizeof(buffer) );
+ ret = pQueryActCtxSettingsW( 0, handle, NULL, dpiAwareW, buffer, 80, &size );
+ ok( !ret, "QueryActCtxSettingsW succeeded\n" );
+ ok( GetLastError() == ERROR_SXS_KEY_NOT_FOUND, "wrong error %u\n", GetLastError() );
+ pReleaseActCtx(handle);
}
START_TEST(actctx)
More information about the wine-cvs
mailing list