草庐IT

log4net-appender

全部标签

正在测试 log.Fatalf?

我想在go代码中实现100%的测试覆盖率。我无法涵盖以下示例-任何人都可以帮助我吗?packageexampleimport("io/ioutil""log")funccheckIfReadable(filenamestring)(string,error){_,err:=ioutil.ReadFile(filename)iferr!=nil{log.Fatalf("Cannotreadthefile...howtoaddcoveragetestforthisline?!?")}return"",nil}funcmain(){checkIfReadable("dummy.txt")}一

go - 不能使用 p[idx + 1 :] (type []Person) as type Person in append

这个问题在这里已经有了答案:cannotusetype[]runeastyperuneinappend(1个回答)关闭2个月前。packagemainimport("fmt")typePersonstruct{namestringageint}funcmain(){p:=[]Person{{"Kate",20},{"Simon",30},{"John",28},{"Lake",19},}n:=[]string{"Simon","Kate","Lake",}foridx:=0;idx我有上面的代码来删除pslice中显示在nslice中的人。但是在编译的时候出现了如下错误:./main.

unit-testing - 如何在不创建实际网络连接的情况下测试依赖于 net.Conn 的代码?

如果我有适用于net.Conn的代码,我如何在不实际创建与本地主机的网络连接的情况下为其编写测试?我在网上没有看到这个问题的解决方案;人们似乎要么忽略它(不进行测试),要么编写无法并行运行的测试(即使用实际的网络连接,这会耗尽端口),要么使用io.Pipe。不过,net.Conn定义了SetReadDeadline、SetWriteDeadline;而io.Pipe没有。net.Pipe也没有,尽管表面上声称要实现该接口(interface),但它只是通过以下方式实现:func(p*pipe)SetDeadline(ttime.Time)error{return&OpError{Op:

arrays - append() 如何在导致这种情况的幕后工作?

我是Go的新手,正在尝试追踪我的代码库中的错误。在此过程中,我已将问题归结为对append()的一次调用,但无法弄清楚为什么会这样......funcmain(){foo:=[]string{"a","b","c"}fmt.Printf("before:%v\n",foo)i:=0noop(append(foo[:i],foo[i+1:]...))//--callappend,butdonothingwiththeresultfmt.Printf("after:%v\n",foo)}funcnoop(ainterface{}){}//--avoid"evaluatedbutnotuse

logging - 是否可以修改其他包中定义的类型的方法集?

内置的log和log.Logger不提供Error或Warning方法,例如Python.所以我想用下面的代码为内置的Logger类型写一个:func(l*Logger)Error(vinterface{}){info:=fmt.Sprintf("ERROR:%v",v)l.Println(info)}然后我将上面的代码放在GOPATH/src/log下的文件morelog.go中。在main.go中我写道:logger:=log.New(os.Stdout,"Test",1)logger.Error("Errorinmain.")当我运行gobuild时,我得到:./main.go:

url - 使用 net/url 内置包解析带有矩阵参数的 URL

似乎URL不支持matrixparameters//Fromnet/urltypeURLstruct{SchemestringOpaquestring//encodedopaquedataUser*Userinfo//usernameandpasswordinformationHoststring//hostorhost:portPathstringRawQuerystring//encodedqueryvalues,without'?'Fragmentstring//fragmentforreferences,without'#'}为什么?如何从URL中提取矩阵参数?我什么时候应该使

tcp - Golang 写 net.Dial 响应给浏览器

我正在玩网络包,我想做一个简单的代理。首先我在本地主机上创建一个监听器,然后我调用远程地址remote,err:=net.Dial("tcp","google.com:80")iferr!=nil{log.Fatal(err)}deferremote.Close()fmt.Fprint(remote,"GET/HTTP/1.0\r\n\r\n")如何通过管道将响应传递给浏览器?还是我需要使用默认网络服务器并复制响应正文?很想用netpackage什么的试试谢谢 最佳答案 要从远程复制连接,使用2个带有io.Copy的goroutin

go - 捕获传递给 http.Server.Serve 的 net.Listener

我想通过执行正常关闭和我将在我的HTTP服务中共享的其他一些小工具来扩展http.Server功能。目前我的代码或多或少说:typeMyServerstruct{server*http.Server//...}func(s*MyServer)ListenAndServe(){//Createlistenerandpasstos.server.Serve()}这很有效很好,但是需要手动公开http.Server的所有必要方法和变量。包装大多数方法不会是一个大问题,但我无法找到一种明智的方法来公开对http.Server.ListenAndServeTLS的访问,而无需实际从thesour

go - 无法使用自制软件安装编译在 OS X 上导入 net/http 的程序

我已经在我的OSX10.10机器上安装了gousingHomebrew。每次我尝试编译导入net/http的示例应用程序时,我都会收到以下错误:loadcmd/cgo:packagecmd/cgo:noGosourcefilesin/Users/bbaron/google_appengine/goroot/src/cmd/cgo我的GOPATH变量设置正确($HOME/go)并且我的目录结构看起来是正确的:/Users/bbaron/go/src/github.com/einsteinx2/gamenotifier/Users/bbaron/go/src/github.com/eins

Go logging struct 实例化实用方法的 Goroutine 线程安全

我正在使用一个新的go服务,我有一个SetupLogger实用函数,它创建一个新的go-kit日志结构实例log.Logger。从在单独的go-routines中处理请求的代码调用此方法是否安全?packageutilsimport("fmt""github.com/go-kit/kit/log""io""os""path/filepath")//Iftheenvironment-specifieddirectoryforwritinglogfilesexists,opentheexistinglogfile//ifitalreadyexistsorcreatealogfileifno