草庐IT

test_channel

全部标签

unit-testing - 我如何对文本将出现在屏幕中央进行单元测试?

这是一个小脚本。packagebashutilimport("fmt""github.com/nsf/termbox-go")funcCenter(sstring){iferr:=termbox.Init();err!=nil{panic(err)}w,_:=termbox.Size()termbox.Close()fmt.Printf(fmt.Sprintf("%%-%ds",w/2),fmt.Sprintf(fmt.Sprintf("%%%ds",w/2+len(s)/2),s),)}我可以对其进行单元测试吗?我怎样才能测试它?我认为测试一个片段这么少是胡说八道。但是,...如果我

testing - golang 单元测试 : inner function parameters

我在go函数中的工作流程很简单,但是当进行单元测试时,我卡在了将参数传递给内部函数,或者模拟内部函数返回结果。代码:packagemyFuncimport(myPackagebookPackage)funcInit()(errerror){err=getResource(myPackage.GetPath())...}funcgetResource(pathstring)(errerror){//getresourcefrompath...err:=bookPackage.GetBook(path)}测试:packagemyFuncimport"testing"funcTestInit

戈朗 : strange issue with coroutines and channels

我写了一个测试代码,但不明白为什么会得到这个结果。我的sub()应该根据channel值更新或返回countersend1=counter++send0=returncounter我启动了10个go例程con()。他们应该简单地发送许多1到channel(这个增加计数器)我等待1秒并将0发送到channel。我应该获得什么值(value)?我想首先,我得到一个“随机”值,但我得到100000(好的10x10000比1秒快)现在我变了fori:=0;i到fori:=0;i现在我的返回值是1为什么!?现在取消注释main()中的fmt.Println(counter)。如您所见,计数器工作

testing - 如何在单元测试中测试函数的输出 (stdout/stderr)

我有一个简单的函数要测试:func(t*Thing)print(min_verbosityint,messagestring){ift.verbosity>=minv{fmt.Print(message)}}但是我怎样才能测试函数实际发送到标准输出的内容呢?Test::Output在Perl中做我想做的事。我知道我可以编写自己的所有样板文件以在Go中执行相同的操作(如here所述):orig=os.Stdoutr,w,_=os.Pipe()thing.print("Somemessage")varbufbytes.Bufferio.Copy(&buf,r)w.Close()os.Std

go - 缓冲/非缓冲 channel 和死锁

为了学习,我使用这段代码来玩goroutines。我无法得到不同的东西:packagemainimport("fmt""time")funcmain(){ch1:=make(chanstring)//ch2:=make(chanstring)//gotest(ch1,ch2)ch1ch2fmt.Scanln()}functest(ch1chanstring,ch2chanstring){timeout:=time.After(time.Second*2)//deferfunc(){fmt.Println("returning")}()for{select{cases:=如果我按原样运行

csv - 我如何在 golang 中覆盖未知类型的 channel

我有一个函数,它接收一个字符串,并基于它创建一个基于字符串值的类型的channel。然后发送该channel以在另一个线程中填充。在这个函数中,我然后想要范围填充的值并使用它们。但是,我收到一个错误:“无法覆盖myChan(类型接口(interface){})”这是我的代码示例:funcmyFunc(inputstring){varmyChaninterface{}switchinput{case"one":myChan=make(chanOne)case"two":myChan=make(chanTwo)}godoStuff(&myChan)for_,item:=rangemyCha

unit-testing - 如何在 Golang 中正确模拟具有成员函数的结构?

我有两个结构:FunctionalityClient和TestClient,它们都实现了Interface。我有一个Interface类型的全局变量Client。我将实际客户端或模拟客户端分配给Client,具体取决于它是测试还是正常运行。Interface有一个方法Request我想在测试中模拟它。也就是说,我想:记录传递给函数的参数是什么从函数返回一些任意定义的返回值所以结构看起来像这样:typeTestClientstruct{recordedArgs[]interface{}returnValues[]interface{}}func(c*TestClient)Request(

go - 动态创建 channel 以用作 Go 中可变参数函数的参数

是否可以在Go中动态创建一个channel,然后给它赋值?此扇出扇入代码适用于f1:=factorial(in)f2:=factorial(in)forn:=rangemerge(f1,f2){fmt.Println(n)}但我想做类似的事情varres[2]这给出了以下错误$gorunmain.go#command-line-arguments.\main.go:26:cannotuseres(type[2]这里是完整的代码...packagemainimport("fmt""sync")funcmain(){in:=gen()f1:=factorial(in)//codetober

multithreading - Goroutines, channels select 语句

我在构建我的goroutines和channel时遇到问题。我的select语句在所有goroutine完成之前一直退出,我知道问题出在我发送完成信号的地方。我应该在哪里发送完成信号。funcstartWorker(okchanLeadRes,errchanLeadResErr,quitchanint,verbosebool,wg*sync.WaitGroup){varresultsProcessResultsdeferwg.Done()log.Info("Starting...")start:=time.Now()for{select{caselead:=

unit-testing - 在 go 中正确测试 http 路由

我有5个端点,它们具有GET、POST和DELETE等方法来测试。我使用go的内置测试包编写了测试用例。我担心我遗漏了一些我不感兴趣的案例。我已经在代码审查中发布了我的测试用例进行审查,但我没有得到任何回应。我也关注了这个帖子TestingHTTProutesingolang.所有这些测试用例都在检查响应代码。问题是,我的大部分测试用例都遵循类似的模式,我以不同的格式发布数据并检查响应代码。我强烈觉得我错过了一些东西,当我将它推向产品时会破坏我的API。我需要对测试这些路由有一些了解,这样我才能有信心将API推向产品。main_test.gofuncTestSigHandler(t*t