草庐IT

TRAVIS_OS_NAME

全部标签

go - 如何通过struct field Name取值

typemcatstruct{IDint}typecatstruct{NamestringMmcat}funcgetValue(pathstring,mcatcat){//throuthstructpathgetthevalue}funcmain(){mycat:=cat{"cat",mcat{1}}id:=getvalue("/M/ID",mycat)}我可以通过反射获取基于字段名称的值来做到这一点吗? 最佳答案 你可以用Value.FieldByName()做你想做的事功能。只需覆盖可能使用strings.Split()分割的路

go - 如何在 Travis-CI 上将 Go 项目从 Linux 交叉编译到 Windows

因为Travis-CI对Go的原生Windows支持似乎很缺乏,我想走这条路。我最好怎么做? 最佳答案 这为Linux本地构建,为OSX本地构建,并为windows交叉编译,作为linux构建的一部分:.travis.yml:language:gosudo:falsematrix:include:-go:tipos:linuxenv:CROSS_COMPILE=true-go:tipos:osxbefore_install:-if["$CROSS_COMPILE"="true"];thensudoaptupdate;fiinstal

go - 如何修复在 Windows 上压缩的 os.PathSeparator 解压缩文件?

我在Windows上压缩文件,在Linux上解压缩时,使用操作系统默认应用程序,它不会沿路径创建文件夹,而是创建一个名为“indexes\search.invcus\index_meta.json”的文件,例如:unzip2019-05-23_113735_data.zip-dxfolderArchive:2019-05-23_113735_data.zipinflating:xfolder/indexes\search.invcus\index_meta.jsoninflating:xfolder/indexes\search.invcus\storeinflating:xfolde

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

go - Travis CI 找不到 GitHub 部署的发布文件

尽管在SO上尝试了其他答案,但我无法让TravisCI找到我的发布文件夹进行部署。我有一个像这样运行发布的Makefile:release:mkdir-preleaseenvGOOS=linuxGOARCH=amd64$(GOBUILD)-orelease/$(CLI)-$(VERSION)-linux-amd64$(BINARY_NAME_CLI)envGOOS=darwinGOARCH=amd64$(GOBUILD)-orelease/$(CLI)-$(VERSION)-darwin-amd64$(BINARY_NAME_CLI)envGOOS=windowsGOARCH=amd6

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 - 如何在 travis-ci 上使用远程包 |走

当我运行go脚本(gorunexample.go)时出现此错误/home/travis/.gvm/gos/go1.1.2/src/pkg/github.com/user/examplepackage(from$GOROOT)/home/travis/.gvm/pkgsets/go1.1.2/global/src/github.com/user/examplepackage(from$GOPATH)example.go导入包使用import"github.com/user/examplepackage"travis.yml文件如下所示:install:-goget...before_sc

go - 无法在travis中构建go项目

我开始创建一个非常轻量级的消息代理来在一个项目中练习go、travis和一些aws服务。我当前的问题是我可以在我的本地机器上构建、运行和测试我的开发分支,但是当travis尝试构建它时我得到一个编译错误。它不喜欢的代码直接来自AWS示例,进一步加深了我的神秘感。Travis构建失败https://travis-ci.org/hevnly/eevy/builds/65687886Githubrepohttps://github.com/hevnly/eevy/tree/92412cf729ed546d698ded1e514d2d54c340ff81错误handler/lambda.go:

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