Hans Leidekker : msi: Reject NULL or empty patch package parameter in MsiApplyPatch.

Alexandre Julliard julliard at winehq.org
Wed May 6 10:33:16 CDT 2009


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

Author: Hans Leidekker <hans at codeweavers.com>
Date:   Wed May  6 15:57:22 2009 +0200

msi: Reject NULL or empty patch package parameter in MsiApplyPatch.

---

 dlls/msi/msi.c           |    3 +++
 dlls/msi/tests/package.c |   12 ++++++++++++
 2 files changed, 15 insertions(+), 0 deletions(-)

diff --git a/dlls/msi/msi.c b/dlls/msi/msi.c
index 58a1856..ed8b4ab 100644
--- a/dlls/msi/msi.c
+++ b/dlls/msi/msi.c
@@ -315,6 +315,9 @@ static UINT MSI_ApplyPatchW(LPCWSTR szPatchPackage, LPCWSTR szProductCode, LPCWS
     static const WCHAR patcheq[] = {'P','A','T','C','H','=',0};
     static WCHAR empty[] = {0};
 
+    if (!szPatchPackage || !szPatchPackage[0])
+        return ERROR_INVALID_PARAMETER;
+
     if (!szProductCode)
     {
         r = MsiOpenDatabaseW(szPatchPackage, MSIDBOPEN_READONLY, &patch);
diff --git a/dlls/msi/tests/package.c b/dlls/msi/tests/package.c
index a7e5261..308a9cc 100644
--- a/dlls/msi/tests/package.c
+++ b/dlls/msi/tests/package.c
@@ -11604,6 +11604,17 @@ static void test_MsiApplyMultiplePatches(void)
     todo_wine ok(r == ERROR_FILE_NOT_FOUND, "Expected ERROR_FILE_NOT_FOUND, got %u\n", r);
 }
 
+static void test_MsiApplyPatch(void)
+{
+    UINT r;
+
+    r = MsiApplyPatch(NULL, NULL, INSTALLTYPE_DEFAULT, NULL);
+    ok(r == ERROR_INVALID_PARAMETER, "Expected ERROR_INVALID_PARAMETER, got %u\n", r);
+
+    r = MsiApplyPatch("", NULL, INSTALLTYPE_DEFAULT, NULL);
+    ok(r == ERROR_INVALID_PARAMETER, "Expected ERROR_INVALID_PARAMETER, got %u\n", r);
+}
+
 START_TEST(package)
 {
     HMODULE hmsi = GetModuleHandleA("msi.dll");
@@ -11642,4 +11653,5 @@ START_TEST(package)
     test_MsiGetProductProperty();
     test_MsiSetProperty();
     test_MsiApplyMultiplePatches();
+    test_MsiApplyPatch();
 }




More information about the wine-cvs mailing list