python: Add an idiomatic interface.
[gpgme.git] / lang / python / tests / t-idiomatic.py
1 #!/usr/bin/env python3
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 import io
21 import os
22 import tempfile
23 import pyme
24 import support
25
26 support.init_gpgme(pyme.constants.PROTOCOL_OpenPGP)
27
28 # Both Context and Data can be used as context manager:
29 with pyme.Context() as c, pyme.Data() as d:
30     c.get_engine_info()
31     d.write(b"Halloechen")
32     leak_c = c
33     leak_d = d
34 assert leak_c.wrapped == None
35 assert leak_d.wrapped == None
36
37 def sign_and_verify(source, signed, sink):
38     with pyme.Context() as c:
39         c.op_sign(source, signed, pyme.constants.SIG_MODE_NORMAL)
40         signed.seek(0, os.SEEK_SET)
41         c.op_verify(signed, None, sink)
42         result = c.op_verify_result()
43
44     assert len(result.signatures) == 1, "Unexpected number of signatures"
45     sig = result.signatures[0]
46     assert sig.summary == (pyme.constants.SIGSUM_VALID |
47                            pyme.constants.SIGSUM_GREEN)
48     assert pyme.errors.GPGMEError(sig.status).getcode() == pyme.errors.NO_ERROR
49
50     sink.seek(0, os.SEEK_SET)
51     assert sink.read() == b"Hallo Leute\n"
52
53 # Demonstrate automatic wrapping of file-like objects with 'fileno'
54 # method.
55 with tempfile.TemporaryFile() as source, \
56      tempfile.TemporaryFile() as signed, \
57      tempfile.TemporaryFile() as sink:
58     source.write(b"Hallo Leute\n")
59     source.seek(0, os.SEEK_SET)
60
61     sign_and_verify(source, signed, sink)
62
63 # XXX: Python's io.BytesIo.truncate does not work as advertised.
64 # http://bugs.python.org/issue27261
65 bio = io.BytesIO()
66 bio.truncate(1)
67 if len(bio.getvalue()) != 1:
68     # This version of Python is affected, preallocate buffer.
69     preallocate = 128*b'\x00'
70 else:
71     preallocate = b''
72
73 # Demonstrate automatic wrapping of objects implementing the buffer
74 # interface, and the use of data objects with the 'with' statement.
75 with io.BytesIO(preallocate) as signed, pyme.Data() as sink:
76     sign_and_verify(b"Hallo Leute\n", signed, sink)