Posted in Javascript onFebruary 16, 2019
前言
对于新手而言,mocha的时序就像谜一般,许多奇怪的测试样例的失败都是由于对时序不清楚。下面我就把我在测试工作中总结的时序规则部分与大家共享。
describe里地时序
simple case
describe('work',function(){ it('1',func(){}); it('2',func(){}); .... }); //按1,2,3...顺序执行
规则1:describe里地it的非异步部分按它们定义的顺序执行,它们所触发的回调的注册顺序也遵从it的注册顺序
hooks
- before
- after
- beforeEach
- afterEach
这是比较常用的hooks,我们可以采用hooks改变在describe中的时序,但是记住hooks是在describe的基础上的,与describe联系在一起的。hooks对子describe是不起作用的。
describe间的时序
非describe部分
规则2:不被describe包裹的部分执行顺序的优先级最高
{block1} describe('1',function(){ ... }); {block2} describe('2',func(){..}); //执行顺序block1,block2,describe1,describe2
并列的describe
规则3:同一层次的describe执行顺序遵从它们的定义顺序
嵌套的describe
describe('parent',func(){ it('1',func(){..}); describe('child1',func(){...}); it('2',func(){...}); describe('child2',func(){..}); }); //执行顺序为it1,it2,child1,child2
规则4:外层describe的所有it执行优先级高于嵌套的describe
最后我们把这四条规则总结一下
- describe里地it的非异步部分按它们定义的顺序执行,它们所触发的回调的注册顺序也遵从it的注册顺序
- 不被describe包裹的部分执行顺序的优先级最高
- 同一层次的describe执行顺序遵从它们的定义顺序
- 外层describe的所有it执行优先级高于嵌套的describe
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。如果你想了解更多相关内容请查看下面相关链接
mocha的时序规则讲解
- Author -
suemi声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@