草庐IT

stdin_reader

全部标签

unit-testing - 为从中读取的函数填充 os.Stdin

如何在我的测试中填充os.Stdin以获取使用扫描仪从中读取的函数?我使用以下函数通过扫描器请求用户命令行输入:funcuserInput()error{scanner:=bufio.NewScanner(os.Stdin)println("Whatisyourname?")scanner.Scan()username=scanner.Text()/*...*/}现在如何测试这种情况并模拟用户输入?以下示例不起作用。标准输入仍然是空的。funcTestUserInput(t*testing.T){varfile*os.Filefile.Write([]byte("Tom"))os.St

http - 将 Reader 返回给 http.Response 的函数

这是我想用于特定页面网络爬虫的代码的精简版。这个想法是有一个获取URL的函数,处理HTTP并将Reader返回到响应主体http.Response:packagemainimport("io""log""net/http""os")funcmain(){consturl="https://xkcd.com/"r,err:=getPageContent(url)iferr!=nil{log.Fatal(err)}f,err:=os.Create("out.html")iferr!=nil{log.Fatal(err)}deferf.Close()io.Copy(f,r)}funcgetP

go - 从后台 go 进程读取 stdin 导致 EOF 错误

我正在为Micro写一个插件创建一个后台进程。当后台进程运行时,它反复从stdin读取字节-但它始终是EOF错误。在Micro中,我的后台进程是使用JobSpawn函数创建的,它返回一个*exec.cmd://JobSpawnstartsaprocesswithargsinthebackgroundwiththegivencallbacks//Itreturnsan*exec.CmdasthejobidfuncJobSpawn(cmdNamestring,cmdArgs[]string,onStdout,onStderr,onExitstring,userargs...string)*

docker - 当 PIPE docker 中的输出时从 os.Stdin 读取时被阻止

我正在尝试将程序的输出(日志)通过管道传输到Go程序,该程序聚合/压缩输出并上传到S3。运行该程序的命令是“/program1|/logShipper”。logShipper是用Go编写的,它只是从os.Stdin读取并写入本地文件。本地文件将由另一个goroutine处理并定期上传到S3。有一些现有的docker日志驱动程序,但我们在完全托管的提供程序上运行容器并且日志处理费用非常昂贵,因此我们想绕过现有解决方案并直接上传到S3。logShipper的主要逻辑只是从os.Stdin读取并写入某个文件。它在本地机器上运行时工作正常,但在docker中运行时,goroutine在read

unit-testing - 为从中读取的函数填充 os.Stdin

如何在我的测试中填充os.Stdin以获取使用扫描仪从中读取的函数?我使用以下函数通过扫描器请求用户命令行输入:funcuserInput()error{scanner:=bufio.NewScanner(os.Stdin)println("Whatisyourname?")scanner.Scan()username=scanner.Text()/*...*/}现在如何测试这种情况并模拟用户输入?以下示例不起作用。标准输入仍然是空的。funcTestUserInput(t*testing.T){varfile*os.Filefile.Write([]byte("Tom"))os.St

io - 使用 Scanf + input + enter 从 stdin 获得双重输入,如何刷新?

我正在使用Go的可移植解压缩版本!每当我尝试使用Scanf(以及相关函数)执行输入输出控制台实现时,插入运行时输入并使用enter验证程序中的结果(它是一个循环)就像我输入了两次或三次一样。显然(就像在C中一样)调用读取函数后需要清除stdin,但我不知道该怎么做。我似乎是唯一一个遇到这个愚蠢的基本问题的人(为什么?)在这个无休止的循环程序中,即使在我糟糕的同花顺尝试之后,问题也会被问和回答3次:packagemainimport"fmt"import"time"varglobalBad,globalGoodintfuncThread1(){variintvartstringfor{f

go - 使用 bufio.reader 从文本文件中读取行

for{v,err=nextNum(reader,'')iferr!=nil{break}w,err=nextNum(reader,'')iferr!=nil{break}cost,err=nextNum(reader,'\n')iferr!=nil{break}fmt.Println(v,w,cost)}我的文本文件由三列和n行组成。第一次调用nextNum时将返回第一行第一列的数字,下次调用第二列第一行的数字,依此类推。我的问题是当我走到最后并最后一次调用nextNum时,我将收到EOF错误并且最后一行永远不会打印出来,因为之前会调用break。关于如何解决问题有什么建议吗?干杯

json - 通过 STDIN/STDOUT 使用 json 的 websocketd

我们构建的软件由两部分组成,一个在浏览器中运行的GUI(前端)和一个将Go编译成exe的内核(后端)。为了将这两个部分粘合在一起,我们使用了在本地机器上运行的nodejs+expressjs+socket.io。Nodejs通过http/socket.io与浏览器对话,它还“生成”Goexe作为child_process。现在websocketd,我们可以跳过nodejs+expressjs+socket.io部分。太好了。难点在于:浏览器中的GUI,用于将JSON发送给nodejs,然后写入配置文件。我们的内核exe将读取该JSON配置文件以确定要做什么。我想不能通过STDIN/ST

go - bufio.Reader ReadRune - 大小为 0(返回值)可能吗?

当错误为nil时,ReadRune真的可以返回大小为0的值吗?我很好奇,因为我在网上看到一些例子,代码如下://assuminginput=*bufio.Readerr,size,err:=input.ReadRune()ifsize==0&&err==nil{return0,nil}elseiferr!=nil{return0,err}returnr,nil然而,根据go文档:Iftheencodedruneisinvalid,itconsumesonebyteandreturnsunicode.ReplacementChar(U+FFFD)withasizeof1.那么在什么情况下

python - 当 Reader 类型作为输入时,gzip.NewReader() 返回 nil

我在解压缩之前压缩的字节流时遇到了问题。基本上,我尝试使用函数bytes.NewReader()创建一个阅读器,然后使用gzip.NewReader()函数解压流。最后,我想以字符串或字节格式返回实际值。我知道gzip.NewReader需要io.Reader作为输入,但是,据我所知,类型Reader实现了接口(interface)io.Reader。我认为这不会导致任何错误,但我想知道在这种情况下可能是什么问题。如果你帮我解决这个问题,我将不胜感激!如果您想知道这段文字是什么,"amZzRUR2NHVtcVpiZHNROHJiTTNYeGdUSndGTlVDZC9jaElSK1lXc