草庐IT

模拟退火算法

全部标签

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 - 是否有像 bcrypt 这样的慢速 Javascript 哈希算法?

我不是在谈论服务器端node.js。我想对我网站客户端的key使用慢散列算法。我找到了SHA-256的实现哪个seemtobereliable.我还找到了thisquestion这导致了OPcreatinghisownlibrary.但是,我不确定我是否应该只进行多轮SHA散列或信任其中的一些代码,因为我不是安全专家而且它似乎没有大量的追随者只是被“盯着”36人。在这种情况下最好的选择是什么?一旦我选择了某些东西,我(基本上)就不能改变方法。我想要一个慢散列(不是加密)算法,我宁愿它产生一个短字符串。例如,60个字符的慢速bcrypt与70个字符的快速SHA-256。

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 - 模拟/ 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 - 在自定义事件上使用 enzyme 模拟?

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

javascript - 使用高效算法对数组中的相同对进行计数

问题陈述:a[]是n个数的数组,数组中相同对的计数,使得0p,q是对的索引。a[3,5,6,3,3,5]n=6这里相同对的数目是4,它们是(0,3),(0,4),(3,4),(1,5)且不(2,2)或(4,3)违反p条件。解决方案1:functiongetIdenticalPairs(a,n){varidenticalPairs=0;for(vari=0;i这段代码工作得很好,但它的时间复杂度似乎是o(n2)。我尝试的第二个解决方案是,解决方案2:使用组合公式,相同对的nos,ncrvaridenticalPairs=0;functiongetIdenticalPairs(a,n){v