8852cb6a0d308650352f9a55720d59f21edb1195
[gpgme.git] / lang / js / BrowserTestExtension / tests / decryptTest.js
1 /* gpgme.js - Javascript integration for gpgme
2  * Copyright (C) 2018 Bundesamt für Sicherheit in der Informationstechnik
3  *
4  * This file is part of GPGME.
5  *
6  * GPGME is free software; you can redistribute it and/or modify it
7  * under the terms of the GNU Lesser General Public License as
8  * published by the Free Software Foundation; either version 2.1 of
9  * the License, or (at your option) any later version.
10  *
11  * GPGME is distributed in the hope that it will be useful, but
12  * WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this program; if not, see <http://www.gnu.org/licenses/>.
18  * SPDX-License-Identifier: LGPL-2.1+
19  *
20  * Author(s):
21  *     Maximilian Krambach <mkrambach@intevation.de>
22  */
23
24 /* global describe, it, before, expect, Gpgmejs */
25 /* global bigString, inputvalues, sabotageMsg*/
26
27 describe('Decryption', function () {
28     let context = null;
29     const good_fpr = inputvalues.encrypt.good.fingerprint;
30
31     before(function (done){
32         const prm = Gpgmejs.init();
33         prm.then(function (gpgmejs){
34             context = gpgmejs;
35             done();
36         });
37     });
38
39     it('Decryption of random string fails', function (done) {
40         let data = bigString(20 * 1024);
41         context.decrypt({ data: data }).then(
42             function (){},
43             function (error){
44                 expect(error).to.be.an('error');
45                 expect(error.code).to.equal('GNUPG_ERROR');
46                 done();
47             });
48     });
49
50     it('Decryption of slightly corrupted message fails', function (done) {
51         const data = bigString(10000);
52         context.encrypt({ data: data, publicKeys:good_fpr }).then(
53             function (enc){
54                 context.decrypt({ data: sabotageMsg(enc.data) }).then(
55                     function (){},
56                     function (error){
57                         expect(error).to.be.an('error');
58                         expect(error.code).to.equal('GNUPG_ERROR');
59                         done();
60                     });
61             });
62     }).timeout(5000);
63
64
65     it('decrypt/verify operations return proper information', function (done){
66         const data = inputvalues.encryptSignedMessage;
67         context.decrypt({ data: data }).then(function (result){
68             expect(result).to.be.an('object');
69             expect(result.signatures).to.be.an('object');
70             expect(result.signatures.all_valid).to.be.true;
71             expect(result.signatures.count).to.equal(1);
72             expect(result.signatures.signatures.good).to.be.an('array');
73             expect(
74                 result.signatures.signatures.good[0].fingerprint).to.equal(
75                 good_fpr);
76             done();
77         });
78     });
79 });