草庐IT

mysql-community-test

全部标签

unit-testing - 获取数据库连接的连接字符串

我正在尝试测试这个功能://OpenConnectionopensaconnectiontoaMySQLdatabaseby`connStr`//orreturnserror.If`connStr`isempty,errorisreturned.////Parameters://-`connStr`:theURLofthedatabasetoconnectto//-`interpolateParams`:shouldweinterpolateparameters?////Returns://-pointertothedatabaseconnection//-anyerrorsthath

mysql - 软删除级联不起作用

目标:如果用户在软删除中被标记为已删除,则他的日历也应被标记为已删除。结构:typeUserstruct{gorm.ModelUsernamestringFirstNamestringLastNamestringCalendarCalendar}typeCalendarstruct{gorm.ModelNamestringUserIDuint}约束:db.Model(&Calendar{}).AddForeignKey("user_id","users(id)","CASCADE","CASCADE")问题:硬删除有效:用户和他的日历都被删除(记录消失)db.Exec("Deletef

unit-testing - 在辅助函数中包装 httptest 方法

在我的处理程序测试中,我多次使用header中带有身份验证token的测试请求服务模式。为了对此进行抽象,并为自己节省大量行数,我编写了以下函数:funcserveTestReq(payloadstring,routestring,methodstring,handlerfuncfunc(whttp.ResponseWriter,r*http.Request),tokenstring){body:=strings.NewReader(payload)req,err:=http.NewRequest(method,route,body)Expect(err).NotTo(HaveOccu

unit-testing - 如何在 golang 中编写关于插入、获取、删除和更新数据的测试用例

我必须编写插入、获取、删除和更新数据的测试用例。在互联网上搜索时,我找到了一个代码并且它可以工作,但我不知道它是如何工作的。我的代码在下面给出,任何人都可以用简单的方式告诉我我将如何理解代码。packagemodelsimport("testing""gopkg.in/mgo.v2/bson""fmt")funcTestAddBlog(t*testing.T){typeargsstruct{queryinterface{}}tests:=[]struct{namestringargsargswantbool}{{"first",args{bson.M{"_id":4,"title":"

unit-testing - 在 Go-kit 中为 make 处理函数编写单元测试

我的问题特定于Go-kit以及如何在其中组织代码。我正在尝试为以下功能编写单元测试:funcMakeHandler(svcService,loggerkitlog.Logger)http.Handler{orderHandler:=kithttptransport.NewServer(makeOrderEndpoint(svc),decodeRequest,encodeResponse,)r:=mux.NewRouter()r.Handle("/api/v1/order/",orderHandler).Methods("GET")returnr编写适当的单元测试的正确方法是什么?我见过

unit-testing - 如何定义模拟方法被调用零次

我正在尝试测试以下方法://AuthenticationMiddlewareMiddlewarewhichhandlesalloftheauthentication.funcAuthenticationMiddleware(contextcontext.ContextIntf,wweb.ResponseWriter,r*web.Request,nextweb.NextMiddlewareFunc){//Checkifurlisonethatdoesn'tneedauthorization.Ifnotthansendthemtotheloginpage.for_,url:=rangeAu

mysql - Ubuntu升级后Golang MySQL连接超时

我在使用golang项目从MySQL数据库获取数据时遇到问题。在我从Ubuntu16.04升级到Ubuntu18.04.01之前,这个项目一直没有问题。应用程序现在在连接到数据库时超时。我的第一个想法是在16.04到18.04的升级过程中出现了问题。为了证明这一点,我启动了一个运行16.04的新虚拟机,执行了“do-release-upgrade”并将其升级到18.04。但是在这个VM上,我的应用程序运行良好,没有问题。我不知道从这里到哪里去解决正在发生的问题。下面是两种配置的总结。VM(工作)和服务器(不工作)如下;Ubuntu18.04.01LTSx86_64内核4.15.0-34

unit-testing - 如何重写gocov命令去工具覆盖?

我有以下命令:${GOPATH}/bin/gocovtest./...2>test|${GOPATH}/bin/gocovreport如果我使用gotoolcover,这个命令会是什么样子? 最佳答案 自go1.10gotoolcoverage支持递归包绕过gotest./...-coverprofile=coverage.out 关于unit-testing-如何重写gocov命令去工具覆盖?,我们在StackOverflow上找到一个类似的问题: http

mysql - 原子更新和备份 ON DUPLICATE KEY insert else - golang sql 语句

在golang中组合两个语句(INSERT或(BACKUP和UPDATE))并自动执行它们的最佳方式是什么?我发现了这个类似的问题:https://codereview.stackexchange.com/questions/186909/query-select-and-insert-if-not-exists?newreg=067063956a834327883542c3171a22d4但是解决方案没有满足以下要求中的2个:对DUPLICATEKEY的值进行备份,使用标准SQL不使用存储过程但是保持原子性。 最佳答案 这更像是一

mysql5.7与8.0区别、8.0新特性

1、索引隐藏索引:当一个索引隐藏时不被查询优化器所使用,用于判断索引的有效性SHOWINDEXFROMts_item_ratio_calculate_result;ALTERTABLEts_item_ratio_calculate_resultALTERINDEXidx_item_codeINVISIBLE;ALTERTABLEts_item_ratio_calculate_resultALTERINDEXidx_item_codeVISIBLE;降序索引:开始真正支持降序索引,以往的MySQL虽然支持降序索引,但是写盘的时候依然是升序保存。MySQL8.0中则是真正的按降序保存(分别在mys