草庐IT

power_unit

全部标签

unit-testing - 使用简单的 http 处理程序测试所有路径

我正试图在这个简单的http处理程序文件上获得100%的代码覆盖率。如果成功,该文件将写入默认响应header,然后返回200和我在下面测试过的“Pong”。但是,也有可能写入默认header会产生错误,在这种情况下,预期会出现带有内部错误正文的500响应。我正在努力弄清楚如何在测试中触发500响应案例。如果出于某种原因将writeDefaultHeaders函数调用的第二个参数更改为“html”,则该案例将失败,因为html不是我的服务中受支持的响应内容类型。在代码中模拟此调用/命中此错误分支的惯用方法是什么?谢谢。ping_handler_test.gopackagemainimp

unit-testing - 使用简单的 http 处理程序测试所有路径

我正试图在这个简单的http处理程序文件上获得100%的代码覆盖率。如果成功,该文件将写入默认响应header,然后返回200和我在下面测试过的“Pong”。但是,也有可能写入默认header会产生错误,在这种情况下,预期会出现带有内部错误正文的500响应。我正在努力弄清楚如何在测试中触发500响应案例。如果出于某种原因将writeDefaultHeaders函数调用的第二个参数更改为“html”,则该案例将失败,因为html不是我的服务中受支持的响应内容类型。在代码中模拟此调用/命中此错误分支的惯用方法是什么?谢谢。ping_handler_test.gopackagemainimp

unit-testing - 初始化函数中断单元测试

在我要测试的包中,我有一个init函数,它加载配置文件,其中包含一些我想用来运行我的应用程序的东西。但是,我不想在运行单元测试时触发此init函数。有什么方法可以跳过或阻止在单元测试期间调用此init函数吗?一些片段来说明这个问题:funcinit(){varerrerror//Necessarytopreventconfigvariableshadowingconfig,err=loadConfig("./client/config.yml")iferr!=nil{log.Fatal(err)}}funcloadConfig(filepathstring)(*Config,error

unit-testing - 初始化函数中断单元测试

在我要测试的包中,我有一个init函数,它加载配置文件,其中包含一些我想用来运行我的应用程序的东西。但是,我不想在运行单元测试时触发此init函数。有什么方法可以跳过或阻止在单元测试期间调用此init函数吗?一些片段来说明这个问题:funcinit(){varerrerror//Necessarytopreventconfigvariableshadowingconfig,err=loadConfig("./client/config.yml")iferr!=nil{log.Fatal(err)}}funcloadConfig(filepathstring)(*Config,error

unit-testing - 检查测试在不运行它们或创建二进制文件的情况下编译

我如何使用Go检查我的测试是否编译而不创建任何二进制文件或执行测试?gobuild./...的测试等效项,它执行此操作但忽略测试。 最佳答案 我使用任何不匹配的正则表达式作为运行标志,比如gotest-runNONE./... 关于unit-testing-检查测试在不运行它们或创建二进制文件的情况下编译,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32162657/

unit-testing - 检查测试在不运行它们或创建二进制文件的情况下编译

我如何使用Go检查我的测试是否编译而不创建任何二进制文件或执行测试?gobuild./...的测试等效项,它执行此操作但忽略测试。 最佳答案 我使用任何不匹配的正则表达式作为运行标志,比如gotest-runNONE./... 关于unit-testing-检查测试在不运行它们或创建二进制文件的情况下编译,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32162657/

unit-testing - 在测试中覆盖 Go 方法

所以我有这个Client结构,它有一个方法UserByID,它向User的端点发出HTTP请求。我想对该函数进行单元测试,但也不想在函数c.Request中发出实际的HTTP请求。我想用我可以控制的响应和错误来stub该函数。func(cClient)UserByID(idstring)(uUser,errerror){v:=url.Values{}v.Set("id",id)opts:=Request{HTTP:http.Request{Method:http.MethodGet,Form:v,},URL:'some/endpoint/users',}resp,err:=c.Requ

unit-testing - 在测试中覆盖 Go 方法

所以我有这个Client结构,它有一个方法UserByID,它向User的端点发出HTTP请求。我想对该函数进行单元测试,但也不想在函数c.Request中发出实际的HTTP请求。我想用我可以控制的响应和错误来stub该函数。func(cClient)UserByID(idstring)(uUser,errerror){v:=url.Values{}v.Set("id",id)opts:=Request{HTTP:http.Request{Method:http.MethodGet,Form:v,},URL:'some/endpoint/users',}resp,err:=c.Requ

unit-testing - 在 Golang 中进行单元测试时如何测试是否调用了 goroutine?

假设我们有这样一个方法:funcmethod(intrMyInterface){gointr.exec()}在单元测试method中,我们想断言inter.exec被调用了一次且仅调用了一次;所以我们可以在测试中用另一个模拟结构模拟它,这将为我们提供检查它是否被调用的功能:typemockInterfacestruct{CallCountint}func(m*mockInterface)exec(){m.CallCount+=1}在单元测试中:funcTestMethod(t*testing.T){varmockmockInterface{}method(mock)ifmock.Cal

unit-testing - 在 Golang 中进行单元测试时如何测试是否调用了 goroutine?

假设我们有这样一个方法:funcmethod(intrMyInterface){gointr.exec()}在单元测试method中,我们想断言inter.exec被调用了一次且仅调用了一次;所以我们可以在测试中用另一个模拟结构模拟它,这将为我们提供检查它是否被调用的功能:typemockInterfacestruct{CallCountint}func(m*mockInterface)exec(){m.CallCount+=1}在单元测试中:funcTestMethod(t*testing.T){varmockmockInterface{}method(mock)ifmock.Cal