Versuch socket.io-Client-Knoten-Server verbinden ich keine Verbindung die folgende Fehlermeldung mit DEBUG = *Kann Socket.io-Client zum Server in Mokka Test
mocha:runner run suite Chat Server Message Events +1ms
Message Events
socket.io-client:url parse http://localhost:5000 +1s
socket.io-client ignoring socket cache for http://localhost:5000 +0ms
socket.io-client:manager readyState closed +1ms
socket.io-client:manager opening http://localhost:5000 +2ms
engine.io-client:socket creating transport "websocket" +1ms
engine.io-client:socket setting transport websocket +7ms
socket.io-client:manager connect attempt will timeout after 20000 +1ms
socket.io-client:manager readyState opening +1ms
engine.io-client:socket socket error
{"description":
{"code":"ENOENT",
"errno":"ENOENT",
"syscall":"connect",
"target":{"domain":null,
"_events":{},
"_maxListeners":10,
"_socket":null,
"_ultron":null,
"_closeReceived":false,
"bytesReceived":0,
"readyState":0,
"supports":{"binary":true},
"extensions":{},
"_isServer":false,
"url":"ws://localhost:5000/socket.io/?EIO=3&transport=websocket",
"protocolVersion":13,
"binaryType":"buffer"}}} +2ms
Diese Situation nicht passiert, wenn ich Verwenden Sie socket.io-client im Browser und verwenden Sie dieselbe Socket-Konfiguration. Hier
ist der Testcode:
var server = require('myServer');
var io = require('socket.io-client');
var url = 'http://localhost:5000';
var options = {
transports: ['websocket'],
'force new connection': true
};
var sender;
describe("Server Test", function() {
it('Should login user', function (done) {
sender = io(url, options);
});
});
Hier Servercode:
var express = require('express');
var app = express();
var server = require('http').Server(app);
var io = require('socket.io')(server);
io.on('connection', function (socket) {
console.log("connect");
});
server.listen(5000);
Server ordnungsgemäß funktioniert. Es zeigt eine Protokollmeldung an, wenn scoket.io-client vom Browser ausgeführt wird, aber nicht im Test.
Könnte mir jemand einen Hinweis geben, warum passiert das?