Go测试中发生的意外错误调试
Golang不知道大家是否熟悉?今天我将给大家介绍《Go测试中发生的意外错误调试》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!
我有一个 go 二进制文件,现在我对其进行了一些测试,这些测试都应该并行运行。
因此,我有很多 _test 包,并且所有 test* 都包含对 t.parallel() 的调用。
go 二进制文件使用 2 个第三方模块,我已经在其中发现(并修复了)并发问题。对我来说不存在明显的并发问题。使用 -race 运行也不会产生任何投诉。
现在使用 go clean -testcache && go test 执行所有测试 ./... 每 4 次运行一次左右:
unexpected fault address 0x2d84420
fatal error: fault
[signal sigsegv: segmentation violation code=0x1 addr=0x2d84420 pc=0x4730e5]
goroutine 15 [running]:
runtime.throw(0x129fe7b, 0x5)
/usr/lib/go-1.15/src/runtime/panic.go:1116 +0x72 fp=0xc000074810 sp=0xc0000747e0 pc=0x439612
runtime.sigpanic()
/usr/lib/go-1.15/src/runtime/signal_unix.go:727 +0x405 fp=0xc000074840 sp=0xc000074810 pc=0x44fda5
runtime.memmove(0xc000680000, 0x1236820, 0x1b4dc80)
/usr/lib/go-1.15/src/runtime/memmove_amd64.s:392 +0x485 fp=0xc000074848 sp=0xc000074840 pc=0x4730e5
fmt.(*buffer).writestring(...)
/usr/lib/go-1.15/src/fmt/print.go:82
fmt.(*fmt).padstring(0xc00009f2f0, 0x1236820, 0x1b4dc80)
/usr/lib/go-1.15/src/fmt/format.go:110 +0x8e fp=0xc0000748d0 sp=0xc000074848 pc=0x4f288e
fmt.(*fmt).fmts(0xc00009f2f0, 0x1236820, 0x1b4dc80)
/usr/lib/go-1.15/src/fmt/format.go:359 +0x65 fp=0xc000074908 sp=0xc0000748d0 pc=0x4f37c5
fmt.(*pp).fmtstring(0xc00009f2b0, 0x1236820, 0x1b4dc80, 0x73)
/usr/lib/go-1.15/src/fmt/print.go:450 +0x1ba fp=0xc000074958 sp=0xc000074908 pc=0x4f6dfa
fmt.(*pp).printarg(0xc00009f2b0, 0x10a2320, 0xc0004c8cf0, 0x73)
/usr/lib/go-1.15/src/fmt/print.go:698 +0x7e7 fp=0xc0000749f0 sp=0xc000074958 pc=0x4f9147
fmt.(*pp).doprintf(0xc00009f2b0, 0x129f741, 0x5, 0xc000074bb8, 0x2, 0x2)
/usr/lib/go-1.15/src/fmt/print.go:1030 +0x168 fp=0xc000074ad8 sp=0xc0000749f0 pc=0x4fc208
fmt.sprintf(0x129f741, 0x5, 0xc000074bb8, 0x2, 0x2, 0xe300000001b7f5f0, 0x1b4f180)
/usr/lib/go-1.15/src/fmt/print.go:219 +0x66 fp=0xc000074b30 sp=0xc000074ad8 pc=0x4f54a6
github.com/grantstreetgroup/go-exasol-client.(*conn).wsconnect(0xc0004a1680)
/user/go/pkg/mod/github.com/grantstreetgroup/[email protected]/websocket.go:33 +0xea fp=0xc000074c78 sp=0xc000074b30 pc=0x7a7daa
github.com/grantstreetgroup/go-exasol-client.connect(0x1236820, 0x1b4dc80, 0xc00063fe10, 0x129ebb5, 0x3, 0x12a1065, 0x6, 0x0, 0x0, 0x0, ...)
/user/go/pkg/mod/github.com/grantstreetgroup/[email protected]/client.go:84 +0x113 fp=0xc000074cb0 sp=0xc000074c78 pc=0x7a2253
github.com/abergmeier/terraform-provider-exasol/internal/exaprovider.newconnect(0x1236820, 0x1b4dc80, 0xc00063fe10, 0x129ebb5, 0x3, 0x12a1065, 0x6, 0x0, 0x0, 0x0, ...)
/user/projects/terraform-provider-exasol/internal/exaprovider/client.go:28 +0x45 fp=0xc000074d30 sp=0xc000074cb0 pc=0x7aa005
github.com/abergmeier/terraform-provider-exasol/internal/exaprovider.(*client).lock(...)
/user/projects/terraform-provider-exasol/internal/exaprovider/client.go:35
github.com/abergmeier/terraform-provider-exasol/internal/resources/role_test_test.testaccexasolrole_import(0xc0003f9800)
/user/projects/terraform-provider-exasol/internal/resources/role_test/role_acc_test.go:61 +0x178 fp=0xc000074f80 sp=0xc000074d30 pc=0xfeb0f8
testing.trunner(0xc0003f9800, 0x12ee108)
/usr/lib/go-1.15/src/testing/testing.go:1127 +0xef fp=0xc000074fd0 sp=0xc000074f80 pc=0x529f8f
runtime.goexit()
/usr/lib/go-1.15/src/runtime/asm_amd64.s:1374 +0x1 fp=0xc000074fd8 sp=0xc000074fd0 pc=0x471e61
created by testing.(*t).run
/usr/lib/go-1.15/src/testing/testing.go:1178 +0x386
goroutine 1 [chan receive]:
testing.(*t).run(0xc0003f9800, 0x12b54a8, 0x18, 0x12ee108, 0x49b701)
/usr/lib/go-1.15/src/testing/testing.go:1179 +0x3ad
testing.runtests.func1(0xc0003f9380)
/usr/lib/go-1.15/src/testing/testing.go:1449 +0x78
testing.trunner(0xc0003f9380, 0xc00063fc00)
/usr/lib/go-1.15/src/testing/testing.go:1127 +0xef
testing.runtests(0xc0004c4940, 0x1b37060, 0x2, 0x2, 0xbfdb48dc53e2df3f, 0x8bb3466227, 0x1b4df40, 0x40f948)
/usr/lib/go-1.15/src/testing/testing.go:1447 +0x2e8
testing.(*m).run(0xc00019ad00, 0x0)
/usr/lib/go-1.15/src/testing/testing.go:1357 +0x245
github.com/abergmeier/terraform-provider-exasol/internal/resources/role_test_test.testrun(0xc00019ad00, 0x0)
/user/projects/terraform-provider-exasol/internal/resources/role_test/main_test.go:28 +0x136
github.com/abergmeier/terraform-provider-exasol/internal/resources/role_test_test.testmain(0xc00019ad00)
/user/projects/terraform-provider-exasol/internal/resources/role_test/main_test.go:20 +0x85
main.main()
_testmain.go:47 +0x165
goroutine 6 [select]:
go.opencensus.io/stats/view.(*worker).start(0xc00019a700)
/user/go/pkg/mod/[email protected]/stats/view/worker.go:276 +0x105
created by go.opencensus.io/stats/view.init.0
/user/go/pkg/mod/[email protected]/stats/view/worker.go:34 +0x68
goroutine 14 [chan receive]:
testing.(*t).parallel(0xc0003f9500)
/usr/lib/go-1.15/src/testing/testing.go:1003 +0x20b
github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource.paralleltest(0x147e120, 0xc0003f9500, 0x0, 0x0, 0x0, 0xc0004d4f30, 0x0, 0x0, 0x0, 0xc0003f9680, ...)
/user/go/pkg/mod/github.com/hashicorp/terraform-plugin-sdk/[email protected]/helper/resource/testing.go:482 +0x63
github.com/abergmeier/terraform-provider-exasol/internal/resources/role_test_test.testaccexasolrole_rename(0xc0003f9500)
/user/projects/terraform-provider-exasol/internal/resources/role_test/role_acc_test.go:26 +0x878
testing.trunner(0xc0003f9500, 0x12ee110)
/usr/lib/go-1.15/src/testing/testing.go:1127 +0xef
created by testing.(*t).run
/usr/lib/go-1.15/src/testing/testing.go:1178 +0x386
堆栈跟踪总是相似的。
我调查了 /user/go/pkg/mod/github.com/grantstreetgroup/[email protected]/websocket.go:33,我非常怀疑它实际上是罪魁祸首(sprintf 和活动对象似乎是无辜的够了)。
我尝试使用 valgrind --error-limit=no --track-origins=yes 运行,但似乎没有确凿证据。特别是因为输出中没有任何地方提到 0x2d84420。
我尝试通过 dlv 运行,但现在似乎有附加到递归启动测试的方法。
到目前为止,我有点不知所措,希望能够采取任何具体步骤来确定错误地址的来源。
如果有人能够弄清楚 0x2d84420 应该是逻辑 (go) 地址还是物理 (linux) 地址,那就加分了。
go版本的输出是:
go version go1.15.2 linux/amd64
编辑1:
因此我重写了第三方模块的函数以不使用 sprintf,现在它声称失败:
Host: host + ":" + port,
host 和 port 都是 string 类型。
所以目前我认为 stacktrace 是假的。也许是由于缺少调试符号?
编辑2:
现在我不知何故认为我可能会触发某种未定义的行为。似乎 port 以前有时会损坏。我尝试测试 port 的(损坏的)值 65040 ,它似乎在 testmain 之后很快就损坏了。我删除了一些非必要的代码,现在损坏的值为 65056。
解决方案
所以我改变了 testmain
var (
exaclient *exaprovider.client
exaconf exasol.connconf
)
func testmain(m *testing.m) {
flag.parse()
os.exit(testrun(m))
}
func testrun(m *testing.m) int {
exaconf = internal.mustcreatetestconf()
exaclient = exaprovider.newclient(exaconf)
return m.run()
}
至
var (
exaClient *exaprovider.Client
exaConf exasol.ConnConf
)
func init() {
exaConf = internal.MustCreateTestConf()
}
func TestMain(m *testing.M) {
flag.Parse()
os.Exit(testRun(m))
}
func testRun(m *testing.M) int {
exaClient = exaprovider.NewClient(exaConf)
return m.Run()
}
所有的腐败似乎都消失了。这是官方的 - 我不再理解 golang 了。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Go测试中发生的意外错误调试》文章吧,也可关注golang学习网公众号了解相关技术文章。
mac虚拟机下载文件出错(mac系统使用虚拟机时下载文件的问题)
- 上一篇
- mac虚拟机下载文件出错(mac系统使用虚拟机时下载文件的问题)
- 下一篇
- 使用PHP计算数组中元素的总和
-
- Golang · Go问答 | 1年前 |
- 在读取缓冲通道中的内容之前退出
- 139浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 戈兰岛的全球 GOPRIVATE 设置
- 204浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何将结构作为参数传递给 xml-rpc
- 325浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何用golang获得小数点以下两位长度?
- 478浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何通过 client-go 和 golang 检索 Kubernetes 指标
- 486浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 将多个“参数”映射到单个可变参数的习惯用法
- 439浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 将 HTTP 响应正文写入文件后出现 EOF 错误
- 357浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 结构中映射的匿名列表的“复合文字中缺少类型”
- 352浏览 收藏
-
- Golang · Go问答 | 1年前 |
- NATS Jetstream 的性能
- 101浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何将复杂的字符串输入转换为mapstring?
- 440浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 相当于GoLang中Java将Object作为方法参数传递
- 212浏览 收藏
-
- Golang · Go问答 | 1年前 |
- 如何确保所有 goroutine 在没有 time.Sleep 的情况下终止?
- 143浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3205次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3417次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3447次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4556次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3825次使用
-
- GoLand调式动态执行代码
- 2023-01-13 502浏览
-
- 用Nginx反向代理部署go写的网站。
- 2023-01-17 502浏览
-
- Golang取得代码运行时间的问题
- 2023-02-24 501浏览
-
- 请问 go 代码如何实现在代码改动后不需要Ctrl+c,然后重新 go run *.go 文件?
- 2023-01-08 501浏览
-
- 如何从同一个 io.Reader 读取多次
- 2023-04-11 501浏览

