
php小编新一将为您介绍如何管理测试依赖项的初始化代码。在进行软件开发时,往往需要使用各种测试工具和框架,而这些工具和框架可能需要一些初始化代码来进行配置和准备工作。管理这些初始化代码的方式对于测试的可维护性和可扩展性非常重要。下面将为您详细介绍如何管理测试依赖项的初始化代码,以帮助您更好地进行软件测试工作。
我有一个日志包装器(在下面使用 logrus 实现),并且我正在使用这个包来记录我的应用程序。我执行此操作的方法是通过依赖项注入将记录器变量传递给每个所需的包。
在这里,当为每个包编写测试用例时,我必须编写一些代码来初始化记录器包。我们如何避免为每个使用记录器的包的测试用例编写初始化代码?
记录器/log.go
type logger interface {
info(args ...interface{})
infof(format string, keyvals ...any)
infowithfields(fields map[string]interface{}, msg ...interface{})
debug(args ...interface{})
debugf(format string, keyvals ...any)
debugwithfields(fields map[string]interface{}, msg ...interface{})
}
app_test.go
func setupLogrusLogger() (*bytes.Buffer, Logger) {
buf := &bytes.Buffer{}
logrusLogger := log.New()
logrusLogger.Out = buf
logrusLogger.Formatter = &log.JSONFormatter{}
return buf, NewLogrusLogger(logrusLogger)
}
func TestSomething(t *testing.T) {
// buf can be used to inspect what gets logged if required
buf, logger := setupLogrusLogger()
Something(logger)
}在这里,对于每个使用记录器的包,我必须通过定义类似于 setuplogruslogger 的内容来初始化记录器。有什么方法可以避免为我正在为其编写测试的每个包单独编写此内容?
导出依赖初始化函数并在非 _test.go 文件中声明,以便其他包可以导入并重用它。如果您想将测试逻辑与包的正常代码分开,您可以将初始化函数移动到提供测试实用程序的包中。
并且,只要您仅从 _test.go 文件(而不是普通文件)导入此类测试实用程序包,测试实用程序代码就不会使其进入实际程序的编译二进制文件中。
此类测试实用程序包的示例可以在标准库中找到:
包 httptest 提供了用于 HTTP 测试的实用程序。
本文档主要讲述的是maven使用方法;Maven是基于项目对象模型的(pom),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。Maven将你的注意力从昨夜基层转移到项目管理层。Maven项目已经能够知道 如何构建和捆绑代码,运行测试,生成文档并宿主项目网页。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
0
socktest 包提供了用于套接字测试的实用程序。
包 fdtest 提供测试助手,用于跨 exec 使用文件描述符。
Package Quick 实现了实用函数来帮助进行黑盒测试。
软件包 fstest 实现了对文件系统测试实现和用户的支持。
iotest 包实现了主要用于测试的读取器和写入器。
以上就是如何管理测试依赖项的初始化代码的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号