Когда я запускаю одиночный тест с go test -run TestNewProbeServiceIsSingleton
, он проходит, как ожидалось.
Проблема возникает всякий раз, когда я пытаюсь протестировать весь пакет / приложение, используя go test ./...
из каталога root моего проекта:
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/mock@v1.4.3/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/mock@v1.4.3/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/mock@v1.4.3/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, но мне кажется, что я что-то упускаю по поводу того, как запускать тесты ...
Вы также можете запустить тесты самостоятельно, клонировав проект