aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBen McGinnes <[email protected]>2018-10-20 00:07:55 +0000
committerBen McGinnes <[email protected]>2018-10-20 00:07:55 +0000
commit651a1afe80bcc421da26f38015e8a322e140f130 (patch)
tree22e62fb877ab0c6a0d1e4fde9cf39a16581304a1
parentcore: Fix segv in genkey when no endtag is provided. (diff)
downloadgpgme-651a1afe80bcc421da26f38015e8a322e140f130.tar.gz
gpgme-651a1afe80bcc421da26f38015e8a322e140f130.zip
python bindings: callback test
* lang/python/tests/t-callbacks.py: Updated test logic to try generating a key which expires in 2099 and if that fails then fallback to an expiration in 2037 in an attempt to catch the 32-bit systems.
-rwxr-xr-xlang/python/tests/t-callbacks.py32
1 files changed, 30 insertions, 2 deletions
diff --git a/lang/python/tests/t-callbacks.py b/lang/python/tests/t-callbacks.py
index 5bcac237..3a210dd0 100755
--- a/lang/python/tests/t-callbacks.py
+++ b/lang/python/tests/t-callbacks.py
@@ -20,12 +20,14 @@
from __future__ import absolute_import, print_function, unicode_literals
import os
+import platform
import gpg
import support
_ = support # to appease pyflakes.
del absolute_import, print_function, unicode_literals
+oops = None
c = gpg.Context()
c.set_pinentry_mode(gpg.constants.PINENTRY_MODE_LOOPBACK)
@@ -99,6 +101,17 @@ Expire-Date: 2099-12-31
</GnupgKeyParms>
"""
+prams = """<GnupgKeyParms format="internal">
+Key-Type: RSA
+Key-Length: 1024
+Name-Real: Joe Tester
+Name-Comment: with stupid passphrase
+Name-Email: [email protected]
+Passphrase: Crypt0R0cks
+Expire-Date: 2037-12-31
+</GnupgKeyParms>
+"""
+
messages = []
@@ -111,7 +124,10 @@ def progress_cb(what, typ, current, total, hook=None):
c = gpg.Context()
c.set_progress_cb(progress_cb, messages)
-c.op_genkey(parms, None, None)
+try:
+ c.op_genkey(parms, None, None)
+except Exception as oops:
+ c.op_genkey(prams, None, None)
assert len(messages) > 0
@@ -123,7 +139,10 @@ def progress_cb(what, typ, current, total, hook=None):
c = gpg.Context()
c.set_progress_cb(progress_cb, None)
try:
- c.op_genkey(parms, None, None)
+ try:
+ c.op_genkey(parms, None, None)
+ except Exception as oops:
+ c.op_genkey(prams, None, None)
except Exception as e:
assert e == myException
else:
@@ -139,6 +158,15 @@ alpha = c.get_key("A0FF4590BB6122EDEF6E3C542D727CC768697734", False)
cookie = object()
edit_cb_called = False
+def oops_check():
+ if oops is not None and platform.architecture()[0] != "64bit":
+ y2k38_msg = "System appears to be 32-bit and vulnerable to EOL in 2038."
+ elif oops is not None and platform.architecture()[0] == "64bit":
+ y2k38_msg = "System appears to be 64-bit, but may use 32-bit time."
+ else:
+ y2k38_msg = "System is 64-bit and/or not susceptible to 2038 EOL."
+ return y2k38_msg
+
def edit_cb(status, args, hook):
global edit_cb_called