使用frisby.js或jasmine节点测试证书过期

Testing certificate expiration with frisby.js or jasmine-node

本文关键字:测试 证书 过期 节点 jasmine frisby js 使用      更新时间:2023-09-26

我正在尝试用frisby.js编写一个测试用例,用于检查证书的状态。测试应在证书到期前n天失败,其中n在中定义

config.numberOfDaysBeforeTestFails

我用这个代码试过了:

var frisby = require('frisby');
var config = require('../config');  //load own config-file
var request = require('request');
frisby.create('https2.0 - Perperation')
 .get(config.server + '/testData')
 .auth(config.username, config.passwort)
 .after(function(err, res, body){
    var auth = "Basic " + new Buffer(config.username + ":" + config.passwort).toString("base64");
    var r = request({
        url: '<serverURL>',
        requestCert: true,
        rejectUnauthorized: false,
        headers : {
            "Authorization" : auth
        }
    });
    r.on('response', function(res) {
        var certificateInformation = res.req.connection.getPeerCertificate();
        var certificateDate = new Date(Date.parse(certificateInformation.valid_to));
        var todayDate = new Date();
        todayDate.setDate(todayDate.getDate() + config.numberOfDaysBeforeTestFails);
        //Below does not get executed
        expect(todayDate < certificateDate).toBe(true);
    });
})
.toss();

问题是,期望没有得到jasmine节点testrunner的验证。使用执行此代码

jasmine-node ./https_spec.js

将导致:

Finished in 0.358 seconds
1 test, 0 assertions, 0 failures, 0 skipped

所以断言

expect(todayDate < certificateDate).toBe(true);

没有被执行。我认为,这是因为nodejs执行代码async,因此测试在执行断言之前结束。

有人知道,我如何才能强制执行这个断言并进入测试结果?

谢谢和问候,Jo

我没有找到一个基于frisby.js的解决方案,但使用异步支持的标准jasmine语法,它似乎可以工作。由于frisby测试是由jasmine节点运行器执行的,所以我可以将其与其他frisby检测一起执行。

var request = require('request');    
var config = require('../config');  //load own config-file for global settings
describe("https 2.0", function() {
 it("Certificate Test", function(done) {
    var auth = "Basic " + new Buffer(config.username + ":" + config.passwort).toString("base64");
    var r = request({
        url: config.server,
        requestCert: true,
        rejectUnauthorized: false,
        headers : {
            "Authorization" : auth
        }
    });
    r.on('response', function(res) {
        var certificateInformation = res.req.connection.getPeerCertificate();
        var certificateDate = new Date(Date.parse(certificateInformation.valid_to));
        var todayDate = new Date();
        todayDate.setDate(todayDate.getDate() + config.numberOfDaysBeforeTestFails);
        expect(todayDate).toBeLessThan(certificateDate);
        done();
    });
  });
});