当前位置:首页 > 文章列表 > Golang > Go问答 > Go测试中发生的意外错误调试

Go测试中发生的意外错误调试

来源:stackoverflow 2024-03-13 18:30:28 0浏览 收藏

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,

hostport 都是 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学习网公众号了解相关技术文章。

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
mac虚拟机下载文件出错(mac系统使用虚拟机时下载文件的问题)mac虚拟机下载文件出错(mac系统使用虚拟机时下载文件的问题)
上一篇
mac虚拟机下载文件出错(mac系统使用虚拟机时下载文件的问题)
使用PHP计算数组中元素的总和
下一篇
使用PHP计算数组中元素的总和
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    30次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    45次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    40次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    53次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    43次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码