【发布时间】:2016-03-24 14:42:53
【问题描述】:
我正在使用 Ginkgo(和 Gomega)包对 Go(lang) Rest API 进行单元测试。
我需要使用全局设置,这应该可以通过定义来实现
var _ = BeforeSuite(func() {...})
然后每个规范(具体的<file>_test.go)应该在这个全局设置之后运行。不幸的是,我无法做到这一点......
我的套件文件名是handlers_suite_test.go,我的第一个测试规范名称是cartContentsHandler_test.go。在我看来,Ginkgo 按字母顺序运行测试文件,使 cartContentsHandler_test.go 运行 before handlers_suite_test.go。我在两个文件中都放了一些log() 调用,不幸的是他们只是证实了我的发现......
这真是令人不快的情况,因为我根本无法让我的测试运行...我需要确保在所有规范之前设置并运行httptest.Server 和数据库池连接。
您知道如何使suite_test 作为测试规范之前的第一个文件运行吗?(我已经尝试将套件文件命名为_suite_test.go,但在这种情况下看起来套件根本没有执行)。
我的handlers_suite_test.go:
package handlers_test
import (
"<PROJ>/config"
"<PROJ>/lib"
"<PROJ>/router"
"github.com/gorilla/mux"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
"log"
"net/http/httptest"
"os"
"testing"
)
var r *mux.Router
var s *httptest.Server
var serverURL string
func TestHandlers(t *testing.T) {
RegisterFailHandler(Fail)
RunSpecs(t, "Caracal Handlers Suite")
}
var _ = BeforeSuite(func() {
r = router.NewRouter()
s = httptest.NewServer(r)
Expect(len(s.URL)).To(BeNumerically(">", 0))
serverURL = s.URL
log.Print("###" + serverURL + "###\n\n") // ==> THIS PRINTS MUCH LATER AFTER log.Print() in cartContentsHandler_test.go
cwd, _ := os.Getwd()
cfg := config.ReadCfg(cwd + "/../config/config.json").DB
lib.DB = lib.InitDB(cfg)
err := lib.DB.Ping()
Expect(err).NotTo(HaveOccurred())
})
var _ = AfterSuite(func() {
// lib.DB.Close() // ==> this was running into Panic...
s.Close()
})
我的cartContensHandler_test.go:
包 handlers_test
import (
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
"log"
"net/http"
"strings"
)
var _ = Describe("Handlers/CartContentsHandler", func() {
Describe("Retrieves all available cart content types", func() {
Context("No query string parameters", func() {
var rdr *strings.Reader
var req *http.Request
var res *http.Response
var err error
var url = serverURL + "/cart-contents"
log.Print(url)
It("Makes a GET request", func() {
rdr = strings.NewReader("")
req, err = http.NewRequest("GET", url, rdr)
Expect(err).NotTo(HaveOccurred())
})
It("retrieves a response", func() {
res, err = http.DefaultClient.Do(req)
Expect(err).NotTo(HaveOccurred())
})
It("Returns HTTP 200 OK", func() {
Expect(res.StatusCode).To(BeNumerically("==", http.StatusOK)) // ==> NOW THIS RETURNS 404 as request is to URL without server part
})
})
})
})
在
ginkgo handlers -cover --v
【问题讨论】:
-
如果你在 cartContensHandler_test.go 的
It函数中加入 log.Print 会发生什么? -
嗯,所以在
It中添加新的log.Print()输出真的是在BeforeSuite中的打印之后!我会将规范“设置”代码移动到It并尝试一下!
标签: unit-testing go ginkgo