首页
学习
活动
专区
圈层
工具
发布

使用Jest测试包含setTimeout调用的函数踩坑记录

前两天给一个包含setTimeout调用的函数写单元测试,在使用fake timer的时候遇到了问题,记录一下。...在启用fake timer的时候,setTimeout、setInterval都会使用Jest提供的假实现,他们不会真正阻塞住测试用例。...根据Jest的官方文档,调用这个函数后,所有队列中的“微任务”都会被立刻执行,这里的目的就是保证catch回调能被立刻调用; 使用jest.advanceTimersByTime(6000)代替await...注意我们此时使用的是fake timer,因此是无法使用await delay(0)这个方案的,因此这会导致我们的测试用例在等待setTimeout被回调,而fake timer的setTimeout又在等待...,对setTimeout函数进行了拦截侦听,被调用时不做任何事。

7.7K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript定时调用函数(SetInterval与setTimeout)

    不过这两个函数还是有区别的,setInterval在执行完一次代码之后,经过了那个固定的时间间隔,它还会自动重复执行代码,而setTimeout只执行一次那段代码。...,它只是简单地每隔一定时间就重复执行一次那个函数。...只要调用了setInterval("PerRefresh()", 5000)此函数,那么每隔5秒钟就会执行PerRefresh这个函数。    ...如果要求在每隔一个固定的时间间隔后就精确地执行某动作,那么最好使用setInterval,而如果不想由于连续调用产生互相干扰的问题,尤其是每次函数的调用需要繁重的计算以及很长的处理时间,那么最好使用setTimeout...setInterval 不断地执行指定代码直到调用clearInterval清除定时器对象 setTimeout 执行一次指定代码,使用clearTimeout清除定时器对象 setInterval和setTimeout

    1.8K40

    关于setTimeout和setInterval的函数参数问题

    今天在写验证码倒计时小demo时,用了如下代码: window.setTimeout(count(num),1000); 这样直接使用将使count函数立即执行,并将返回值传递给setTimeout函数作为参数...方法一 使用字符串形式可以达到想要的结果: window.setTimeout("count(num)",1000); 这是我以前常用的方法。 但这种写法是将函数包在引号里,有点像字符串,不够直观。...而且有些场合必须使用函数名,于是上网查阅了以下方法: 方法二 //倒计时函数 function count(_num){ ... } //创建一个函数,用于返回一个无参数函数...(_count(30),1000); 这里定义了一个函数_count,用于接收一个参数,并返回一个不带参数的函数,在这个函数内部使用了外部函数的参数,从而对其调用,不需要使用参数。...在 window.setTimeout函数中,使用_count(30)来返回一个不带参数的函数,此时不需要用引号也实现了参数传递的功能。

    2.2K20

    JS中setTimeout是如何实现的

    我们知道 Javascript引擎是单线程的,而setTimeout方法的作用是延后执行目标代码,同时还可以继续往下执行 setTimeout是如何实现的?...这涉及到了浏览器内核的事件循环模型,在Javascript引擎之外,有一个任务队列,当执行到setTimeout时,延时方法会交给内核其他模块处理(与执行引擎主线程独立),当延时方法到达触发条件,这一延时方法被添加至任务队列里...,执行引擎在主线程方法执行完毕后,会从任务队列中顺序获取任务来执行,这一过程是一个不断循环的过程,称为事件循环模型 下面通过一段示例代码,看一下整个执行过程 console.log('1'); setTimeout...(2)setTimeout test入栈执行 交由webapis处理 ? (3)log('3')入栈执行 ?...(4)在setTimeout方法执行5秒后,timer模块检测到延时处理方法到达触发条件,于是将延时处理方法加入任务队列 ?

    3.7K80

    字节面试:如何实现准时的setTimeout

    这站图可以很好的描述以上问题: 如何实现准时的 “setTimeout” requestAnimationFrame window.requestAnimationFrame() 告诉浏览器——你希望执行一个动画...,并且要求浏览器在下次重绘之前调用指定的回调函数更新动画。...该方法需要传入一个回调函数作为参数,该回调函数会在浏览器下一次重绘之前执行,回调函数执行次数通常是每秒60次,也就是每16.7ms 执行一次,但是并不一定保证为 16.7 ms。...cb(); return; } requestAnimationFrame(loop) } } 发现由于 16.7 ms 间隔执行,在使用间隔很小的定时器...依旧非常的稳定,因此通过系统的时间补偿,能够让我们的 setTimeout 变得更加准时,至此我们完成了如何让 setTimeout 准时的探索。

    73610

    Vue中 使用定时器 (setInterval、setTimeout)

    要调用一个代码串,也可以是一个函数。 milliseconds 必须。周期性执行或调用 code/function 之间的时间间隔,以毫秒计。...eg: 开始的时候创建了一个定时器 setInterval ,时间间隔为2秒,每2秒都会调用一次函数 valChange,从而使 value 的值+1。...定时执行 ( setTimeout) 定时执行 setTimeout 是设置一个时间,等待时间到达的时候只执行一次,但是执行完以后定时器还在,只是不再运行; 语法: setTimeout(code,...传给执行函数的其他参数(IE9 及其更早版本不支持该参数)。 返回值: 返回一个 ID(数字),可以将这个ID传递给 clearTimeout() 来取消执行。...eg: 开始时候创建一个定时器 setTimeout,只在2秒后执行一次方法。

    10.4K11

    如何使用SUMIFS函数

    标签:Excel函数,SUMIFS函数 如下图1所示,要求数据表中指定颜色和尺寸的价格之和。数据表区域为B3:D8,条件区域在列B和列C。...图1 使用SUMIFS函数很容易求得,在单元格D11中的公式为: =SUMIFS(D3:D8,B3:B8,B11,C3:C8,C11) 单元格D12中的公式为: =SUMIFS(D3:D8,B3:B8,...B12,C3:C8,C12) SUMIFS函数的语法 SUMIFS函数语法: SUMIFS(sum_range,criteria_range1,criteria1,[criteria_range2],[...示例5:使用逻辑运算符 单元格D11中的公式求编号小于104且尺寸为“小”的价格之和: =SUMIFS(D3:D8,B3:B8,B11,C3:C8,C11) 单元格D12中的公式求编号大于等于103且尺寸为...“中”的价格之和: =SUMIFS(D3:D8,B3:B8,B11,C3:C8,C11) 图6 可以使用的逻辑运算符有: 1.

    2.6K20

    setTimeout(f,0)的作用及使用场景

    ⬇️ 计时精度如下: IE8及更早版本的计时器精度为15.625ms IE9及更晚版本的计时器精度为4ms Firefox和Safari的计时器精度大约为10ms Chrome的计时器精度为4ms 当使用这个方法的时候...,浏览器会另起一个线程,来执行setTimeout里面的函数,而原有的线程继续执行。...至于与setTimeout后继的同步函数的执行顺序或者执行快慢,并没有固定的答案,视浏览器而定了。...# 简单应用场景 监控input或者textarea中文本的变化 当使用鼠标右键操作进行粘贴或剪切时,控制台输入的文本内容是操作前的旧内容。...this.val()); }, 0) }); setTimeout能够影响代码的执行顺序和时机,合理使用能够让更重要的代码优先执行,fix特定场景下奇怪的bug等等。

    1.6K20

    如何使用Scala的exists函数

    在本文中,我们将演示如何在Scala的集合上使用exists函数,该函数适用于Scala的可变(Mutable)和不可变(Immutable)集合。...exists函数接受谓词函数(predicate function),并将使用该函数查找集合中与谓词匹配的第一个元素。...exists函数如何检查在序列中是否存在一个指定的元素: 下面的代码展示了如何使用exists函数来查找某个特定元素是否存在于一个序列中——更准确地说,就是使用exists函数来查找甜甜圈序列中存在普通甜甜圈元素...(Value Function) 4、如何使用exists函数并通过步骤3的谓词函数查找元素Plain Donut: 下面的代码展示了如何调用exists方法并传递步骤3中的值谓词函数,以查找甜甜圈序列中是否存在普通的甜甜圈元素...exists函数声明谓词def函数: 下面的代码展示了如何使用谓词def函数查找序列中是否存在普通的甜甜圈元素: println("\nStep 5: How to declare a predicate

    2.3K40

    且看setTimeout的实现原理以及setTimeout(0)的使用场景「建议收藏」

    在今天之前我一直以为setTimeout这个函数是异步的,无意中看到了一篇关于setTimeout的文章。发现自己曾经的认识全是错误的,赶紧总结下。...也就是说:setTimeout失效了,指定的函数并没有在500ms后运行。而是延迟到1000ms后才运行。...所以一次鼠标点击,或是计时器到达时间点,或是Ajax请求完毕触发了回调函数。这些事件处理程序或回调函数都不会马上运行,而是马上排队。一旦线程有空暇就运行。...也就是说setTimeout仅仅能保证在指定的时间过后将任务(须要运行的函数)插入队列等候,并不保证这个任务在什么时候运行。...如今我们知道了setTimeout的原理了,如今看下setTimeout(0)的使用场景。以下这个样例来自这篇文章。

    84410

    如何使用Python的filter函数

    filter()函数的基本语法是: filter(function, iterable) 返回一个可迭代的filter对象,可以使用list()函数将其转化为列表,这个列表包含过滤器对象中返回的所有的项...下面介绍filter()的四种不同用法: 在filter()中使用特殊函数 filter()的第一个参数是一个函数,用它来决定第二个参数所引用的可迭代对象中的每一项的去留。...此函数被调用后,当返回False时,第二个参数中的可迭代对象里面相应的值就会被删除。针对这个函数,可以是一个普通函数,也可以使用lambda函数,特别是当表达式不那么复杂的时候。...同样,输出如下: ['Ashley', 'Olly'] 总的来说,在filter()函数中使用lambda函数得到的结果与使用常规函数得到的结果相同。...接下来,for循环访问字典中每个键值对,然后使用条件语句检查search_string是键值对中的值。 iterator_func函数作为filter函数的参数对象,用它对迭代对象进行筛选。

    5.4K31
    领券