【发布时间】:2018-04-01 22:24:49
【问题描述】:
我使用 socket.io 库制作了一个简单的示例应用程序,现在我想测试我的 io.on("connection") 在客户端连接时是否被调用。
所以我在我的单元测试中创建了一个简单的假客户端,它成功连接到服务器,但是监视由io.on("connection") 触发的方法handleSocket 的间谍说它从未被触发过,这显然是根据日志。
这可能是我无法弄清楚的时间/异步问题。
服务器端代码:
const express = require("express");
const app = express();
const port = process.env["PORT"] || 3030;
var io = require("socket.io").listen(port);
io.on("connect", socket => handleSocket(socket));
function handleSocket(socket) {
console.log("a user connected", socket.id);
}
exports.io = io;
exports.handleSocket = handleSocket;
mocha 中的实际单元测试:
var expect = require("chai").expect;
var sinon = require("sinon");
var ioClient = require("socket.io-client");
process.env["PORT"] = 3030;
process.env["VERBOSE"] = true;
var options = {
transports: ["websocket"],
"force new connection": false
};
describe("server.spec", function() {
this.timeout(5000);
it("Client should connect", function(done) {
app = require("./server2");
let spy = sinon.spy(app.handleSocket);
var client = ioClient.connect("http://localhost:" + process.env["PORT"], options);
client.on("connect", function() {
expect(spy.called).to.be.equal(true);
client.disconnect();
app.io.close();
done();
});
});
});
测试 - 失败,spy.call 等于 false 日志输出:
server.spec
a user connected jopFRhcfzjkC_TjsAAAA
Spy was called: false
1) Client should connect
a user connected uIpW2gsiljJkS4wFAAAB
Spy was called: false
【问题讨论】:
标签: node.js unit-testing socket.io mocha.js