gpt4 book ai didi

mysql - 如何用MySQL编写golang集成测试

转载 作者:IT王子 更新时间:2023-10-29 00:45:22 32 4
gpt4 key购买 nike

我想编写一个集成测试,使用 MySQL 来测试我的查询。如何在 golang 中执行此操作?

这包含几个问题:

  1. 如何在 golang 测试中设置 MySQL(内存中?)服务器?
  2. 如何在每次测试之前/之后清理/重新创建数据模型,以免留下垃圾?
  3. 如何在所有测试完成后拆除mysql?

最佳答案

如果你真的想要一个嵌入式 MySQL,你可以使用 golangs C 绑定(bind)来集成:https://dev.mysql.com/doc/refman/5.1/en/libmysqld.html .我还没有看到任何项目将绑定(bind)打包到一个不错的 Go 包中,那将是一个有趣的小项目。

否则,您可以使用 Docker 设置一次性 MySQL 服务器,但这需要在运行 go test 之前执行一些设置/拆卸步骤。这就是我们在我工作的地方所做的事情。

在这两种情况下,您都需要编写设置/拆卸方法来根据测试需要创建和删除表。这些只是普通的 SQL 语句,DROP DATABASE、CREATE TABLE 等。

作证https://github.com/stretchr/testify有用于设置/拆卸的工具,但只需为此编写一个辅助函数就可以了。

关于mysql - 如何用MySQL编写golang集成测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29910793/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com