我刚刚开始使用Jest,并且已经成功编写了测试DOM的单元测试。我有一个library在屏幕上输入内容,所以我可以很好地进行测试。在某些情况下,我的库不会抛出错误,而是吐出console.warn或console.log。是否可以使用Jest来测试这些控制台消息是否正在发生? 最佳答案 您可以像这样通过spy设置console.log:global.console={warn:jest.fn(),log:jest.fn()}//runyourcodeexpect(global.console.log).toHaveBeenCalle
在Sinon我可以做以下事情:varmyObj={prop:'foo'};sinon.stub(myObj,'prop').get(functiongetterFn(){return'bar';});myObj.prop;//'bar'但是我怎样才能对Jest做同样的事情呢?我不能只用jest.fn()之类的东西覆盖函数,因为它不会替换getter"can'tsetthevalueofget" 最佳答案 对于遇到这个答案的其他人来说,Jest22.1.0引入了spyongetterandsettermethods的能力.编辑:如sc
我想测试在我的测试中是否调用了特定函数并使用了正确的参数。从JEST文档中我无法弄清楚什么是正确的方法。假设我有这样的东西://add.jsfunctionchild(ch){constt=ch+1;//noreturnvaluehere.Functionhassomeother"sideeffect"}functionmain(a){if(a==2){child(a+2);}returna+1;}exports.main=main;exports.child=child;现在在单元测试中:1.我想运行main(1)并测试它是否返回了2并且未调用child()。2。然后我想运行main
我在Jest模拟静态方法时遇到了麻烦。假设您有一个带有静态方法的A类:exportdefaultclassA{f(){return'a.f()'}staticstaticF(){return'A.staticF()'}}还有一个导入A的B类importAfrom'./a'exportdefaultclassB{g(){consta=newA()returna.f()}gCallsStaticF(){returnA.staticF()}}现在你想模拟A。模拟f()很容易:importAfrom'../src/a'importBfrom'../src/b'jest.mock('../src
这是fullminimalrepro给定以下应用:src/food.jsconstFood={carbs:"rice",veg:"greenbeans",type:"dinner"};exportdefaultFood;src/food.jsimportFoodfrom"./food";functionformatMeal(){const{carbs,veg,type}=Food;if(type==="dinner"){return`Goodevening.Dinneris${veg}and${carbs}.Yum!`;}elseif(type==="breakfast"){retur
我正在对两个非常复杂的对象进行比较,并尝试在expect中使用.toEqual方法。这是我的测试:it('checkifstepGroupsdataincontrolDatamatchesdatainliveData',()=>{varcontrolStore=data.controlStorevarliveStorereturngetData().then(result=>{liveStore=newStore()liveStore.loadData(JSON.parse(result))expect(controlStore).toEqual(liveStore)})})我对预期输
如何使用Jest测试输出随机的函数?像这样:importcuidfrom'cuid';constfunctionToTest=(value)=>({[cuid()]:{a:Math.random(),b:newDate().toString(),c:value,}});因此functionToTest('Somepredictablevalue')的输出将类似于:{'cixrchnp60000vhidc9qvd10p':{a:0.08715126430943698,b:'TueJan10201715:20:58GMT+0200(EET)',c:'Somepredictablevalue
我有一个包含Jest测试的React应用程序。我正在我的package.json中配置Jest:…"jest":{"setupEnvScriptFile":"./test/jestenv.js","setupTestFrameworkScriptFile":"./test/setup-jasmine-env.js","testRunner":"node_modules/jest-cli/src/testRunners/jasmine/jasmine2.js","unmockedModulePathPatterns":["./node_modules/q","./node_modules
模拟ES6类导入我想在我的测试文件中模拟我的ES6类导入。如果被模拟的类有多个消费者,将模拟移动到__mocks__中可能是有意义的,这样所有的测试都可以共享模拟,但在那之前我想将模拟保留在测试文件中。Jest.mock()jest.mock()可以模拟导入的模块。当传递单个参数时:jest.mock('./my-class.js');它使用在与模拟文件相邻的__mocks__文件夹中找到的模拟实现,或创建一个自动模拟。模块出厂参数jest.mock()采用第二个参数,这是一个模块工厂函数。对于使用exportdefault导出的ES6类,不清楚这个工厂函数应该返回什么。是不是:返回模
我正在尝试使用jest模拟类Mailer,但我不知道该怎么做。文档没有给出很多例子来说明它是如何工作的。这个过程是我将有一个节点事件password-reset被触发,当该事件被触发时,我想使用Mailer.send(to,subject,body)发送电子邮件。这是我的目录结构:project_root--__test__----server------services--------emails----------mailer.test.js--server----services------emails--------mailer.js--------__mocks__-----