2016-08-03 20 views
2

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?

Antwort

0

Da Sie testen, haben Sie wahrscheinlich global.window in einer Nodejs-Umgebung definiert. Und this Codezeile erwartet nicht, dass es bei allen

sollten Sie entweder global.window Objekt entfernen oder so etwas wie global.WebSocket = require('ws'); schreiben oder entfernen transports: ['websocket']