草庐IT

test-mail-server-tool

全部标签

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都在他们的测试中导入。我们将其用于测试中

go - Go Server无需重启的无缝补丁部署

我很好奇是否有任何解决方案可以部署go服务器而无需将其关闭并重新启动。我知道ASP.Net和PHP等流行的解决方案可以为用户session无缝执行此操作。无状态session会处理这个问题吗? 最佳答案 即使是最简单的应用程序服务器也可以通过引入请求路由器(例如nginx)来实现这种无缝部署。或haproxy.这两个路由器都允许您将请求转发到不同的服务(称为反向代理),并在不断开连接的情况下重新加载它们的配置。举个例子:将您的路由器配置为监听0.0.0.0.80并将这些请求转发到127.0.0.1:5001。在127.0.0.1:5

sql-server - 使用 ODBC 驱动程序调用 Microsoft SQL Server 上的存储过程

我有一个存储过程,名称为“vijaystoredprocedure”,如果它是mssql中的一些查询,那么我将在Go中查询,如l_query_str=fmt.Sprintf(`select*fromUserswhereFname='%s'`,l_firstanme)row,err:=DBC.Query(l_query_str)iferr!=nil{log.Fatal("Preparefailed:",err.Error())}_,rows,r_err:=DBScan_fn(row)ifr_err!=nil{fmt.Println("nodatafounderr")return}现在因为

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

go - 如何捕获 "http: server closed idle connection"错误

在我的go应用程序中,我收到以下错误:“http:服务器关闭空闲连接”。我想捕获它并在遇到它时重试我的http连接。我发现这个错误来自“net/http”包,而且来自传输实现。特别是它定义了here我把它包裹在url.Error中,但这就是我能找到的全部。你知道我怎样才能真正捕捉到这个错误吗?编辑:我正在使用elasticsearchclient,它又使用net/http。我从客户端收到上述错误,并希望重试我的Elasticsearch请求,因为它是暂时的。现在我捕捉暂时性错误的方式是:ifurlErr,ok:=err.(*url.Error);ok&&(urlErr.Temporar

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

docker - 错误 : hyperledger/fabric:make gotools: unrecognized import path "golang.org/x/tools/go/gcexportdata"

当makepeer时,它无法访问build/docker/gotools/bin/protoc-gen-go,所以我makegotools,但是失败了,这是日志:mkdir-pbuild/bincdgotools&&makeinstallBINDIR=/root/gocode/binmake[1]:Enteringdirectory'/root/gocode/src/github.com/hyperledger/fabric/gotools'make[2]:Enteringdirectory'/root/gocode/src/github.com/hyperledger/fabric/

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.

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