草庐IT

test-coverage

全部标签

go - 为什么我们在 Go 中的 foo() 中有一个独立的 test() ?

为什么下面代码中的test()函数是这样组织的,而不是将test()中的所有内容都取出来放入foo()中?谢谢!funcfoo()error{...err=test()error{......}...} 最佳答案 您可能需要这样的内部函数有多种原因,但到目前为止,最常见的用途是当您需要在内部函数中使用包含函数的局部变量时。为什么要有一个内部函数?有时您需要它传递到库中,或者您需要它用于go或defer语句。内部函数“关闭”它使用的任何来自外部函数的变量,即使在外部函数返回后这些变量仍然有效。因此,以这种方式定义的函数称为“闭包”。一

unit-testing - assert_called_once() 或 assert_called_xyz().... 等效?

能够断言在我的测试中调用了多少次伪造/模拟方法对我来说很重要,我想知道在不使用testify之类的情况下执行此操作的最佳方法是什么。在我的例子中,对模拟方法的调用是一些递归调用的结果。假设我对各种动物进行了表驱动测试,我想断言Hello实际上是为某些测试调用的,但不是为其他测试调用的。在某些情况下,对于给定的测试(遍历一个slice)应该多次调用它。在我的表驱动测试中只添加一个计数器并对其进行断言是否合适?在我看来,也许有更好的方法可以做到这一点。如果我确实在hello方法中添加了一个计数器...应该在哪里处理和检查它。在假方法本身还是在测试等中?typefakeFarmService

testing - 未调用的测试如何影响 Go 中的另一个测试?

我在https://github.com/VertebrateResequencing/wr/blob/develop/jobqueue/jobqueue_test.go中有一个测试函数TestJobqueue()我可以单独调用:gotest-tagsnetgo./jobqueue-v-run'TestJobqueue$'。我最近开始遇到与boltdb(我的依赖项之一)相关的测试失败,并伴随着signalSIGBUS:buserrorcodepanic,或者通常测试失败是因为无法打开数据库。但仅在处理NFS安装目录时。很公平,我或boltdb有某种与NFS相关的错误。但我无法解决的问题

unit-testing - 让 'go test -run <case>' 成功为 'go test' 的一般规则是什么?

我发现'gotest'PASS,但是如果我指定subtest,它会失败,这里我给一个全局变量sample,'gotest'会PASS,'gotest-runf/sample2'会失败.我想知道我应该遵循什么一般规则来防止此类问题?走吧packagemainimport"fmt"vargstringfuncf(sstring)string{g=g+sreturns+g}funcmain(){fmt.Println(f("a"))}t_test.gopackagemainimport("testing")funcTest_f(t*testing.T){tests:=[]struct{nam

unit-testing - 如何使用结构/接口(interface)来模拟依赖项以进行测试

我是新手...我的目标是单元测试我的ready()中的状态是否正在更新。我一直在看https://engineering.aircto.com/writing-testable-code-in-golang/并尝试找出如何使他们正在做的事情适应我的用例,尽可能填补golang知识的空白。我收到错误消息cannotusefakeSession(type*FakeSession)astype*discordgo.Sessioninargumenttoready但我不确定为什么我'我收到此错误。ma​​in.goimport("fmt""os""os/signal""syscall""git

testing - Golang Benchmark 表测试,我可以从b.Run()中提取func吗?

在golang中进行基准示例测试后,我可以进行以下测试://AnexamplebenchmarktobenchmarkaquerybasedondifferentinputsfuncBenchmark_GetProcessingCountForRegions(b*testing.B){benchmarks:=[]struct{regionstring}{{"EU"},{"US"},}for_,bm:=rangebenchmarks{b.Run(bm.region,func(bbb*testing.B){fori:=0;i这是网络上的默认示例,适用于我;测试taskDb包在GetProc

go test 仅在测试完成后打印输出

我注意到gotest似乎在测试完成后打印到标准输出。我不确定这是gotest的问题,还是因为我正在使用ginkgo以及。有谁知道如何让它在测试运行时打印输出? 最佳答案 在gotest上使用verbose标志以在测试运行时查看日志或打印语句的输出。gotest-v 关于gotest仅在测试完成后打印输出,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/47535538/

unit-testing - Go - 表驱动测试辅助函数

我发现了很多关于表驱动测试的好例子,但似乎没有人写过关于创建辅助测试方法以传递要测试的函数的下一步。这样就不必为您要测试的每个函数重复这部分代码:funcTestFib(t*testing.T){for_,tt:=rangefibTests{actual:=Fib(tt.n)ifactual!=tt.expected{t.Errorf("Fib(%d):expected%d,actual%d",tt.n,tt.expected,actual)}}}//from:https://medium.com/@matryer/5-simple-tips-and-tricks-for-writin

testing - 如何使用标准的 Go 测试包实现 BDD 实践?

我想先写测试,再写让测试通过的代码。我可以这样写测试函数:funcTestCheckPassword(t*testing.T){isCorrect:=CheckPasswordHash("test","$2a$14$rz.gZgh9CHhXQEfLfuSeRuRrR5uraTqLChRW7/Il62KNOQI9vjO2S")ifisCorrect!=true{t.Errorf("Passwordiswrong")}}但我想为每个测试函数提供更多描述性信息。例如,我正在考虑为我的应用程序创建身份验证模块。现在,用简单的英语,我可以很容易地描述我对这个模块的要求:它应该接受一个非空字符串作

go test 无法使用命令 : go test file1_test. go file2.go 加载包

我正在编写单元测试。我将所有测试文件放在其他目录中。假设文件夹mypack。fun1_test.go和base.go文件夹下有两个文件。base.go具有与fun1_test.go相同的通用基本函数。base.go看起来像:packagemypack_testimport(.....)funcBase1(){//somecode}func1_test.go具有测试func1的函数。func1_test.go看起来像:packagemypack_testimport(.....)funcTestFunc1(){//somecodeBase1()//somecode}当我使用命令时gote