go测试问题记录

Running tool: /home/lexfan/goroot/bin/go test -timeout 30s -run ^TestMlegOrderCreate$ gitlab.futunn.com/institutional-trading-center/futc-oms/oms_write_service/stub_test/futc_oms_write_service

ok gitlab.futunn.com/institutional-trading-center/futc-oms/oms_write_service/stub_test/futc_oms_write_service (cached)

我在单测,突然就变成运行很快,但是不生效,直接ok了,不知道为什么

当 Go 测试输出显示 (cached) 时,这意味着 Go 测试框架没有实际运行测试,而是返回了之前测试运行的结果。Go 1.10 引入了测试结果缓存,目的是为了加快测试的速度。如果自上次成功测试以来源代码和测试代码都没有发生变化,并且测试所依赖的环境(如环境变量和文件)也没有变化,Go 测试框架就会使用缓存的结果。

如果您希望强制重新运行测试并忽略任何缓存的结果,可以使用 -count=1 参数,如下所示:

/home/lexfan/goroot/bin/go test -timeout 30s -run ^TestMlegOrderCreate$ gitlab.futunn.com/institutional-trading-center/futc-oms/oms_write_service/stub_test/futc_oms_write_service -count=1

这将告诉 Go 测试框架忽略缓存,并重新运行指定的测试。-count=1 指定测试至少运行一次,这也意味着不使用任何缓存的结果。

另外,请确保你的测试确实触发了一些代码的变动,因为如果测试无法检测到代码变动(包括测试中依赖的任何文件或环境变量的变动),它可能会直接使用缓存的结果。如果你在测试中有一些动态生成的数据或者外部依赖,你应该确保这些因素在测试运行时能够正确反映。

相关推荐
kishu_iOS&AI8 分钟前
Python - 链表浅析
开发语言·python·链表
m0_7336122117 分钟前
C++20概念(Concepts)入门指南
开发语言·c++·算法
我爱娃哈哈18 分钟前
SpringBoot + Redis Stream + 消费组:替代 Kafka 轻量级消息队列,低延迟高吞吐
后端
程序员大飞哥19 分钟前
MPTCP 协议全景:从 RFC 6824 到 RFC 8684 的演进
后端
程序员大飞哥20 分钟前
MPTCP 握手全解剖:一条连接是如何"长出"多条腿的
后端
凛訫訫22 分钟前
Java基础--面向对象高级(2)
后端
悟空码字25 分钟前
滑块拼图验证:SpringBoot完整实现+轨迹验证+Redis分布式方案
java·spring boot·后端
Nyarlathotep011326 分钟前
对象头、Monitor与synchronized
后端
luffy545940 分钟前
Rust语言入门-变量篇
开发语言·后端·rust
2301_807367191 小时前
C++中的模板方法模式
开发语言·c++·算法