我有一个yaml文件,其中包含一些配置信息,我在要测试的模块中使用它。但是当我测试它时我想模拟它所以它只有简化和静态数据,所以它很容易测试并且如果配置发生变化我不必编辑测试。到目前为止,这是我尝试过的://config/index.jsconstyaml=require('js-yaml');constfs=require('fs');constpath=require('path');constfilePath=path.join(__dirname,'stuff.yaml');module.exports={getStuff(){returnyaml.safeLoad(fs.rea
我有几个Redux-Thunk风格的函数,可以在一个文件中分派(dispatch)其他操作。其中一个Action将另一个作为其逻辑的一部分进行分派(dispatch)。它看起来类似于:exportconstfunctionToMock=()=>async(dispatch)=>{awaitdispatch({type:'abasicaction'});};exportconstfunctionToTest=()=>async(dispatch)=>{dispatch(functionToMock());};在我实际遇到的情况下,这些函数都涉及更多,并且每个都分派(dispatch)多个
我目前正在做一个ReactNative项目,想使用FirebaseJSSDK。为了熟悉它的所有API,我想用Jest编写一些学习测试。这是我的测试:importFirebasefrom'firebase';describe('Firebase',function(){it('shouldwork',function() {expect(null).toBeNull()})});不幸的是我收到了这个错误:●测试套件运行失败TypeError:Cannotreadproperty'defineProperties'ofundefinedatnode_modules/firebase/app
我有一个ImageLoader类组件,我正在尝试测试是否正在调用HTMLImageElement上的onload函数。重要的是要注意ImageLoader按预期工作,我只是无法运行测试。这是我的类组件的示例:exportdefaultclassImageLoaderextendsReact.Component{//OmittedforbrevitysetSrc=()=>{const{src}=this.props;if(src){this.tmpImg=newImage();//this.tmpImg.onloadisnevercalledthis.tmpImg.onload=()=>
我正在尝试在我的process.on('SIGTERM')回调中使用Jest对计时器进行单元测试,但它似乎从未被调用过。我正在使用jest.useFakeTimers()虽然它似乎在一定程度上模拟了setTimeout调用,但它并没有在setTimeout.mock中结束检查时对象。我的index.js文件:process.on('SIGTERM',()=>{console.log('GotSIGTERM');setTimeout(()=>{console.log('Timerwasrun');},300);});setTimeout(()=>{console.log('Timer2w
不确定为什么会在这条线上提示:constwrapper=shallow();/Users/leongaban/projects/match/bitcoin/src/components/bitcoinWidget.test.js:Unexpectedtoken(17:26)JestencounteredanunexpectedtokenThisusuallymeansthatyouaretryingtoimportafilewhichJestcannotparse,e.g.it'snotplainJavaScript.Bydefault,ifJestseesaBabelconfig,i
我正在尝试模拟一个将数据检索到组件中的fetch()。I'musingthisasamodelformockingmyfetches,但我无法让它正常工作。我在运行测试时遇到此错误:babel-plugin-jest-hoist:Themodulefactoryof'jest.mock()'isnotallowedtoreferenceanyout-of-scopevariables。有没有办法让这些函数返回模拟数据,而不是实际尝试进行真正的API调用?代码utils/getUsers.js返回Angular色映射到每个用户的用户。constgetUsersWithRoles=role
functioncreateRequest(method){constinit={method,headers:newHeaders({.....}),};returnnewRequest(url,init);}我在上面的代码(https://davidwalsh.name/fetch)中使用请求header(带Fetch)然而,在使用Jest编写单元测试用例时,它给了我这个错误:ReferenceError:Headersisnotdefined我是否需要模拟这些标准模块?单元测试用例中如何导入Headers 最佳答案 我说是的,
我在这里看到了一些关于用jest模拟默认导出的问题,但我认为还没有人问过这个问题:当模拟正在测试的模块的依赖项的默认导出时,如果模块使用ES6导入语句导入依赖项,测试套件将无法运行,声明TypeError:(0,_dependency.default)不是函数但是,如果模块改用require().default调用,它会成功。在我的理解中,importmodulefromlocation直接转换为constmodule=require(location).default,所以我很困惑为什么会这样。我宁愿保持我的代码风格一致,也不使用原始模块中的require调用。有办法吗?模拟测试文件
据我所知,在运行脚本时,console.log()应该可以毫无问题地打印到我的控制台的STDOUT。但在我的例子中,我将NPM配置为在从shell发出npmtest时运行Jest,并且测试文件中的任何console.log()都不会在屏幕上打印任何东西。我也尝试使用process.stdout.write()但在运行npmtest时我仍然没有得到自定义输出。我应该如何调试测试脚本中的内容?我不知道这是来自Node、NPM还是Jest的问题。有一个Jestissue看起来和我的很相似,但我仍然无法解决并输出一个简单的字符串;而其余的Jest输出则照常回显。有人遇到过类似的问题吗?编辑1: