草庐IT

test_channel

全部标签

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/

go - 从 Sarama 的错误 channel 中读取的正确方法是什么?

当我生成一条消息时,我正在使用用Go编写的Sarama库从错误channel中读取。整体代码如下所示,包含在一个函数中:producer.AsyncProducer.Input()根据我对go例程的理解,我的go例程会不断迭代Errors()channel,直到它收到一个错误。有没有办法让它在我的函数执行完毕后停止监听错误? 最佳答案 您可以使用另一个channel和一个select来使循环返回。varquitchanstruct{}gofunc(){for{select{caseerr:=原始的for...range循环在获得ch

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

带有 for 循环的 golang channel 行为

我很好奇channel的行为以及它们与循环相关的工作方式。假设我有以下代码:消费者tick:=time.Tick(time.Duration(2)*time.Second)for{select{case我有一个goroutine具有以下内容:处理器for{select{casecanProcess:=如果消费者推送到channel的速度比处理器完成同步过程的速度快,会发生什么情况?它们是堆积起来等待处理器完成,还是跳过一个“节拍”?如果它们堆积起来,是否存在内存泄漏的可能性?我知道我可以将同步过程放在goroutine中,但这实际上是为了了解channel的行为方式。(即我的示例有一个

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

unit-testing - 用单元测试覆盖主函数中的代码

Golang显示我只有50%的覆盖代码,而且我看到main中的代码没有被覆盖,我尝试搜索但没有找到任何解释如何覆盖main中的代码的内容。ma​​in.gopackagemainfuncSum(xint,yint)int{returnx+y}funcmain(){Sum(5,5)}ma​​in_test.gopackagemainimport("testing")funcTestSum(t*testing.T){total:=Sum(5,5)iftotal!=10{t.Fail()}} 最佳答案 测试文件通常紧挨着他们测试的代码。根

caching - channel 并发保证

我正在写一个并发安全的备忘录:packagemuimport("sync")//Funcrepresentsamemoizablefunction,operatingonastringkey,tousewithaMutypeFuncfunc(keystring)interface{}//Muisacachethatmemoizesresultsofanexpensivecomputation////Ithasatraditionalimplementationusingmutexes.typeMustruct{//guardsdonemusync.RWMutexdonemap[stri

opengl - 渲染不同于单 channel 渲染

我已经开始更新我的代码以允许多channel渲染。我相当确定我正在做正确的帧缓冲区,但不知何故我没有得到我想要的结果。我使用的代码基于以下教程:https://learnopengl.com/Advanced-OpenGL/Framebuffers当我渲染到默认缓冲区时,我得到的正是我所期望的:然而,当我将其渲染为非默认帧缓冲区纹理并将其放置在四边形上时,我得到了这个非常令人费解的结果:所以我最初的想法是,我绘制放置非默认帧缓冲区纹理的四边形(跨越窗口所有四个角的四边形)的方式有问题。但是当只渲染那个,启用线框时,我得到的正是我所期望的(以及教程确认我会得到的):所以我认为我的代码可能