草庐IT

test_map

全部标签

testing - 测试 Go 时如何跨包共享设置和拆卸方法?

假设我有两个包foo和bar。每个包都有文件和一个测试文件:foo---widget.go---widget_test.gobar---wingding.go---wingding_test.go现在对于两个测试(widget_test.go和wingding_test.go),我想分享一些设置代码。我知道我可以将这段代码放在main_test.go中的每个包中。但我显然不想在两个地方复制/粘贴代码。那么我可以将此代码放在哪里以便跨包共享呢? 最佳答案 把它放在另一个包baz中,foo和bar都在他们的测试中导入。我们将其用于测试中

testing - go中接口(interface)模拟的方法

如果我有一个如下所示的handlerfunc。“模拟”或注入(inject)包装某些对象以进行测试的接口(interface)的最佳方法是什么?funcGetOrCreateUser(whttp.ResponseWriter,r*http.Request){user:=GetUserFromContext(r.Context())ifcreated:=user.GetOrCreate();created{smtp.SendEmail(...)return}else{w.Write([]byte("HelloUser!"))}}我遇到的唯一方法似乎是这样做:typeMailerinter

testing - echo c.Get ("user") 在测试环境中不起作用

我正在尝试测试基于echo框架/路由器构建的golangAPI。我有以下测试......funcTestLogout(t*testing.T){loadConfig()db:=stubDBs(t)Convey("Whenyoupostto/logout",t,func(){Convey("withavalidtoken,youshouldgetaasuccessmsgandbeloggedout",func(){e:=echo.New()e.Use(middleware.JWTWithConfig(middleware.JWTConfig{SigningKey:[]byte("secr

testing - 如何模拟 DNS 请求? (米克/dns)

我有一小段代码来解释我要测试的代码库。我已经跳过检查错误以使问题简短。funclastCNAME(domainstring)(lastCNAMEstring){ns:="8.8.8.8:53"c:=dns.Client{}m:=dns.Msg{}m.SetQuestion(domain,dns.TypeA)r,_,_:=c.Exchange(&m,ns)//LastCNAMEfor_,ans:=ranger.Answer{cname,ok:=ans.(*dns.CNAME)ifok{lastCNAME=cname.Target}}returnlastCNAME}模拟对名称服务器8.8.

dictionary - 带 map 优化的嵌套范围循环

我正在尝试从结构字段中收集所有X和Y值,并将属于同一X值的Y值放置在映射中,但它嵌套了3层。目前,我正在使用以下代码:topClasses:=make([]TopClass,0)//populatetopClassesSlicehereKeyValueMap:=make(map[int][]int)for_,nestedClass:=rangetopClasses{for_,nestedItem:=rangenestedClass.nestedList{for_,value:=rangenestedItem.Values{if_,found:=KeyValueMap[value.X];

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

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

python - AttributeError : dlsym(0x7fc4cfd563b0, add_all_items_to_map): symbol not found;使用 C 从 Python 运行 Go

我有以下go文件://try_async.gopackagemainimport("C""fmt""math/rand""sync""time")varmutexsync.Mutexvarwgsync.WaitGroupfuncrandom_sleep(){r:=rand.Intn(3000)time.Sleep(time.Duration(r)*time.Millisecond)}funcadd_to_map(mmap[string]string,wordstring){deferwg.Done()added_word:=word+"plusmoreletters"fmt.Print

json - 将复杂的 JSON 转换为 Golang 中的 map

如何在golang中将复杂的JSON对象转换为具有所有正确类型的映射。我是否绝对必须做典型的Golang事情,即我用我知道会出现的字段创建一个结构,或者是否有一种通用的方法来获取所有正确类型的字段?这是我想转换为map的JSON示例:{"people":[{"diffs":[77],"original":{"name":"Nick","active":"Active","email":"nick@example.com"},"id":"21"}]} 最佳答案 您可以构建一个带有类型断言开关的递归函数,以将JSON数组类型断言到多维映

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相关的错误。但我无法解决的问题