草庐IT

TOOL_OS_SUFFIX

全部标签

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

logging - 在 log.SetOutput(ioutil.Discard) 之后延迟 log.SetOutput(os.Stdout)

在go-nsq库(https://github.com/bitly/go-nsq/blob/master/writer_test.go#L38)中,我找到了以下代码:log.SetOutput(ioutil.Discard)deferlog.SetOutput(os.Stdout)为什么作者在丢弃日志后将日志记录延迟到标准输出? 最佳答案 log.SetOutput(ioutil.Discard)语句更改标准记录器输出目的地。deferlog.SetOutput(os.Stdout)语句尝试在函数结束时将输出目标重置回其初始值。但是

go tool pprof 使用应用程序 PID 而不是 http 端点

现在,我像这样使用gotoolpprof分析Go应用程序:gotoolpprofhttp://localhost:8080/debug/pprof/profile我想在未知端口上运行http服务器的任意Go进程上使用pprof工具。我所掌握的关于该进程的唯一信息是它的PID。我需要做以下两件事之一:从其PID获取Go进程端口号。直接分析正在运行的进程。例如,类似于gotoolpprof10303,其中PID为10303。这些都行吗? 最佳答案 服务发现旨在解决此类问题。一个简单的解决方案是为每个PID创建一个tmp文件,将每个端口写

go - os.OpenFile 权限问题在测试中

我目前遇到了os.OpenFile的问题。当我运行我的go测试时,它只是给我“权限被拒绝”。typelogstruct{MessagestringSourcestringTimestamptime.TimeErrorCodeErrorCode}typeErrorCodeintconst(InfoErrorCode=1+iotaWarningError)func(errorCodeErrorCode)String()string{switcherrorCode{caseInfo:return"Info"caseWarning:return"Warning"caseError:return

go - 无法在 Golang os.Arg 变量中使用反斜杠 `\`

我在Golang中制作了一个程序,我试图在启动我的程序时使用一个文件作为第一个参数。例如:./goprogram.exeC:\Acidic\image.png当我的程序尝试使用应该链接到image.png文件的os.Arg[1]变量时,它返回没有任何反斜杠的字符串(C:Acidicimage.png)。如何在不转义字符的情况下使用参数的整个字符串?我举了一个小例子:packagemainimport("fmt""os")funcmain(){iflen(os.Args)>=2{fmt.Println(os.Args[1])}}我运行gorunargs.goC:\Users\image.

file - 如何在 golang 的 os.FileMode 中设置 gid 和 uid?

我想为我们的golang应用程序创建的文件设置uid和gid。看起来正确的地方是使用os.FileMode.我正在寻找一步设置权限以及uid和gid的示例。设置权限看起来非常简单:os.FileMode(hdr.Mode&0777)但我不确定如何在FileMode上也设置uid/gid。 最佳答案 不知道一步是什么意思,我用下面的方法设置uid和gidfuncChown(路径字符串,uidint,gidint)https://golang.org/pkg/syscall/#Chown 关

go - 通过 golang os/exec 使用 sftp << INPUT

我想做的是在golang中通过SFTP从我的服务器导出文件。这是麻烦的代码cmd=exec.Command("sftp","login@sftp.com",`INPUTcd/some/pathputfile.gzquitINPUT`)cmd.Stderr=&stderrerr=cmd.Run()iferr!=nil{fmt.Println(stderr.String())os.Exit(1)}fmt.Println("done")它会完成但不会导入file.gz。 最佳答案 我终于找到了解决方案。cmd=exec.Command("

go - os : process already finished when sending syscall. SIGCONT(可能是错误?)

当执行进程并使用以下方式向其发送信号时:Process.Signal我注意到在发送第二个信号syscall.SIGCONT之后我得到了一个:os:processalreadyfinished但如果使用syscall.Kill一切都按预期工作。为了演示目的,我创建了这个简单的示例:packagemainimport("fmt""os""os/exec""syscall""time")funcmain(){exit:=make(chanerror,1)gorun(exit)for{select{case所以基本上如果使用:cmd.Process.Signal(syscall.SIGCONT

go - 带有 gRPC 的 golang protocol buffers 可以在不同的 OS 平台上交叉编译和使用吗?

这个问题专门关于在不同的操作系统平台上编译和使用golangProtocolBuffer(使用gRPC),我还没有看到类似的问题。是否可以在Windows上编译一个.proto文件,然后在Linux上使用生成的文件?还是相反?我在Windows和Linux上编译了相同的.proto文件,diff显示了不同的结果。一个区别是Windows编译版本有时会在请求结构的字段中重复json,如下所示:Field1Name*type`protobuf,bytes,1,opt,name=my_name,json=myName"json:"my_name,omitempty"`而Linux版本是:Fi

os.stdin 上的 golang io.TeeReader 中断 tty

我正在尝试创建一个程序,它通过ssh连接到远程服务器并执行用户给出的命令。我在os.stdin上使用os.TeeReader来记录所有用户输入,但这会破坏tty。varbufferReadbytes.Buffersshstring:=user+"@"+hostcmd:=exec.Command("ssh",sshstring,"-oStrictHostKeyChecking=no")cmd.Stdout=os.Stdoutcmd.Stdin=io.TeeReader(os.Stdin,&bufferRead)cmd.Stderr=os.Stderrcmd.Run()fmt.Printf