使用 Jasmine 测试 Web 套接字

Testing Web Sockets with Jasmine(使用 Jasmine 测试 Web 套接字)
本文介绍了使用 Jasmine 测试 Web 套接字的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

这是一些使用 stomp 协议为 web-socket 编写的代码.

Here is some code that has been written for web-socket using stomp protocol.

function WS(url) {
    var ws = new SockJS('/notifications');

    this.client = Stomp.over(ws),

    this.client.connect('', '', function() {
        console.log('Connected');
    }, function(error) {
        console.log('STOMP protocol error: ', error.headers.message);
    });
}

WS.prototype.disconnect = function() {
};

WS.prototype.subscribe = function() {
};

WS.prototype.unSubscribe = function() {
};

WS.prototype.send = function(msg) {
};

我找到了这篇文章,但它需要实际连接到服务器,单元测试Node.js和WebSockets (Socket.io)

I found this post but it requires actual connection to server, Unit testing Node.js and WebSockets (Socket.io)

我们如何使用 Jasmine 进行测试.寻找一种伪造网络套接字服务器和触发事件(连接、断开连接等)的方法.我将不胜感激任何示例或有用的链接.

How do we test this using Jasmine. Looking for a way to fake web-socket server and fire events (connect, disconnect etc). I'll appreciate any example or useful link.

推荐答案

只需模拟函数的所有依赖项,因此在您的情况下,这将是 SockJSStomp.over.

Just mock all your dependencies of your function, so in your case this will be SockJS and Stomp.over.

var wsSpy = jasmine.createSpy();
spyOn(window, 'SockJs').andReturn(wsSpy);

var clientSpy = jasmine.createSpy();
spyOne(Stomp, 'over').andReturn(clientSpy)

运行脚本后,您可以测试他们被调用的间谍.要运行回调函数,您可以使用 mostRecentCall.args 找到它们并在测试中调用它们:

After running your script you can test on the spies that they was called. To run the callback functions you can use mostRecentCall.args to find them and call them in the test:

var successCallBack = clientSpy.mostRecentCall.args[2];
successCallBack();

var errorCallBack = clientSpy.mostRecentCall.args[3];
errorCallBack();

这篇关于使用 Jasmine 测试 Web 套接字的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Drag amp; Drop with Protractor by Repeater(拖动amp;通过中继器使用量角器掉落)
Getting the position of the element in a list when it#39;s drag/dropped (ui.sortable)(拖放时获取元素在列表中的位置(ui.sortable))
Detecting HTML5 Drag And Drop support in javascript(在 javascript 中检测 HTML5 拖放支持)
HTML5 drop event doesn#39;t work unless dragover is handled(除非处理了拖动,否则 HTML5 放置事件不起作用)
How to use jQuery#39;s drop event to upload files dragged from the desktop?(如何使用 jQuery 的 drop 事件上传从桌面拖动的文件?)
Drop image into contenteditable in Chrome to the cursor(将图像拖放到 Chrome 中的 contenteditable 到光标处)