在写自动化测试脚本的时候,遇到了一个singleton单例模式的坑,例如:关联接口,老是报错请求失败了。
排查了很久,最后找到原因了:
执行测试用例的时候,多线程如果跑同一个接口test function,多线程操作同一个资源的时候,会请求失败。
比如下面这个情况。
Post notification这个用例我是需要去测试的,需要跑,然后关联的接口Notification Message需要用到关联接口Post notification去拿id,那么Post notification单独测这个用例,跑了一次。Notification Message去拿id,又调了一次。Id= TestnotificationPost().test_01(Client)
需要注意:
这里的测试用例,是多线程在跑的。
如果conftest.py里面定义了client(使用单例模式singleton), 在单独跑TestnotificationPost().test_01(Client)的时候,方法执行完毕,client就关闭了,但是另一个线程(在跑关联接口)调完这个接口拿到Id以后,还需要进行其他的操作。但是已经关闭了client,后面的代码没法继续执行了。
这个问题目前有2种解决方案,
第1种是在测试用例里面去new一个新的client 对象,这种情况多线程不使用单例singleton
第2种是使用线程锁。