• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

suculent / thinx-device-api / #252646770

01 Nov 2025 03:54PM UTC coverage: 71.849% (+25.6%) from 46.298%
#252646770

push

suculent
testing fixed broker URL configuration after MQTT upgrade

1867 of 3538 branches covered (52.77%)

Branch coverage included in aggregate %.

27 of 38 new or added lines in 1 file covered. (71.05%)

20 existing lines in 10 files now uncovered.

8212 of 10490 relevant lines covered (78.28%)

7.49 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

98.53
/spec/jasmine/ZZ-RouterRSAKeySpec.js
1
/* Router integration test only; does not have to cover full unit functionality. */
2

3
const THiNX = require("../../thinx-core.js");
1✔
4

5
let chai = require('chai');
1✔
6
var expect = require('chai').expect;
1✔
7
let chaiHttp = require('chai-http');
1✔
8
chai.use(chaiHttp);
1✔
9

10
let thx;
11

12
describe("RSA Keys (noauth)", function () {
1✔
13

14
    beforeAll((done) => {
1✔
15
        thx = new THiNX();
1✔
16
        thx.init(() => {
1✔
17
            done();
1✔
18
        });
19
    });
20

21
    it("GET /api/user/rsakey/create", function (done) {
1✔
22
        chai.request(thx.app)
1✔
23
            .get('/api/user/rsakey/create')
24
            .end((err, res) => {
25
                expect(res.status).to.equal(401);
1✔
26
                done();
1✔
27
            });
28
    }, 30000);
29

30
    it("GET /api/user/rsakey/list", function (done) {
1✔
31
        chai.request(thx.app)
1✔
32
            .get('/api/user/rsakey/list')
33
            .end((err, res) => {
34
                expect(res.status).to.equal(401);
1✔
35
                done();
1✔
36
            });
37
    }, 30000);
38

39
    it("POST /api/user/rsakey/revoke (noauth, invalid)", function (done) {
1✔
40
        chai.request(thx.app)
1✔
41
            .post('/api/user/rsakey/revoke')
42
            .send()
43
            .end((err, res) => {
44
                expect(res.status).to.equal(401);
1✔
45
                done();
1✔
46
            });
47
    }, 30000);
48

49
});
50

51
describe("RSA Keys (JWT)", function () {
1✔
52

53
    let agent;
54
    let jwt;
55
  
56
    beforeAll((done) => {
1✔
57
        agent = chai.request.agent(thx.app);
1✔
58
        agent
1✔
59
            .post('/api/login')
60
            .send({ username: 'dynamic', password: 'dynamic', remember: false })
61
            .then(function (res) {
62
                expect(res).to.have.cookie('x-thx-core');
1✔
63
                let body = JSON.parse(res.text);
1✔
64
                jwt = 'Bearer ' + body.access_token;
1✔
65
                done();
1✔
66
            })
UNCOV
67
            .catch((e) => { console.log(e); });
×
68
    });
69
  
70
    afterAll((done) => {
1✔
71
        agent.close();
1✔
72
        done();
1✔
73
    });
74

75
    let key_id = null;
1✔
76

77
    it("GET /api/user/rsakey/create", function (done) {
1✔
78
        chai.request(thx.app)
1✔
79
            .get('/api/user/rsakey/create')
80
            .set('Authorization', jwt)
81
            .end((err, res) => {
82
                expect(res.status).to.equal(200);
1✔
83
                let j = JSON.parse(res.text);
1✔
84
                expect(j.success).to.equal(true);
1✔
85
                let k = j.response;
1✔
86
                expect(k).to.be.an('object');
1✔
87
                expect(k.name).to.be.a('number');
1✔
88
                expect(k.pubkey).to.be.a('string');
1✔
89
                
90
                done();
1✔
91
            });
92
    }, 30000);
93

94
    it("GET /api/user/rsakey/list", function (done) {
1✔
95
        chai.request(thx.app)
1✔
96
            .get('/api/user/rsakey/list')
97
            .set('Authorization', jwt)
98
            .end((err, res) => {
99
                console.log("🚸 [chai] GET /api/user/rsakey/list response:", res.text, res.status);
1✔
100
                let r = JSON.parse(res.text);
1✔
101
                key_id = r.response[0].filename;
1✔
102
                expect(res.status).to.equal(200);
1✔
103
                expect(res.text).to.be.a('string');
1✔
104
                done();
1✔
105
            });
106
    }, 30000);
107

108
    it("POST /api/user/rsakey/revoke (jwt, undefined)", function (done) {
1✔
109
        chai.request(thx.app)
1✔
110
            .post('/api/user/rsakey/revoke')
111
            .set('Authorization', jwt)
112
            .send()
113
            .end((err, res) => {
114
                expect(res.status).to.equal(400);
1✔
115
                expect(res.text).to.be.a('string');
1✔
116
                expect(res.text).to.equal('{"success":false,"response":"invalid_body"}');
1✔
117
                done();
1✔
118
            });
119
    }, 30000);
120

121
    it("POST /api/user/rsakey/revoke (valid)", function (done) {
1✔
122
        console.log("🚸 [chai] POST /api/user/rsakey/revoke (valid)");
1✔
123
        chai.request(thx.app)
1✔
124
            .post('/api/user/rsakey/revoke')
125
            .set('Authorization', jwt)
126
            .send({ filenames: [key_id]})
127
            .end((err, res) => {
128
                console.log("🚸 [chai] POST /api/user/rsakey/revoke (valid) response:", res.text, res.status);
1✔
129
                expect(res.status).to.equal(200);
1✔
130
                let j = JSON.parse(res.text);
1✔
131
                expect(j.success).to.equal(true);
1✔
132
                expect(j.response).to.be.an('array');
1✔
133
                done();
1✔
134
            });
135
    }, 30000);
136
});
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc