aboutsummaryrefslogtreecommitdiffstats
path: root/lang/js/BrowserTestExtension/tests/encryptTest.js
blob: ccdb4994d25e4897cdee71a56936d3da8209f643 (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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/* 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, expect, before, Gpgmejs */
/* global inputvalues, fixedLengthString */

describe('Encryption', 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('Successful encrypt', function (done) {
        const data = inputvalues.encrypt.good.data;
        context.encrypt({ data: data, publicKeys: good_fpr })
            .then(function (answer) {
                expect(answer).to.not.be.empty;
                expect(answer.data).to.be.a('string');
                expect(answer.data).to.include('BEGIN PGP MESSAGE');
                expect(answer.data).to.include('END PGP MESSAGE');
                done();
            });
    });

    const sizes = [5,20,50];
    for (let i=0; i < sizes.length; i++) {
        it('Successful encrypt a ' + sizes[i] + 'MB message', function (done) {
            const data = fixedLengthString(sizes[i]);
            context.encrypt({ data: data, publicKeys: good_fpr })
                .then(function (answer) {
                    expect(answer).to.not.be.empty;
                    expect(answer.data).to.be.a('string');
                    expect(answer.data).to.include('BEGIN PGP MESSAGE');
                    expect(answer.data).to.include('END PGP MESSAGE');
                    done();
                });
        }).timeout(20000);
    }

    it('Sending encryption without keys fails', function (done) {
        const data = inputvalues.encrypt.good.data;
        context.encrypt({ data: data }).then(function (answer) {
            expect(answer).to.be.undefined;
        }, function (error){
            expect(error).to.be.an('Error');
            expect(error.code).to.equal('MSG_INCOMPLETE');
            done();
        });
    });

    it('Sending encryption without data fails', function (done) {
        context.encrypt({ data: null, publicKeys: good_fpr })
            .then(function (answer) {
                expect(answer).to.be.undefined;
            }, function (error) {
                expect(error).to.be.an.instanceof(Error);
                expect(error.code).to.equal('MSG_INCOMPLETE');
                done();
            });
    });

    it('Sending encryption with non existing keys fails', function (done) {
        const data = inputvalues.encrypt.good.data;
        const bad_fpr = inputvalues.encrypt.bad.fingerprint;
        context.encrypt({ data:data, publicKeys: bad_fpr })
            .then(function (answer) {
                expect(answer).to.be.undefined;
            }, function (error){
                expect(error).to.be.an('Error');
                expect(error.code).to.not.be.undefined;
                expect(error.code).to.equal('GNUPG_ERROR');
                done();
            });
    }).timeout(5000);

    it('Overly large message ( > 64MB) is rejected', function (done) {
        const data = fixedLengthString(65);
        context.encrypt({ data: data, publicKeys: good_fpr })
            .then(function (answer) {
                expect(answer).to.be.undefined;
            }, function (error){
                expect(error).to.be.an.instanceof(Error);
                // TODO: there is a 64 MB hard limit at least in chrome at:
                // chromium//extensions/renderer/messaging_util.cc:
                // kMaxMessageLength
                // The error will be a browser error, not from gnupg or from
                // this library
                done();
            });
    }).timeout(8000);

    // TODO check different valid parameter
});