802a32da0fb1131b4d3f046d0f3c12d61a0a833b
[gpgme.git] / lang / python / tests / t-sign.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 sys
21 import os
22 import pyme
23 from pyme import core, constants
24 import support
25
26 def fail(msg):
27     raise RuntimeError(msg)
28
29 def check_result(r, typ):
30     if r.invalid_signers:
31         fail("Invalid signer found: {}".format(r.invalid_signers.fpr))
32
33     if len(r.signatures) != 1:
34         fail("Unexpected number of signatures created")
35
36     signature = r.signatures[0]
37     if signature.type != typ:
38         fail("Wrong type of signature created")
39
40     if signature.pubkey_algo != constants.PK_DSA:
41         fail("Wrong pubkey algorithm reported: {}".format(
42             signature.pubkey_algo))
43
44     if signature.hash_algo != constants.MD_SHA1:
45         fail("Wrong hash algorithm reported: {}".format(
46             signature.hash_algo))
47
48     if signature.sig_class != 1:
49         fail("Wrong signature class reported: {}".format(
50             signature.sig_class))
51
52     if signature.fpr != "A0FF4590BB6122EDEF6E3C542D727CC768697734":
53         fail("Wrong fingerprint reported: {}".format(signature.fpr))
54
55
56 support.init_gpgme(constants.PROTOCOL_OpenPGP)
57 c = core.Context()
58 c.set_textmode(True)
59 c.set_armor(True)
60
61 source = core.Data("Hallo Leute\n")
62 sink = core.Data()
63
64 c.op_sign(source, sink, constants.SIG_MODE_NORMAL)
65
66 result = c.op_sign_result()
67 check_result(result, constants.SIG_MODE_NORMAL)
68 support.print_data(sink)
69
70 # Now a detached signature.
71 source.seek(0, os.SEEK_SET)
72 sink = core.Data()
73
74 c.op_sign(source, sink, constants.SIG_MODE_DETACH)
75
76 result = c.op_sign_result()
77 check_result(result, constants.SIG_MODE_DETACH)
78 support.print_data(sink)
79
80 # And finally a cleartext signature.  */
81 source.seek(0, os.SEEK_SET)
82 sink = core.Data()
83
84 c.op_sign(source, sink, constants.SIG_MODE_CLEAR)
85
86 result = c.op_sign_result()
87 check_result(result, constants.SIG_MODE_CLEAR)
88 support.print_data(sink)
89
90 # Idiomatic interface.
91 with pyme.Context(armor=True, textmode=True) as c:
92     message = "Hallo Leute\n".encode()
93     signed, _ = c.sign(message)
94     assert len(signed) > 0
95     assert signed.find(b'BEGIN PGP MESSAGE') > 0, 'Message not found'
96
97     signed, _ = c.sign(message, mode=pyme.constants.SIG_MODE_DETACH)
98     assert len(signed) > 0
99     assert signed.find(b'BEGIN PGP SIGNATURE') > 0, 'Signature not found'
100
101     signed, _ = c.sign(message, mode=pyme.constants.SIG_MODE_CLEAR)
102     assert len(signed) > 0
103     assert signed.find(b'BEGIN PGP SIGNED MESSAGE') > 0, 'Message not found'
104     assert signed.find(message) > 0, 'Message content not found'
105     assert signed.find(b'BEGIN PGP SIGNATURE') > 0, 'Signature not found'
106
107 with pyme.Context() as c:
108     message = "Hallo Leute\n".encode()
109
110     c.signers = [c.get_key(support.sign_only, True)]
111     c.sign(message)
112
113     c.signers = [c.get_key(support.encrypt_only, True)]
114     try:
115         c.sign(message)
116     except pyme.errors.InvalidSigners as e:
117         assert len(e.signers) == 1
118         assert support.encrypt_only.endswith(e.signers[0].fpr)
119     else:
120         assert False, "Expected an InvalidSigners error, got none"