草庐IT

jmeter模拟虚拟用户并发

全部标签

javascript - 禁用 Jest setTimeout 模拟

我正在为依赖于websocket库的代码编写Jest测试。websocket库被模拟。我想发送一条消息,等待异步操作完成,然后检查响应。it('sendsamessageandgetsaresponse',()=>{processor(ws).sendMessage()//doabunchofasyncstuff,callwebsocket.sendMessage()setTimeout(()=>{expect(ws.getResponse()).toEqual('alldone')},100)})不幸的是,因为Jest模拟了setTimeout,所以setTimeout失败了。如果我

javascript - 在 Angular 单元测试中模拟 ngResource

我有一个看起来像这样的ngResourceMockFactory:(function(){'usestrict';angular.module('app').factory('NgResourceMock',ngResourceMockFactory);ngResourceMockFactory.$inject=[];functionngResourceMockFactory(){functionNgResourceMock(){varcontext=this;context.$promise.then=function(){context.prototype.$promise.the

javascript - 使用 Jest 模拟基于 promise 的请求

我正在尝试使用Jest对函数进行单元测试,但我在处理jest模拟模块时遇到了一些麻烦(相当于nodejs世界中的rewire或proxyquire)。我实际上是在尝试测试是否已使用一些参数在模拟模块上调用了spy程序。这是我要测试的功能。注意:当前测试只涉及“fetch(...)”部分,我正在尝试测试fetch是否已使用good参数调用。exportconstfetchRemote=slug=>{returndispatch=>{dispatch(loading());returnfetch(Constants.URL+slug).then(res=>res.json()).then(

javascript - 模拟超时 url

我正在尝试从网页模拟超时,以便我可以实现“处理超时”功能。基本上我需要的是一个在X秒内不回复的东西的URL。提前致谢这是我的代码:varreq=Components.classes["@mozilla.org/xmlextras/xmlhttprequest;1"].createInstance();req.overrideMimeType('text/plain;charset=utf-8');req.open("GET",configurationURL,false);req.variable=specificConfigurationURLTerminator;setTimeou

javascript - 我可以使用一组限制来模拟 JavaScript 中的函数式编程吗?

我在看MiskoHevery关于干净代码的演讲,他提到尝试编写一个没有if语句的程序(嗯,尽可能少)以模拟在...Smalltalk或其他一些这种语言,其中多态性优于内联条件行为。据我有限的理解,函数式编程对于像我这样的目前为止只有命令式的程序员来说很难——因为我们的状态改变方法无法在函数式程序中表达。函数只接受一个值并返回一个值,对状态一无所知。我还看到JS被誉为能够支持函数式模型。那么是否有一组简单的限制,类似于我的第一段,这将使我能够用我知道和喜爱的语言尝试功能范式-而不是学习一门全新的语言(我最终会这样做但我现在想尝试这种精神)? 最佳答案

javascript - 浏览器中的JavaScript是否可能发生并发读/写读/写冲突?

我有一种情况,我正在进行几个(比如四个)ajax调用(使用AngularJShttpget,如果这很重要)并且我希望每个调用都回调并增加一个计数器,所以我可以知道所有(四个)线程已完成。我担心的是,由于JavaScript没有任何可与Java的“同步”或“volatile”关键字相媲美的东西,因此多个并发线程在递增计数器时可能会发生冲突,从而错过一些递增。换句话说,两个线程同时来,都读取计数器,得到相同的值(比如100)。然后两个线程递增该计数器(到101)并存储新值,看哪,我们错过了一个计数(101而不是102)!我知道JavaScript应该是单线程的,但也有异常(exceptio

javascript - 模拟/ stub `super` 调用

我想模拟super调用,尤其是某些ES6类中的构造函数。例如importBarfrom'bar';classFooextendsBar{constructor(opts){...super(opts);}someFunc(){super.someFunc('asdf');}}然后在我的测试中,我想做类似的事情importFoofrom'../lib/foo';importBarfrom'bar';describe('constructor',function(){it('shouldcallsuper',function(){letopts=Symbol('opts');letcons

javascript - 在 Node.js 中模拟嵌套模块?

我有这些文件:文件1.jsvarmod1=require('mod1');mod1.someFunction()...文件2.jsvarFile1=require('./File1');现在在为File2编写单元测试时,是否可以模拟mod1,这样我就不会调用mod1.someFunction()? 最佳答案 我通常使用mockery模块,如下所示:lib/file1.jsvarmod1=require('./mod1');mod1.someFunction();lib/file2.jsvarfile1=require('./file

javascript - axios 并发请求数 : any way to get the results from the successful requests even if some have failed?

我正在尝试了解如何在javascript中处理并发异步请求,您是否知道使用axios获取成功请求结果的方法,即使请求失败了?如果不是,您将如何处理这种情况?varaxios=require('axios')varoptions=[{baseURL:'https://some-base-url',url:'/some-path&key=some-key',method:'post',data:'some-data'},{baseURL:'https://some-base-url',url:'/some-path&key=some-key',method:'post',data:'som

javascript - 在自定义事件上使用 enzyme 模拟?

可以在自定义事件上使用Enzyme的方法.simulate()。例如://Code//Testconstelement=shallow();element.simulate('foo');这是应该使用Enzyme测试自定义事件的方式,还是使用s.th.的更好方法?喜欢://Testconstelement=shallow();element.props.onFoo() 最佳答案 似乎没有实现自定义事件的.simulate()。有一个issue在github上,讨论了这个主题,其中一位Enzyme维护者建议使用您提供的第二种方法:wr