qt: Handle if gpg does not support tofu in test
[gpgme.git] / lang / python / tests / t-idiomatic.py
1 #!/usr/bin/env python
2
3 # Copyright (C) 2016 g10 Code GmbH
4 #
5 # This file is part of GPGME.
6 #
7 # GPGME is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 2 of the License, or
10 # (at your option) any later version.
11 #
12 # GPGME is distributed in the hope that it will be useful, but WITHOUT
13 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 # or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General
15 # Public License for more details.
16 #
17 # You should have received a copy of the GNU Lesser General Public
18 # License along with this program; if not, see <http://www.gnu.org/licenses/>.
19
20 from __future__ import absolute_import, print_function, unicode_literals
21 del absolute_import, print_function, unicode_literals
22
23 import sys
24 import io
25 import os
26 import tempfile
27 import gpg
28 import support
29
30 # Both Context and Data can be used as context manager:
31 with gpg.Context() as c, gpg.Data() as d:
32     c.get_engine_info()
33     d.write(b"Halloechen")
34     leak_c = c
35     leak_d = d
36 assert leak_c.wrapped == None
37 assert leak_d.wrapped == None
38
39 def sign_and_verify(source, signed, sink):
40     with gpg.Context() as c:
41         c.op_sign(source, signed, gpg.constants.sig.mode.NORMAL)
42         signed.seek(0, os.SEEK_SET)
43         c.op_verify(signed, None, sink)
44         result = c.op_verify_result()
45
46     assert len(result.signatures) == 1, "Unexpected number of signatures"
47     sig = result.signatures[0]
48     assert sig.summary == (gpg.constants.sigsum.VALID |
49                            gpg.constants.sigsum.GREEN)
50     assert gpg.errors.GPGMEError(sig.status).getcode() == gpg.errors.NO_ERROR
51
52     sink.seek(0, os.SEEK_SET)
53     assert sink.read() == b"Hallo Leute\n"
54
55 # Demonstrate automatic wrapping of file-like objects with 'fileno'
56 # method.
57 with tempfile.TemporaryFile() as source, \
58      tempfile.TemporaryFile() as signed, \
59      tempfile.TemporaryFile() as sink:
60     source.write(b"Hallo Leute\n")
61     source.seek(0, os.SEEK_SET)
62
63     sign_and_verify(source, signed, sink)
64
65 if sys.version_info[0] == 3:
66     # Python2's io.BytesIO does not implement the buffer interface,
67     # hence we cannot use it as sink.
68
69     # XXX: Python's io.BytesIo.truncate does not work as advertised.
70     # http://bugs.python.org/issue27261
71     bio = io.BytesIO()
72     bio.truncate(1)
73     if len(bio.getvalue()) != 1:
74         # This version of Python is affected, preallocate buffer.
75         preallocate = 128*b'\x00'
76     else:
77         preallocate = b''
78
79     # Demonstrate automatic wrapping of objects implementing the buffer
80     # interface, and the use of data objects with the 'with' statement.
81     with io.BytesIO(preallocate) as signed, gpg.Data() as sink:
82         sign_and_verify(b"Hallo Leute\n", signed, sink)