草庐IT

Quiz_for_Unit

全部标签

for-loop - 字符串 slice 的范围不一致

这段代码:import"fmt"import"time"funcmain(){string_slice:=[]string{"a","b","c"}for_,s:=rangestring_slice{gofunc(){time.Sleep(1*time.Second)fmt.Println(s)}()}time.Sleep(3*time.Second)}产生输出“ccc”,而这段代码:import"fmt"funcmain(){string_slice:=[]string{"a","b","c"}for_,s:=rangestring_slice{s="asd"fmt.Println(

unit-testing - 如何模拟getClient?

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭4年前。Improvethisquestion我有一个功能:funcHTTPGet(urlstring)(*http.Response,error){resp,err:=getClient().Get(url)returnresp,err}getClient函数是:vardefaultClient*http.ClientfuncgetClient()*http.Client{ifdefaultClient==nil{defaultClient

for-loop - Golang 一行for循环

我试图用一个for循环逐行读取Golang中的CSV文件,该循环需要一个带有中断的if语句来查看读取文件的错误是否是EOF。我发现这种语法相当不必要,因为我可以在java中读取while循环条件中的行并同时检查EOF错误。我认为在for循环内声明一个变量是可能的,而且我确信你可以在Golang中使用if语句来做到这一点。正在做:ifv:=2;v>1{fmt.Println("2isbetterthan1")}我这里的第一段代码是我知道可以在我的程序中使用的代码。reader:=csv.NewReader(some_file)for{line,err:=reader.Read()ifer

go - for init 语句只进入函数一次

我开始使用Go进行编程,我正在尝试创建一个程序来查询数据库并返回数据。我做到了这一点,但在此期间我遇到了一些问题。首先,我尝试创建一个带有条件的for来告诉程序何时我想停止查询,但是for的Init语句看起来只被评估一次-而且我再也不会被要求通过输入输入terminal-(我在这里读到是因为他的值是hold然后它不再执行函数:Golangswitchstatementonlycallsfunctiononce):已编辑funcmain(){varquerystringforquery=ReadQuery();query!="exit\n";{rows,err:=db.Query(que

unit-testing - 在 Go 单元测试中使用两个不同的模拟

我正在学习使用gomock的mockgen实用程序第一次在Go中使用mock进行单元测试。我的单元测试工作正常,除了其中一个。被测方法有两个依赖项:一个依赖于数据库,另一个依赖于它调用restapi的外部服务。数据库的模拟(mockRepo)工作正常,因为被测方法正确调用模拟而不是实际的repo代码。然而,rest客户端的mock继续调用实际的rest客户端而不是mock代码。我不知道为什么。有人可以解释原因并帮助修复吗?这是我的单元测试:funcTestService_CreateWorkspace(t*testing.T){ts:=NewTestService(t)deferts.

arrays - Append for array of maps raplaces all previous array items on the 最新的一个

这个问题听起来可能很愚蠢,但我真的不明白哪里出了问题。我想像这样创建一个map数组:values:=make([]map[string]string,0)然后我创建一些map:row:=make(map[string]string)row["item1"]="value1"row["item2"]="value2"然后将其追加到数组中:values=append(values,row)打印值现在给出:[map[item1:value1item2:value2]]使用其他一些值做同样的事情:row["item1"]="value3"row["item2"]="value4"values=

unit-testing - 如何测试以确保函数被调用?

我想做单元测试。为了简单起见,我只想确保调用“JWTCheck”。我该怎么做?这是我实现JWTCheck的文件:typeJWTCheckerstruct{SubjectPrefixstring}func(j*JWTChecker)JWTCheck(nexthttp.Handler)http.Handler{//Dosomething}这是我实现路由器的地方:import("net/http""github.com/gorilla/mux")//Routerreturnsapreconfiguredrouterforapplicationfunc(a*Adapter)Router()ht

gorequest 包 : check specifically for timeout

我正在使用以下包发出出站http请求https://github.com/parnurzeal/gorequest例如,我正在发出如下所示的GET请求res,body,errs=goReq.Get(url).End()我的问题是如何判断请求是否超时。 最佳答案 由于超时方法setsthedealinesfordial,read,andwrite,你可以使用os.IsTimeout(net和net/url包中的所有错误类型都实现了Timeout()bool)。gorequest不支持上下文,所以context.Canceled不必考虑

unit-testing - 如何确保所有异步函数在执行 defer 之前运行

我有一个函数说Myfunction(){x.RunAsync()//AsyncFunctioncall}我必须为Myfunction()编写一个测试用例。我正在为此使用go-mock。还有mockedx。Test_MyFunction(){mockCtrl:=gomock.NewController(t)defermockCtrl.Finish()//EXPECT()calltostubRunAsync()}现在的问题是我的测试运行成功,但不知何故最后它panic地说,对mockX.RunAsync()的调用丢失了。我认为这是因为在我的RunAsync被stub之前正在执行延迟。如何确

go - 在 "for {select }"结构中添加一个简单的 fmt.Println 后,CPU 使用率有很大不同,为什么?

遇到困惑的情况:假设我们有一个用Go编写的for{select}函数。下面是代码:packagemain//import"fmt"funcmain(){for{select{default:_=11.firstsituation//fmt.Sprint("aa")2.secondsituation}}}而在第一种情况下,杯子的使用情况如下所示:在第二种情况下,CPU使用情况如下所示:我猜fmt.Println中发生了一些事情。可能跟Go的fmt实现机制有关?不太清楚使用所有CPU是如何发生的?提前致谢! 最佳答案 我的猜测:在第一个