Go 运行单元测试时怎样传入命令行参数

发布于 2022-09-12 00:15:17 字数 3555 浏览 32 评论 0

我的 业务单元(需要被测试的单元)中依赖了另外一个包(以下简称 parser 包),parser 包专门负责解析所有传入的命令行参数,在 parser 包的 init 函数中进行了 flag.Parse 操作,将命令行参数绑定至该包的变量内。

所有的 业务单元 需要用到命令行参数,直接从 parser 包的变量中取就行了,而不需要自己做解析。

现在,我需要对那个依赖了 parser 包中变量的业务单元进行单元测试,在执行 go test 命令的时候自然而然会将 parser 包一起编译,所以当执行测试的时候,会先执行 parser 包的 init 函数进行命令行参数解析。

现在,问题就出在这里,我无法通过命令行将参数传递测试程序,应该怎样传递?

以下是我的尝试,都报错了:flag provided but not defined: -test.timeout

➜  logger git:(master) ✗ go test logger.go logger_test.go -monitor-url=foo
flag provided but not defined: -test.timeout
Usage of /var/folders/s8/lrvd172x0_5bn35_lblgb0tm0000gn/T/go-build722317095/b001/logger.test:
  -debug-mode
        turn on debug mode
  -mail-from-addr string
        sender's mail address
  -mail-from-name string
        sender's name
  -mail-from-password string
        sender's smtp auth code
  -mail-smtp-auth-host string
        smtp auth host
  -mail-smtp-server-addr string
        smtp server addr
  -mail-to-addr string
        receiver's mail address
  -monitor-interval string
        milli second, testing cycle (default "20000")
  -monitor-respheader-timeout string
        milli second, timeout for waiting response header (default "2000")
  -monitor-total-timeout string
        milli second, timeout for waiting url response (default "5000")
  -monitor-url string
        the url for monitor
FAIL    command-line-arguments  0.450s
FAIL
➜  logger git:(master) ✗ go test logger.go logger_test.go -args -monitor-url=foo
flag provided but not defined: -test.timeout
Usage of /var/folders/s8/lrvd172x0_5bn35_lblgb0tm0000gn/T/go-build861303357/b001/logger.test:
  -debug-mode
        turn on debug mode
  -mail-from-addr string
        sender's mail address
  -mail-from-name string
        sender's name
  -mail-from-password string
        sender's smtp auth code
  -mail-smtp-auth-host string
        smtp auth host
  -mail-smtp-server-addr string
        smtp server addr
  -mail-to-addr string
        receiver's mail address
  -monitor-interval string
        milli second, testing cycle (default "20000")
  -monitor-respheader-timeout string
        milli second, timeout for waiting response header (default "2000")
  -monitor-total-timeout string
        milli second, timeout for waiting url response (default "5000")
  -monitor-url string
        the url for monitor
FAIL    command-line-arguments  0.313s
FAIL
➜  logger git:(master) ✗ go test logger.go logger_test.go -args monitor-url=foo 
flag provided but not defined: -test.timeout
Usage of /var/folders/s8/lrvd172x0_5bn35_lblgb0tm0000gn/T/go-build447796332/b001/logger.test:
  -debug-mode
        turn on debug mode
  -mail-from-addr string
        sender's mail address
  -mail-from-name string
        sender's name
  -mail-from-password string
        sender's smtp auth code
  -mail-smtp-auth-host string
        smtp auth host
  -mail-smtp-server-addr string
        smtp server addr
  -mail-to-addr string
        receiver's mail address
  -monitor-interval string
        milli second, testing cycle (default "20000")
  -monitor-respheader-timeout string
        milli second, timeout for waiting response header (default "2000")
  -monitor-total-timeout string
        milli second, timeout for waiting url response (default "5000")
  -monitor-url string
        the url for monitor
FAIL    command-line-arguments  0.094s
FAIL

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

柳絮泡泡 2022-09-19 00:15:17

问题已解决,原因在于,testing 包也需要注册 flags,比如报错中的 test.timeout 就是一个 flag,而理论上应该是先将所有的 flags(包括 testing 包需要的和自己的程序需要的)注册之后,再执行 flag.Parse。而我的 parser 包是被依赖的包,所以先被执行 init,进行了 flag.Parse 操作,导致 testing 包的 flags 注册动作发生在 Parse 之后,从而得不到注册。

解决办法
分析执行测试时代码的执行顺序,只要保证在 Parse 解析之前,testing 包需要的 flags 和你的程序需要的 flags 都进行了注册即可。主动调用 testing 包的 flags 注册动作是 testing.Init() 函数。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文