回答

收藏

使用 Go 语言进行测试的正确包命名

技术问答 技术问答 277 人阅读 | 0 人回复 | 2023-09-12

我在 Go 我看到了几种不同的测试包命名策略,想知道每种策略的优缺点以及我应该使用哪一种。; w9 N/ h5 A/ E5 Y8 I$ I* [$ ?
策略一:: v& C$ A1 u& J6 b/ D
文件名:github.com/user/myfunc.go  q- _+ N& T; C! F! R
    package myfunc
    9 s" O# H3 X. W( ]8 ~3 |
测试文件名称:github.com/user/myfunc_test.go
2 Y6 F' H( i! e, Z' C* i! X1 j( L
    package myfunc
    5 d( r: R: [! a5 ]& }: S+ m, v5 h
有关示例,请参见bzip2。- O& B. K$ K' A$ y4 ]. Y+ c* z
策略二:, h7 k+ y' m" w! y
文件名:github.com/user/myfunc.go
6 P& u2 Z9 g( y4 h
    package myfunc
    ; k. k0 t3 t& }1 T$ }
测试文件名称:github.com/user/myfunc_test.go
! W6 d7 {( L) h. Z& e: Q
    package myfunc_testimport  "github.com/user/myfunc")
    + r2 X6 q3 Y% s. {/ s
策略三:6 N" k0 H8 I$ C. {; X9 z' U
文件名:github.com/user/myfunc.go
$ f) B& S* s9 [
    package myfunc; p* O4 i9 X( ?4 q
测试文件名称:github.com/user/myfunc_test.go
2 X% @  O) g% w% m! |, r
    package myfunc_testimport  . "myfunc")
    ( o! D- b' ^( L5 d5 j9 H2 T
请参见字符串。
* P: d0 F" \8 IGo 标准库似乎混合了 1 和 2的策略。这三个应该用哪一个?package *_test我的测试包很痛苦,因为这意味着我不能测试我的私人方法,但也许有一个我不知道的隐藏优势?
" o+ O. E, G+ W8 N                                                               
: i2 C4 C6 e' U    解决方案:                                                               
. B- `: o# F$ B/ t/ a& A1 b                                                                您列出的三种策略之间的根本区别在于测试代码是否与被测代码在同一个包中。使用决定package myfunc或package myfunc_test测试文件取决于您是否要执行白盒或黑盒测试。
7 F1 y  U; B5 a3 w在项目中同时使用这两种方法没有错。例如,你可以拥有它myfunc_whitebox_test.go和myfunx_blackbox_test.go。7 u; \" O2 D! i" Y. ?. }9 S+ t
比较测试代码包黑盒测试:使用package myfunc_test,这将确保您只使用导出的标识符。
9 x1 T  X7 n+ W5 d) A+ I白盒测试:使用package myfunc使您能够访问非导出标识符。适用于需要访问非导出变量、函数和方法的单元测试。
比较问题中列出的策略% m0 P8 B1 B1 t6 W
策略 1:文件myfunc_test.go使用package myfunc- 在这种情况下,中间的测试代码myfunc_test.go与 中正在测试的代码在同一包中myfunc.go,myfunc在这个例子中。
6 h& L7 @# j9 Q9 G) S( J9 e策略 2:文件myfunc_test.go使用package myfunc_test——在这种情况下,myfunc_test.go在主测试二进制文件链接并运行为单独的包编译,然后链接并运行主测试二进制文件[来源:test.go源代码中的第 58-59 行]
) }( O7 l; a7 v; s+ V9 m策略 3:文件myfunc_test.go使用package myfunc_test但myfunc导入使用点表示法- 这是策略 2 的变体,但导入使用点表示法myfunc.
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则