Detlef Riekenberg : msi/tests: Run tests again with older msi versions ( MsiApplyMultiplePatchesA).

Alexandre Julliard julliard at winehq.org
Tue May 5 09:12:52 CDT 2009


Module: wine
Branch: master
Commit: a31e9a1bfa509bbd96c0c4fc4be95c7412e9766e
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=a31e9a1bfa509bbd96c0c4fc4be95c7412e9766e

Author: Detlef Riekenberg <wine.dev at web.de>
Date:   Mon May  4 23:08:52 2009 +0200

msi/tests: Run tests again with older msi versions (MsiApplyMultiplePatchesA).

---

 dlls/msi/tests/package.c |   29 ++++++++++++++++++++---------
 1 files changed, 20 insertions(+), 9 deletions(-)

diff --git a/dlls/msi/tests/package.c b/dlls/msi/tests/package.c
index 82b7110..a7e5261 100644
--- a/dlls/msi/tests/package.c
+++ b/dlls/msi/tests/package.c
@@ -32,6 +32,8 @@
 static const char msifile[] = "winetest.msi";
 char CURR_DIR[MAX_PATH];
 
+static UINT (WINAPI *pMsiApplyMultiplePatchesA)(LPCSTR, LPCSTR, LPCSTR);
+
 static void get_user_sid(LPSTR *usersid)
 {
     HANDLE token;
@@ -11537,13 +11539,18 @@ static void test_MsiApplyMultiplePatches(void)
 {
     UINT r, type = GetDriveType(NULL);
 
-    r = MsiApplyMultiplePatchesA(NULL, NULL, NULL);
+    if (!pMsiApplyMultiplePatchesA) {
+        win_skip("MsiApplyMultiplePatchesA not found\n");
+        return;
+    }
+
+    r = pMsiApplyMultiplePatchesA(NULL, NULL, NULL);
     ok(r == ERROR_INVALID_PARAMETER, "Expected ERROR_INVALID_PARAMETER, got %u\n", r);
 
-    r = MsiApplyMultiplePatchesA("", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA("", NULL, NULL);
     ok(r == ERROR_INVALID_PARAMETER, "Expected ERROR_INVALID_PARAMETER, got %u\n", r);
 
-    r = MsiApplyMultiplePatchesA(";", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA(";", NULL, NULL);
     todo_wine
     {
         if (type == DRIVE_FIXED)
@@ -11554,7 +11561,7 @@ static void test_MsiApplyMultiplePatches(void)
                "Expected ERROR_INVALID_NAME, got %u\n", r);
     }
 
-    r = MsiApplyMultiplePatchesA("  ;", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA("  ;", NULL, NULL);
     todo_wine
     {
         if (type == DRIVE_FIXED)
@@ -11565,7 +11572,7 @@ static void test_MsiApplyMultiplePatches(void)
                "Expected ERROR_INVALID_NAME, got %u\n", r);
     }
 
-    r = MsiApplyMultiplePatchesA(";;", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA(";;", NULL, NULL);
     todo_wine
     {
         if (type == DRIVE_FIXED)
@@ -11576,10 +11583,10 @@ static void test_MsiApplyMultiplePatches(void)
                "Expected ERROR_INVALID_NAME, got %u\n", r);
     }
 
-    r = MsiApplyMultiplePatchesA("nosuchpatchpackage;", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA("nosuchpatchpackage;", NULL, NULL);
     todo_wine ok(r == ERROR_FILE_NOT_FOUND, "Expected ERROR_FILE_NOT_FOUND, got %u\n", r);
 
-    r = MsiApplyMultiplePatchesA(";nosuchpatchpackage", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA(";nosuchpatchpackage", NULL, NULL);
     todo_wine
     {
         if (type == DRIVE_FIXED)
@@ -11590,15 +11597,19 @@ static void test_MsiApplyMultiplePatches(void)
                "Expected ERROR_INVALID_NAME, got %u\n", r);
     }
 
-    r = MsiApplyMultiplePatchesA("nosuchpatchpackage;nosuchpatchpackage", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA("nosuchpatchpackage;nosuchpatchpackage", NULL, NULL);
     todo_wine ok(r == ERROR_FILE_NOT_FOUND, "Expected ERROR_FILE_NOT_FOUND, got %u\n", r);
 
-    r = MsiApplyMultiplePatchesA("  nosuchpatchpackage  ;  nosuchpatchpackage  ", NULL, NULL);
+    r = pMsiApplyMultiplePatchesA("  nosuchpatchpackage  ;  nosuchpatchpackage  ", NULL, NULL);
     todo_wine ok(r == ERROR_FILE_NOT_FOUND, "Expected ERROR_FILE_NOT_FOUND, got %u\n", r);
 }
 
 START_TEST(package)
 {
+    HMODULE hmsi = GetModuleHandleA("msi.dll");
+
+    pMsiApplyMultiplePatchesA = (void *)GetProcAddress(hmsi, "MsiApplyMultiplePatchesA");
+
     GetCurrentDirectoryA(MAX_PATH, CURR_DIR);
 
     test_createpackage();




More information about the wine-cvs mailing list