summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBerker Peksag <berker.peksag@gmail.com>2017-11-24 09:53:58 (GMT)
committerGitHub <noreply@github.com>2017-11-24 09:53:58 (GMT)
commit4864a619dc1cc9092780ccf5a6327e8abf66133d (patch)
tree379ff96504c78c9bd6d05d6c768c3e6cf16ee3a1
parentcdfe910e746e1d0fc43429b8cc3384a65a19b358 (diff)
downloadcpython-4864a619dc1cc9092780ccf5a6327e8abf66133d.zip
cpython-4864a619dc1cc9092780ccf5a6327e8abf66133d.tar.gz
cpython-4864a619dc1cc9092780ccf5a6327e8abf66133d.tar.bz2
bpo-12382: Make OpenDatabase() raise better exception messages (GH-4528)
Previously, 'msilib.OpenDatabase()' function raised a cryptical exception message when it couldn't open or create an MSI file. For example: Traceback (most recent call last): File "<stdin>", line 1, in <module> _msi.MSIError: unknown error 6e
-rw-r--r--Lib/test/test_msilib.py12
-rw-r--r--Misc/NEWS.d/next/Library/2017-11-23-21-47-36.bpo-12382.xWT9k0.rst2
-rw-r--r--PC/_msi.c6
3 files changed, 20 insertions, 0 deletions
diff --git a/Lib/test/test_msilib.py b/Lib/test/test_msilib.py
index 65ff386..4093134 100644
--- a/Lib/test/test_msilib.py
+++ b/Lib/test/test_msilib.py
@@ -1,4 +1,5 @@
""" Test suite for the code in msilib """
+import os.path
import unittest
from test.support import TESTFN, import_module, unlink
msilib = import_module('msilib')
@@ -41,6 +42,17 @@ class MsiDatabaseTestCase(unittest.TestCase):
)
self.addCleanup(unlink, db_path)
+ def test_database_open_failed(self):
+ with self.assertRaises(msilib.MSIError) as cm:
+ msilib.OpenDatabase('non-existent.msi', msilib.MSIDBOPEN_READONLY)
+ self.assertEqual(str(cm.exception), 'open failed')
+
+ def test_database_create_failed(self):
+ db_path = os.path.join(TESTFN, 'test.msi')
+ with self.assertRaises(msilib.MSIError) as cm:
+ msilib.OpenDatabase(db_path, msilib.MSIDBOPEN_CREATE)
+ self.assertEqual(str(cm.exception), 'create failed')
+
class Test_make_id(unittest.TestCase):
#http://msdn.microsoft.com/en-us/library/aa369212(v=vs.85).aspx
diff --git a/Misc/NEWS.d/next/Library/2017-11-23-21-47-36.bpo-12382.xWT9k0.rst b/Misc/NEWS.d/next/Library/2017-11-23-21-47-36.bpo-12382.xWT9k0.rst
new file mode 100644
index 0000000..d9b5425
--- /dev/null
+++ b/Misc/NEWS.d/next/Library/2017-11-23-21-47-36.bpo-12382.xWT9k0.rst
@@ -0,0 +1,2 @@
+:func:`msilib.OpenDatabase` now raises a better exception message when it
+couldn't open or create an MSI file. Initial patch by William Tisäter.
diff --git a/PC/_msi.c b/PC/_msi.c
index a6a12e2..8cc1fd5 100644
--- a/PC/_msi.c
+++ b/PC/_msi.c
@@ -315,6 +315,12 @@ msierror(int status)
case ERROR_INVALID_PARAMETER:
PyErr_SetString(MSIError, "invalid parameter");
return NULL;
+ case ERROR_OPEN_FAILED:
+ PyErr_SetString(MSIError, "open failed");
+ return NULL;
+ case ERROR_CREATE_FAILED:
+ PyErr_SetString(MSIError, "create failed");
+ return NULL;
default:
PyErr_Format(MSIError, "unknown error %x", status);
return NULL;