前言
对于新手而言,mocha的时序就像谜一般,许多奇怪的测试样例的失败都是由于对时序不清楚。下面我就把我在测试工作中总结的时序规则部分与大家共享。
describe里地时序
simple case
js
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包裹的部分执行顺序的优先级最高
js
{block1} describe('1',function(){ ... }); {block2} describe('2',func(){..}); //执行顺序block1,block2,describe1,describe2
并列的describe
规则3:同一层次的describe执行顺序遵从它们的定义顺序
嵌套的describe
js
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
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。