使用 t.Skip 可在go测试中根据条件跳过测试函数,如平台限制或环境依赖未满足时,调用 t.Skip(“原因”) 会立即终止执行并标记为跳过;t.SkipNow() 等价于无消息跳过;通过 testing.Short() 可在 go test -short 模式下跳过耗时测试,提升测试稳定性和可读性。

在Go语言中,使用 t.Skip 可以在运行测试时有条件地跳过某个测试函数。这种方式常用于平台限制、环境依赖未满足或资源不可用等情况,避免测试因外部原因失败。
使用 t.Skip 跳过测试
在测试函数中调用 t.Skip 会立即停止当前测试的执行,并标记该测试为“已跳过”。
示例代码:
<pre class="brush:php;toolbar:false;">func TestSomething(t *testing.T) { if runtime.GOOS == "windows" { t.Skip("跳过 windows 平台上的此测试") } // 正常测试逻辑 if result := someFunction(); result != expected { t.Errorf("期望 %v,但得到 %v", expected, result) } }
当在windows系统上运行时,该测试会直接跳过并显示跳过状态。
t.SkipNow 和 t.Skip 的区别
t.SkipNow() 是立即跳过测试的常用方法,等价于调用 t.Skip() 后不输出额外信息。
立即学习“go语言免费学习笔记(深入)”;
t.Skip(…) 支持传入字符串参数,用于说明跳过原因,信息会输出到控制台。
例如:
<pre class="brush:php;toolbar:false;">func TestDatabase(t *testing.T) { if os.Getenv("DATABASE_URL") == "" { t.Skip("DATABASE_URL 未设置,跳过数据库测试") } // 连接数据库并执行测试 }
跳过整个测试包(使用 testing.Short)
除了直接跳过单个测试,还可以结合 -short 标志跳过耗时或依赖外部服务的测试。
<pre class="brush:php;toolbar:false;">func TestExternalAPI(t *testing.T) { if testing.Short() { t.Skip("短模式下跳过外部API测试") } // 发起真实网络请求 }
运行命令:go test -short 会跳过这些被标记的测试。
基本上就这些。根据运行环境或条件灵活使用 t.Skip,能让测试更稳定、更有可读性。


