`go test` 单个测试成功,但测试包时失败

问题描述 投票:0回答:2

当我使用

go test -run TestNewProbeServiceIsSingleton
运行单个测试时,它按预期通过。

每当我尝试使用项目根目录中的

go test ./...
测试整个包/应用程序时,就会出现问题:

madjlzz@MadSfeirLab $ go test ./...              
?       github.com/madjlzz/madprobe     [no test files]
ok      github.com/madjlzz/madprobe/controller  (cached) [no tests to run]
?       github.com/madjlzz/madprobe/internal/alerter    [no test files]
?       github.com/madjlzz/madprobe/internal/mock       [no test files]
?       github.com/madjlzz/madprobe/internal/persistence        [no test files]
--- FAIL: TestInsertReturnErrorOnGetFailure (0.00s)
panic: Fail in goroutine after TestNewProbeServiceIsSingleton has completed [recovered]
        panic: Fail in goroutine after TestNewProbeServiceIsSingleton has completed [recovered]
        panic: Fail in goroutine after TestNewProbeServiceIsSingleton has completed

goroutine 23 [running]:
testing.tRunner.func1(0xc0000f6400)
        /usr/local/Cellar/go/1.13.6/libexec/src/testing/testing.go:874 +0x3a3
panic(0x12ccca0, 0xc000095190)
        /usr/local/Cellar/go/1.13.6/libexec/src/runtime/panic.go:679 +0x1b2
github.com/golang/mock/gomock.(*Controller).Finish(0xc000098ff0)
        /Users/madjlzz/Documents/Projects/Go/pkg/mod/github.com/golang/[email protected]/gomock/controller.go:246 +0x2b2
panic(0x12ccca0, 0xc000095190)
        /usr/local/Cellar/go/1.13.6/libexec/src/runtime/panic.go:679 +0x1b2
testing.(*common).Fail(0xc0000f6200)
        /usr/local/Cellar/go/1.13.6/libexec/src/testing/testing.go:609 +0x151
testing.(*common).FailNow(0xc0000f6200)
        /usr/local/Cellar/go/1.13.6/libexec/src/testing/testing.go:631 +0x2b
testing.(*common).Fatalf(0xc0000f6200, 0x1351581, 0x2e, 0xc0000c4140, 0x5, 0x5)
        /usr/local/Cellar/go/1.13.6/libexec/src/testing/testing.go:716 +0x90
github.com/golang/mock/gomock.(*Controller).Call.func1(0xc000098de0, 0x1301ca0, 0xc000094f90, 0x1343807, 0x3, 0xc000095110, 0x1, 0x1, 0x0, 0x0, ...)
        /Users/madjlzz/Documents/Projects/Go/pkg/mod/github.com/golang/[email protected]/gomock/controller.go:201 +0x486
github.com/golang/mock/gomock.(*Controller).Call(0xc000098de0, 0x1301ca0, 0xc000094f90, 0x1343807, 0x3, 0xc000095110, 0x1, 0x1, 0x5, 0xc00008a660, ...)
        /Users/madjlzz/Documents/Projects/Go/pkg/mod/github.com/golang/[email protected]/gomock/controller.go:217 +0xb4
github.com/madjlzz/madprobe/internal/mock.(*MockPersister).Get(0xc000094f90, 0x134426b, 0x7, 0x16, 0x0, 0x0)
        /Users/madjlzz/Documents/Projects/Go/src/github.com/madjlzz/madprobe/internal/mock/entity.go:53 +0xe5
github.com/madjlzz/madprobe/internal/prober.(*service).Insert(0xc000098e70, 0x134426b, 0x7, 0x1348f2d, 0x16, 0x0, 0x0, 0x5, 0xc00008a660, 0x156df40, ...)
        /Users/madjlzz/Documents/Projects/Go/src/github.com/madjlzz/madprobe/internal/prober/service.go:63 +0x19b
github.com/madjlzz/madprobe/internal/prober.TestInsertReturnErrorOnGetFailure(0xc0000f6400)
        /Users/madjlzz/Documents/Projects/Go/src/github.com/madjlzz/madprobe/internal/prober/service_test.go:59 +0x4fb
testing.tRunner(0xc0000f6400, 0x135be98)
        /usr/local/Cellar/go/1.13.6/libexec/src/testing/testing.go:909 +0xc9
created by testing.(*T).Run
        /usr/local/Cellar/go/1.13.6/libexec/src/testing/testing.go:960 +0x350
FAIL    github.com/madjlzz/madprobe/internal/prober     0.287s
?       github.com/madjlzz/madprobe/util        [no test files]
FAIL

应用程序构建没有任何错误:

madjlzz@MadSfeirLab $ go build .   
madjlzz@MadSfeirLab $ 

我的Golang版本是:

madjlzz@MadSfeirLab $ go version
go version go1.13.6 darwin/amd64

我还使用

mockgen
来模拟版本
1.4.3

中的界面

我是 Golang 新手,但感觉我有点想念一些关于如何运行测试的东西......

您还可以通过克隆 项目

自行运行测试
macos unit-testing go mocking
2个回答
0
投票

可能发生的事情(我没有可用于验证的源代码)是您的代码正在启动一个 goroutine,然后测试正在退出,但 goroutine 仍在运行并尝试执行操作。例如: package panicatthegocode import ( "testing" "time" ) func TestPanicMaybe(t *testing.T) { go func() { time.Sleep(1 * time.Millisecond) t.Skip("Skipping") }() }

产量

$ go test . -count=100 panic: Log in goroutine after TestPanicMaybe has completed: Skipping goroutine 32 [running]: testing.(*common).logDepth(0xc0000db860, {0xc000116020, 0x9}, 0x3) C:/Program Files/Go/src/testing/testing.go:1028 +0x4c5 testing.(*common).log(...) C:/Program Files/Go/src/testing/testing.go:1010 testing.(*common).Skip(0xc0000db860, {0xc0000fbfc0?, 0x0?, 0x0?}) C:/Program Files/Go/src/testing/testing.go:1095 +0x4a leetcode.TestPanicMaybe.func1() C:/Users/mparn/Desktop/panic_test.go:11 +0x5c created by leetcode.TestPanicMaybe in goroutine 31 C:/Users/mparn/Desktop/panic_test.go:9 +0x4f panic: Log in goroutine after TestPanicMaybe has completed: Skipping



-1
投票

for _, subtest := range subtests{ t.Run(subtest.name, func(t *testing.T) { do something with subtest... } }

但它必须看起来像:

for _, s := range subtests{ subtest:=s t.Run(subtest.name, func(t *testing.T) { do something with subtest... } }

注意
子测试:=s

这是这种情况下可能的解决方案之一。

© www.soinside.com 2019 - 2024. All rights reserved.