草庐IT

gcloud-sql-test

全部标签

go - 由结构包装的 sql.DB 无法在实例中调用方法

我的目标是使用一个结构来包装sql.DB来做一些比sql.DB更重要的事情。我创建的实例无法运行,运行时出现此错误。DbConn.db.prepareundefined(cannotrefertounexportedfieldormethodsql.(*DB)."".prepare)我的代码是:typeDatabaseConnstruct{driverNamestringdatabaseNamestringuserNamestringpasswordstringdataSourceNamestringdb*sql.DB}func(dDatabaseConn)Open()error{d.

postgresql - Go database/sql 改变表名的大小写

我正在尝试使用database/sql和github.com/lib/pqPostgres驱动程序查询数据库。我遇到的错误是:pq:relation"itemprices_itemsale"doesnotexist但是看看我的查询:rows,err:=db.Query("SELECT*FROM\"itemPrices_itemsale\"LIMIT10")您会注意到表名中的大写“P”。我已经了解到,如果没有引用,Postgres会将名称折叠成小写字母。我引用了我的表名,所以我不太确定为什么会这样。我相当确定这就是问题所在,因为我能够使用类似Python程序中的表名查询表,并且一切都按预

testing - 针对 xml/字符串测试失败的自定义 testify 输出

我正在使用testify测试XML编码(marshal)处理,并使用strings.Contains检查我希望包含在XML中的行是否确实存在。但是,我想区分实际xml与所需xml。目前,我的代码看起来像这样:func(suite*BookSuite)TestXMLMarshal(){priceXML,priceErr:=xml.Marshal(PriceType{Price:10,Type:"IND"})suite.Nil(priceErr)linePresent:=strings.Contains(string(priceXML),``)iftrue!=linePresent{err

http - 去 Gin 框架 : Testing query and POST with cURL

我正在尝试theREADMEofginframework中的代码示例(“另一个例子:查询+发布表单”):packagemainimport("fmt""github.com/gin-gonic/gin")funcmain(){router:=gin.Default()router.POST("/post",func(c*gin.Context){id:=c.Query("id")page:=c.DefaultQuery("page","0")name:=c.PostForm("name")message:=c.PostForm("message")fmt.Printf("id:%s;p

unit-testing - 如何为测试目的重新定义/模拟 Go 中的方法?

我正在为Go库创建测试。我发现了一个错误:cannotassignto我有以下代码(https://play.golang.org/p/kf0gANb-p-):packagemainimport("bytes""fmt""os/exec""strconv""strings")const(CONSOLE="dialog"KDE="kdialog"GTK="gtkdialog"X="Xdialog"DIALOG_TEST_ENV="test_env"AUTO="auto")const(DIALOG_ERR_CANCEL="exitstatus1"DIALOG_ERR_HELP="exits

unit-testing - 如何用reflect测试方法?

我有一个Sync()方法可以覆盖在环境中设置的Config字段值。环境变量名称是通过下划线和大写名称从配置字段派生的。例如。AppName会有一个对应的环境变量APP_NAME请帮我测试以下情况。有复杂的东西,比如https://golang.org/pkg/reflect/#Value.Set:Setassignsxtothevaluev.ItpanicsifCanSetreturnsfalse.AsinGo,x'svaluemustbeassignabletov'stype.所以我不知道如何测试这个案例?import("encoding/json""errors""fmt""os"

unit-testing - go 模板的示例测试因导入和未使用 : "testing" 而失败

据我所知,我正在完美地遵循“进行测试”所需的结构。我没有发现与我可以在其他包中运行的测试有差异。“去build”工作正常。我得到了./HelloTemplate_test.go:3:importedandnotused:"testing"./HelloTemplate_test.go:5:undefined:TestinginTesting.T我错过了什么?HelloTemplate.gopackagetemplateprintimport"testing"funcTestRunTempl(t*Testing.T){sweaters:=Inventory{"wool",17}tmpl:

testing - Go-lang测试,Benchmark上Parallel Setting是什么意思?

在https://golang.org/pkg/testing/描述了我们可以使用testing.B.RunParallel()函数在并行设置中运行基准测试。我尝试编写简单的测试代码:funcBenchmarkFunctionSome(b*testing.B){fori:=0;i然后我将其更改为使用RunParallel()funcBenchmarkFunctionSome(b*testing.B){b.RunParallel(func(pb*testing.PB){forpb.Next(){SomeFunction()}})}并且使用RunParallel()的比第一个基准测试慢。其

go - 为什么 'Open connection failed:sql: unknown driver "mssql“(忘记导入?)”会在 go build 中第一次发生?

我第一次跑https://github.com/denisenkom/go-mssqldb/blob/master/examples/simple.go我收到错误“打开连接失败:sql:未知驱动程序“mssql”(忘记导入?)”我通过更改解决了这个问题导入_“github.com/denisenkom/go-mssqldb”到导入“github.com/denisenkom/go-mssqldb”这给出了一个不同的错误“导入但未使用:“github.com/denisenkom/go-mssqldb”作为mssql”。但是......在改回import_"github.com/deni

go - 我应该在 GO 中的数据库查询中使用 Sql.Stmt 还是字符串?

您好,在database/sql包中,我可以通过两种方式执行查询:第一种方式:使用Sql.StmtvarDeletePermissionStmt*sql.StmtDeletePermissionStmt,err=database.Prepare(`DELETEFROMpermissionWHEREpermission_id=$1`)iferr!=nil{log.Errorf("can'tpreparedeletepermissionstatement:%s",err.Error())}transaction,err:=database.Begin()//assumepostgresda