golang 测试工具的go test的使用 go语言单元测试的编写

​ 当我们写好一段代码,就要进行测试,以保证代码的正确性,如果我们不写测试,而是每次把整个项目运行一遍,一方面,运行消耗的资源会更大.另一方面,项目的主要部分可能还没有完成,你本来就要单独写一个文件来进行测试. 总不能几千行代码全部写完再运行看效果.

​ 比如说我现在,写一个视频网站爬虫类的项目,需要把解析下载地址,和视频信息的部分抽象出来, 然后主函数要写命令行解析部分的代码,还有就是多线程下载器部分的代码.首先写的是视频解析部分的代码, 基本上是顺序式执行的代码,首先就是把json解析成结构体,这步做完就要检查一下解析的对不对,因为这步解析错了不修改过来的话,后面也是跟着错.

​ 说下面一行代码,实际上是对bilibili番剧页面返回的json信息进行解析,在golang里面只需要把结构体定义好,调用Unmarshal方法就能把json字符串里的数据解析到结构体,其中遇到解析错误的时候, 比如说json中带双引号""的是字符串类型,但是我们定义结构体的时候定义成int类型,就会发生解析错误,后面的内容就不会继续解析下去了

package bilibili
func getBugumiDataJSON(bugumiHTML string) (data bangumiData, err error) {
    dataString := utils.MatchOneOf(bugumiHTML, `window.__INITIAL_STATE__=(.+?);\(function`)[1]
    err = config.JSON.Unmarshal([]byte(dataString), &data)
    return
}

​ 编写测试的时候我们只需要在同一目录下创建 包名_test.go 的文件,然后里面以Test_开头的函数是对下划线后面的函数的测试函数.

​ 另外还有两种前缀 Benchmark和Example 这里先不讨论.

​ 我们对那个函数编写测试,测试函数需要传入一个*testing.T类型的参数,里面有很多错误输出和其他测试相关的代码,用这个错误输出就能被go test 工具解析到了.

package bilibili
func TestGetBangumiDataJSON(t *testing.T) {
    url := "https://www.bilibili.com/bangumi/play/ep341211"
    res, err := req.Get(url, reqHeader)
    if err != nil {
        t.Error("请求页面失败", url, err)
    }
    data, err := getBangumiDataJSON(res.String())
    if err != nil {
        t.Errorf("解析结构体出错%s \n", err)
    }
    t.Logf("%+v", data)
}

在当前目录下命令行执行 go test -v 即可看到运行结果,

Test_包名的函数是主函数,可以等整个包完成后在这个函数里写最后的测试内容.

可以-run+正则表达式字符串匹配运行的测试函数.

下面翻译go test工具的帮助文档(go help test):

usage: go test [build/test flags] [packages] [build/test flags & test binary flags]

​ go test 重新编译每个包文件名符合*_test.go的go文件

​ 这些额外的文件包含了测试函数,benchmark函数还有example函数, 运行go help testfunc 查看更多消息

​ 每个包都会执行独立的测试文件,即包名_test.go,以_.开头的文件将被忽略掉

​ test后缀的包将作为一个独立的包被编译,和 main test函数一起运行

​ test工具会忽略文件名为 testdata的文件夹,如果你有一些辅助文件建议放到这个文件夹里

​ 当编译test的二进制文件的时候会使用go vet定位问题,如果发现错误,go test 会报告错误,并且停止运行这个测试,只有部分高可靠性的包会被go vet使用 That subset is: 'atomic', 'bool', 'buildtags', 'errorsas','ifaceassert', 'nilfunc', 'printf', and 'stringintconv'.

你可以查看相关帮助文档 运行go doc cmd/vet

​ 所有测试输出和总结会被打印到go 标准输出, 因为标准错误流会被用于打印编译测试文件时的错误.

​ go test运行在两种不同的模式上.

  1. 第一种 本地文件夹模式,当go test 没有pakage参数的情况下运行(for example, 'go test' or 'go
    test -v'),此时 go test 会从当前文件夹下找测试文件运行.在这个模式下 caching不能使用,在package tese 结束之后,go test打印一行总结,表明测试结果 ok 或者fail, 包名,和经过的时间

  2. 第二种 package list 模式,当go test 在特定包参数下运行(for example 'go test math', 'go
    test ./...', and even 'go test .') 在这种模式下,go test会去找匹配的包列表,当测试通过的时候,只打印一行ok ,但是当测试失败的时候,会打印所有测试输出

    如果以-bench 带有-v启动,go test会打印所有输出,即使通过了测试.为了显示需求的benchmark结果和verbose 详细的日志信息. 当列表里的包的package test都结束,输出也被打印,如果有package出现失败信息,最后会打印一个 FAIL.

    只有在包列表模式下,go test 会缓存成功的包测试结果,避免不必要的重复测试,当测试结果能从缓存中恢复时,go test会重新显示一遍之前的输出,而不是重新进行测试文件的编译,当缓存调用发生的时候,go test 会打印(cached) 取代执行时间.

    缓存匹配的规则是调用了相同的test文件,并且命令行参数是一些可以缓存的参数 包括 -cpu, -list,
    -parallel, -run, -short, and -v, 如果出现这些以外的参数,结果不会被缓存,如果你不想使用缓存,建议使用一些不可缓存的参数,最通用的取消缓存的做法是使用-count=1参数,test在根目录打开文件,或者查询环境变量的情况,只有这些参数没有发生变化的时候会被缓存匹配.

    一个缓存的测试结果会被当成执行时间为0,所以一个成功的包测试结果会重复使用 无视-timeout参数

'Go test' recompiles each package along with any files with names matching
the file pattern "*_test.go".
These additional files can contain test functions, benchmark functions, and
example functions. See 'go help testfunc' for more.
Each listed package causes the execution of a separate test binary.
Files whose names begin with "_" (including "_test.go") or "." are ignored.

Test files that declare a package with the suffix "_test" will be compiled as a
separate package, and then linked and run with the main test binary.

The go tool will ignore a directory named "testdata", making it available
to hold ancillary data needed by the tests.

As part of building a test binary, go test runs go vet on the package
and its test source files to identify significant problems. If go vet
finds any problems, go test reports those and does not run the test
binary. Only a high-confidence subset of the default go vet checks are
used. That subset is: 'atomic', 'bool', 'buildtags', 'errorsas',
'ifaceassert', 'nilfunc', 'printf', and 'stringintconv'. You can see
the documentation for these and other vet tests via "go doc cmd/vet".
To disable the running of go vet, use the -vet=off flag.

All test output and summary lines are printed to the go command's
standard output, even if the test printed them to its own standard
error. (The go command's standard error is reserved for printing
errors building the tests.)

Go test runs in two different modes:

The first, called local directory mode, occurs when go test is
invoked with no package arguments (for example, 'go test' or 'go
test -v'). In this mode, go test compiles the package sources and
tests found in the current directory and then runs the resulting
test binary. In this mode, caching (discussed below) is disabled.
After the package test finishes, go test prints a summary line
showing the test status ('ok' or 'FAIL'), package name, and elapsed
time.

The second, called package list mode, occurs when go test is invoked
with explicit package arguments (for example 'go test math', 'go
test ./...', and even 'go test .'). In this mode, go test compiles
and tests each of the packages listed on the command line. If a
package test passes, go test prints only the final 'ok' summary
line. If a package test fails, go test prints the full test output.
If invoked with the -bench or -v flag, go test prints the full
output even for passing package tests, in order to display the
requested benchmark results or verbose logging. After the package
tests for all of the listed packages finish, and their output is
printed, go test prints a final 'FAIL' status if any package test
has failed.

In package list mode only, go test caches successful package test
results to avoid unnecessary repeated running of tests. When the
result of a test can be recovered from the cache, go test will
redisplay the previous output instead of running the test binary
again. When this happens, go test prints '(cached)' in place of the
elapsed time in the summary line.

The rule for a match in the cache is that the run involves the same
test binary and the flags on the command line come entirely from a
restricted set of 'cacheable' test flags, defined as -cpu, -list,
-parallel, -run, -short, and -v. If a run of go test has any test
or non-test flags outside this set, the result is not cached. To
disable test caching, use any test flag or argument other than the
cacheable flags. The idiomatic way to disable test caching explicitly
is to use -count=1. Tests that open files within the package's source
root (usually $GOPATH) or that consult environment variables only
match future runs in which the files and environment variables are unchanged.
A cached test result is treated as executing in no time at all,
so a successful package test result will be cached and reused
regardless of -timeout setting.

In addition to the build flags, the flags handled by 'go test' itself are:

        -args
            Pass the remainder of the command line (everything after -args)
            to the test binary, uninterpreted and unchanged.
            Because this flag consumes the remainder of the command line,
            the package list (if present) must appear before this flag.

        -c
            Compile the test binary to pkg.test but do not run it
            (where pkg is the last element of the package's import path).
            The file name can be changed with the -o flag.

        -exec xprog
            Run the test binary using xprog. The behavior is the same as
            in 'go run'. See 'go help run' for details.

        -i
            Install packages that are dependencies of the test.
            Do not run the test.

        -json
            Convert test output to JSON suitable for automated processing.
            See 'go doc test2json' for the encoding details.

        -o file
            Compile the test binary to the named file.
            The test still runs (unless -c or -i is specified).

The test binary also accepts flags that control execution of the test; these
flags are also accessible by 'go test'. See 'go help testflag' for details.
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容