草庐IT

query_cache_min_res_unit

全部标签

unit-testing - 使 ioutil.ReadAll(response.Body) 在 golang 中抛出错误

出于某种原因,我似乎无法获取ioutil.ReadAll(res.Body),其中res是*http.Response由res,err:=hc.Do(redirectRequest)返回(对于hchttp.Client,redirectRequest*http.Request)。到目前为止的测试策略任何时候我在SUT中看到hc.Do或http.Request,我的直觉是启动一个假服务器并指向适当的申请说明。这样的服务器,对于这个测试,看起来像这样:badServer:=httptest.NewServer(http.HandlerFunc(func(whttp.ResponseWrit

go - 不能在 db.Query 的参数中使用缓冲区(类型 bytes.Buffer)作为类型字符串

我在buffer.WriteString()中编写了一个SQL查询,但无法在db.Query()中使用该缓冲区。buffer.WriteString(fmt.Sprintf(`SELECTc.id,c.company_name,ss.start_date,ss.shift_length,ss.bill_rate,ss.ot_hrs,ss.dt_hrs,ts.pay_rate,ts.wc_rate,ts.paid,td.wcFROMcompanycJOINusersu1ONc.id=u1.company_idJOINschedulesONu1.id=s.user_idJOINschedu

unit-testing - 如何测试 bytes.ErrTooLarge panic 错误

我想在bytes.Buffer.Write方法上模拟bytes.ErrTooLargepanic错误并测试panic处理。我试图写入无限量的数据以超过内存,但随后整个测试崩溃了。还有哪些选择? 最佳答案 听起来像是模拟对象的工作。在测试期间使用此(badBuffer)代替bytes.Buffer。typebadBufferbytes.Bufferfunc(b*badBuffer)Write(p[]byte)(nint,errerror){panic(bytes.ErrTooLarge)}

go - 为什么 Golang http 参数 (URL.Query()) 是列表的映射?

当我们打电话r.URL.Query()在Go中的http路由处理程序中,它返回一个map[string][]string。我想知道为什么它是一个列表,以及我是否可以在发送请求时以某种方式使用此属性。 最佳答案 它是一个列表,因为它允许在URL中发送相同查询字符串参数的多个副本,是的,您可以在请求中发送查询字符串参数。例如对于像http://example.com/?foo=1&foo=2这样的URL,Query()会返回:{"foo":["1","2"]} 关于go-为什么Golangh

unit-testing - 单元测试具有 ORM 交互的 Go 函数

我写了一个函数:funcAllItems(whttp.ResponseWriter,r*http.Request){db,err:=gorm.Open("sqlite3","test.db")iferr!=nil{panic("failedtoconnectdatabase")}deferdb.Close()varitems[]Itemdb.Find(&items)fmt.Println("{}",items)json.NewEncoder(w).Encode(items)}我想对此进行单元测试。理想情况下,单元测试意味着需要测试函数的每一行。我不确定我应该如何测试数据库连接是否打开以

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:

unit-testing - 如何获得文件夹的全局测试覆盖率

显示代码覆盖率时,gotest显示每个包的代码覆盖率(百分比)。有没有办法显示一个考虑了所有子文件夹(子包)的文件夹的摘要?我想要的是整个项目的全局代码覆盖率,一个显示文件夹和所有子文件夹的代码覆盖率的数字。 最佳答案 运行后:gotest--coverprofile=coverage.out./...运行:gotoolcover-func=coverage.out您将在结果末尾看到总百分比 关于unit-testing-如何获得文件夹的全局测试覆盖率,我们在StackOverflow上

unit-testing - 我可以使用嵌套界面模拟库代码吗?

这个问题在这里已经有了答案:HowcanImockmultipletypeswhenthesignatureofaconcretemethodreferstoanotherconcretetype,notitsinterface?(1个回答)关闭3年前。我正在尝试在我的go代码中的测试中模拟第3方库。但是我无法编译我所采用的方法。如果我想模拟T2.M2的结果,有什么方法可以使它工作,或者我可以采用另一种方法吗?packagemainimport("fmt")//TwotypesinalibrarythatIdonthavecontrolovertypeT1struct{}func(T1

unit-testing - Go 应用程序在测试包含锁的函数时挂起

这是我编写的一个函数,用于将请求添加到请求队列:func(self*RequestQueue)addRequest(request*Request){self.requestLock.Lock()self.queue[request.NormalizedUrl()]=request.ResponseChannelself.requestLock.Unlock()}这是它的测试之一:funcTestAddRequest(t*testing.T){before:=len(rq.queue)r:=SampleRequests(1)[0]rq.addRequest(&r)if(len(rq.q

unit-testing - Google App Engine 数据存储 - 测试查询失败

我目前正在尝试测试我的一段代码,该代码在放入新实体之前在数据存储上运行查询以确保不会创建重复项。我编写的代码在应用程序的上下文中运行良好,但我为该方法编写的测试失败了。似乎我无法通过测试包上下文中的查询访问放入数据存储区的数据。一种可能性可能在于goapptest的输出,其中显示:Applyingallpendingtransactionsandsavingthedatastore。这行在调用get和put方法后打印出来(我用日志语句验证了这一点)。我尝试关闭上下文并为不同的操作创建一个新上下文,但不幸的是,这也无济于事。下面是一个简单的测试用例,它放入一个对象然后对其运行查询。任何帮