aboutsummaryrefslogtreecommitdiffstats
path: root/lang/js/BrowserTestExtension/tests/decryptTest.js
blob: a3f48daaf5dd7e0c39c8b727da9930077154a886 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/* gpgme.js - Javascript integration for gpgme
 * Copyright (C) 2018 Bundesamt für Sicherheit in der Informationstechnik
 *
 * This file is part of GPGME.
 *
 * GPGME is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 2.1 of
 * the License, or (at your option) any later version.
 *
 * GPGME is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this program; if not, see <http://www.gnu.org/licenses/>.
 * SPDX-License-Identifier: LGPL-2.1+
 *
 * Author(s):
 *     Maximilian Krambach <[email protected]>
 */

/* global describe, it, before, expect, Gpgmejs */
/* global bigString, inputvalues, sabotageMsg*/

describe('Decryption', function () {
    let context = null;
    const good_fpr = inputvalues.encrypt.good.fingerprint;

    before(function (done){
        const prm = Gpgmejs.init();
        prm.then(function (gpgmejs){
            context = gpgmejs;
            done();
        });
    });

    it('Decryption of random string fails', function (done) {
        let data = bigString(20 * 1024);
        context.decrypt(data).then(
            function (){},
            function (error){
                expect(error).to.be.an('error');
                expect(error.code).to.equal('GNUPG_ERROR');
                done();
            });
    });

    it('Decryption of slightly corrupted message fails', function (done) {
        const data = bigString(10000);
        context.encrypt(data, good_fpr).then(function (enc){
            context.decrypt(sabotageMsg(enc.data)).then(
                function (){},
                function (error){
                    expect(error).to.be.an('error');
                    expect(error.code).to.equal('GNUPG_ERROR');
                    done();
                });
        });
    }).timeout(5000);
});