草庐IT

with-config-file-scan-dir

全部标签

unit-testing - 如何使用 os.O_RDWR 和 os.O_CREATE 标志测试 file.Open?

我正在尝试为结构构造函数编写单元测试,如果在file.Open期间发生错误,它也可能返回nil。我不知道如何使用标志测试/模拟文件错误:os.O_RDWR|os.O_CREATE|os.O_APPEND我试图在测试中检查nil值,但失败了。构造函数:typeAppstruct{someFieldstringlog*log.Logger}funcNew()*App{app:=&App{}f,err:=os.OpenFile("info.log",os.O_RDWR|os.O_CREATE|os.O_APPEND,0666)iferr!=nil{fmt.Printf("erroropeni

go - x/手机 : Launch a android application with given package name [String] in go

下面是用go写的函数:funcLaunchApplication(packageNamestring){Query:howcanIexecuteapplicationwithgivenpackageName}使用gomobile生成java绑定(bind)[.aar]。我想包含在我的android应用程序中生成的.aar,并从java层调用LaunchApplication("com.package.name")到本地go层,go层应该运行该应用程序。在java应用中,使用包名运行apk的方法如下:Processprocess=Runtime.getRuntime().exec("am

gob 编码到/从 *os.File 解码不工作

当我使用文件指针时f*os.File我得到一个空映射funcdecode(f*os.File,bmap[string]interface{})error{err:=gob.NewDecoder(f).Decode(&b)fmt.Printf("%+v\n",b)returnerr}funcencode(f*os.File,bmap[string]interface{})error{bb:=map[string]interface{}{"X":1,"Greeting":"hello",}err:=gob.NewEncoder(f).Encode(bb)f.Sync()//fmt.Prin

postgresql - pq : invalid input syntax for type double precision: "$1" with Golang

我正在尝试在我的GO程序中将一个简单的INSERT插入到postgresql数据库中。我的数字0是一个float64,我的数据库中有一列需要doubleprecision。我不知道我需要将数字转换成什么才能让数据库接受该值。 最佳答案 PostgreSQL驱动程序可以很好地处理将float64插入到double列中:tmp=#\dtestTable"public.test"Column|Type|Modifiers--------+------------------+-----------v|doubleprecision|和代码

go - 尝试运行 go get -u 出现错误 : package XXX: unrecognized import path "_/XXX" (import path does not begin with hostname)

我在Windows中工作。完整错误:包/C/Go_Projects:无法识别的导入路径“/C/Go_Projects”(导入路径不以主机名开头)GOPATH=C:\Go_ProjectsGOROOT=C:\去path=path;C:\Go_Projects\binGo_Projects包含:bin、src、pkg和一些.bat文件,仅此而已。我尝试将GOROOT/GOPATH更改为:GOPATH=\\Go_ProjectsGOROOT=C:\Go\bin,\\Go\bin,\\Go我不确定如何解决这个问题,我不断收到错误消息,而且我的GOPATH从未正确设置。

file - os.File 是如何实现 io.Writer 的?

我能做到:f,err:=os.Create("file")iferr!=nil{....}by:=bufio.NewWriter(f)还有这个:var_io.Writer=&os.File{}os.File的包文档导致thissourcefile它确实包含一个未导出的写函数,但是当我尝试使用未导出的函数实现接口(interface)时出现错误。var_Disease=&Scratch{}//*Scratchdoesn'timplementDiseasehavespread()wantSpread()typeDiseaseinterface{Spread()}typeScratchstr

linux - 戈朗 : ssh running remote scripts: No such file or directory

我正在使用ssh模块在远程机器上运行shell脚本://ssh-run.gopackagemainimport("bytes""flag""fmt""log""time""golang.org/x/crypto/ssh")var(flagUser=flag.String("user","","")flagPwd=flag.String("pwd","","")flagHost=flag.String("host","","")flagCmd=flag.String("cmd","",""))funcmain(){flag.Parse()log.SetFlags(log.Lshortfi

file - Go connection.Writer 和 reader 行为不正常,在一次读取操作中读取 2 写入

我正在尝试从客户端读取文件,然后将其发送到服务器。它是这样的,你输入send在客户端程序中,然后是将被发送到服务器。服务器通过TCP连接从客户端读取2个东西,首先是命令send其次是文件的内容。但是,有时我的程序会随机包含中的文件内容。字符串。例如,假设我有一个名为xyz.txt的文本文件,其内容是“Hellowworld”。服务器有时会收到sendxyz.txtHellowworld.有时它不会,但它工作得很好。我认为这是同步或不刷新读写器缓冲区的问题。但我不太确定。提前致谢!客户端代码:funcsendFileToServer(fileNamestring,connectionne

file - 无法覆盖文件内容

我在用零覆盖文件内容时遇到了问题。问题是原始文件的最后一个字节仍然存在,即使我超过了它的大小100个字节。有人知道我错过了什么吗?func(hPostKey)ServeHTTP(whttp.ResponseWriter,r*http.Request){f,err:=os.Create("received.dat")iferr!=nil{w.WriteHeader(http.StatusInternalServerError)return}deferf.Close()_,err=io.Copy(f,r.Body)iferr!=nil{w.WriteHeader(http.StatusIn

go - SELECT WHERE with updated_at 是错误的

预期此代码结果为null但我得到的不是null。rDB.Where("user_id=?ANDupdated_at>?",userID,date).Find(&onedays)date:="2018-01-0423:18:00"Onedays表中有一些记录。+----+---------+------------+------------+---------------------+|id|user_id|save_state|date|updated_at|+----+---------+------------+------------+---------------------+