加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

database – 如何为依赖动态数据的函数编写单元测试?

发布时间:2020-12-13 20:10:14 所属栏目:百科 来源:网络整理
导读:假设你有一个网站,它使用一个函数从数据库中检索数据并返回要显示/解析的结果/ etc … 由于从数据库中检索的数据是动态的,并且可能每天都有可能发生变化,因此如何为此功能正确编写单元测试? 假设该函数应该返回一组结果.显然,单元测试可以测试是否返回数组.
假设你有一个网站,它使用一个函数从数据库中检索数据并返回要显示/解析的结果/ etc …

由于从数据库中检索的数据是动态的,并且可能每天都有可能发生变化,因此如何为此功能正确编写单元测试?

假设该函数应该返回一组结果.显然,单元测试可以测试是否返回数组.但是,由于MySQL查询编写错误,当数组本身的内容不正确时会发生什么?数组的大小可能为零,或者数组的内容可能不正确.由于它依赖于不断变化的数据,单元测试如何知道什么是正确的,什么不是?从单元测试本身调用数据库是否必要,所以有什么可以比较它?

如何为依赖动态数据的函数正确编写单元测试?

单元测试,以理想的形式,应该只测试一件事.在这种情况下,您正在测试两件事:

>你的功能的逻辑
>数据库检索

所以我建议以下重构:

>将数据库检索逻辑移动到单独的函数中
>有你要测试的功能调用其他功能
>模拟返回数据的功能,这样您就可以对应用程序的逻辑进行单元测试
>如果它有意义(如果你只是依靠另一个库来执行此操作,那么希望lib已经有测试),为动态检索功能编写一个单元测试,在那里你不能测试细节,但是可以测试返回的数据的结构和合理性(例如,它设置了所有字段,并且是现在5秒内的时间).

此外,通常最好在测试环境中运行单元测试,在该测试环境中您可以完全控制存储在数据库中的内容.您不希望针对生产数据运行这些.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读