用例之间都是独立的……这一点该如何实践? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
ebingtel

用例之间都是独立的……这一点该如何实践?

  •  
  •   ebingtel 2021 年 3 月 19 日 2654 次点击
    这是一个创建于 1859 天前的主题,其中的信息可能已经有所发展或是发生改变。

    道理是明白的: 容易实现并发执行测试用例(毕竟目前单线程执行的方式速度太慢了)

    但有个测试场景该怎么处理:

    测试用例,需要执行 sql 、验证 sql 的正确性, 所以我会: 1 ) 先清空表 2 ) 插入数据 3 ) 执行测试逻辑

    如果多个测试用例,会清空同样的表,就无法保证独立性……

    能否不清空呢? 比如有时候测试: 没有数据的逻辑……

    14 条回复    2022-12-29 10:22:06 +08:00
    ruanimal
        1
    ruanimal  
       2021 年 3 月 19 日
    mock 呗, 除了直接测试数据库,其他都用 mock
    liujavamail
        2
    liujavamail  
       2021 年 3 月 19 日
    用例之间独立,主要是为了防止测试数据的干扰,单个测试用例,测试前后,数据库都应该都是干净的。
    111111111111
        3
    111111111111  
       2021 年 3 月 19 日
    用例之间独立并不为例并发执行,当然了 如果要并发执行测试,那么用例直接应当”真正的独立”,包括各自使用独立的数据库或其他外部资源
    111111111111
        4
    111111111111  
       2021 年 3 月 19 日
    例如在 setUp 中为用例创建一个独用数据库(或其他资源)
    ebingtel
        5
    ebingtel  
    OP
       2021 年 3 月 19 日
    @ruanimal 只靠 mock 感觉 mock 的量会比较大吧

    @liujavamail
    @111111111111
    @111111111111 目前是在测试之前 dump 一份新的数据库,基于该数据库执行测试用例,然后删除该库
    IvanLi127
        6
    IvanLi127  
       2021 年 3 月 19 日
    单测用例,调用数据库的方法应该 mock 掉。
    liujavamail
        7
    liujavamail  
       2021 年 3 月 19 日
    @ebingtel 在 rails 里面, 开发环境和测试环境都有自己独立的数据库, 运行测试代码的时候, 插入数据和删除数据都是在测试的数据库中,所以会比较干净, 并且每个测试用例的需要的数据量并不大, 插入删除,并不会花多少时间, 可以借鉴一下
    jones2000
        8
    jones2000  
       2021 年 3 月 20 日
    增加预算加机器, 多部署几套 docker 的测试环境不就可以了. 代码都不用改. 以后简历也好看, 参与大规模集群并行测试.
    msg7086
        9
    msg7086  
       2021 年 3 月 20 日
    事务把请求包起来。
    ebingtel
        10
    ebingtel  
    OP
       2021 年 3 月 22 日
    @jones2000 是不是太重了?
    xiaolinjia
        11
    xiaolinjia  
       2021 年 3 月 22 日
    不是有个 setUpClass 、tearDownClass 类方法吗,清空表的操作,放在 tearDownClass 里不就行了。
    jones2000
        12
    jones2000  
       2021 年 3 月 22 日
    @ebingtel 装机器,docker 运维部门会做, 环境好了做一个镜像, 然后就可以直接跑用例. 跑完用例用镜像还原, 然后再跑下一个测试用例.
    ebingtel
        13
    ebingtel  
    OP
       2021 年 3 月 23 日
    @jones2000 唉 我目前是在 pre-commit 之前 完成 testcase 的 所以希望快点 单个项目被测试的接口大概 50 ~ 100……
    angryPHP
        14
    angryPHP  
       2022 年 12 月 29 日
    遇到同样的问题,楼主后面是怎么处理的?
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5715 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 64ms UTC 06:47 PVG 14:47 LAX 23:47 JFK 02:47
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86