如何将测试代码从一个模块导入到另一个模块而不将其暴露给生产代码?

问题描述 投票:0回答:1

TLDR:我在 logutils/test-logger_test.go 中放置了一个 TestLogger 结构,并尝试在authentication/login_tests.go 中引用它。在为身份验证模块构建测试时,编译器抱怨未声明 TestLogger。唯一的解决方法是将 test-logger_test.go 重命名为 test-logger.go,但这存在在生产代码中引用 TestLogger 的风险。

在运行 go 测试时,golang 似乎不会将测试代码(在带有 _test.go 后缀的文件中声明的代码)从一个模块导入到另一个模块。我做错了什么或者这是 golang 的设计方式吗?有解决办法吗?

简单的例子来说明:

我有一个“库”模块(我们称之为 il logutils)和“应用程序”模块(我们称之为“身份验证”)。 logutils 模块有自己的测试,涵盖了记录器的所有实现特定功能(例如 FileLogger、HttpLogger),一切都很好。

logutils 模块还声明了一个 TestLogger,可供“客户端”模块(例如“身份验证”)使用,以确保它们正确记录所有内容,而无需设置文件或 http 日志记录。它基本上只是实现了 Logger 接口,但只是将所有内容记录到可以在测试结束时验证的缓冲区。

因此“身份验证”模块可以声明自己的 _test.go 文件来实例化 TestLogger,这一切都像魅力一样工作。

令我困扰的是,TestLogger 需要在常规生产文件(logutils/test-logger.go)中声明,而不是在测试文件(logutils/test-logger_test.go)中声明,否则身份验证测试会抱怨 TestLogger没有定义。但通过这样做,没有什么可以阻止 TestLogger 在生产代码中被引用/使用。

我想要的是任何 logutils _test.go 文件中的代码都可以在任何身份验证 _test.go 文件中导入(但不能在生产 .go 文件中导入)。

有什么见解/建议吗?

编辑:修正拼写错误

go testing go-modules go-toolchain
1个回答
0
投票

我想要的是任何 logutils _test.go 文件中的代码都可以在任何身份验证 _test.go 文件中导入(但不能在生产 .go 文件中导入)。

你不能拥有这个。简单极了。 (不存在“生产 .go 文件”之类的东西。测试代码不是“非生产”。)

© www.soinside.com 2019 - 2024. All rights reserved.