forked from quic-go/quic-go
introduce a logfile command line flag for the integrationtests
Use: ginkgo -failFast -- -logfile=log.txt Ginkgo will create log.txt and set the log level to LogLevelDebug. Use of -failFast is recommended to make sure that no other tests are run if one test fails (the log file would be overwritten otherwise).
This commit is contained in:
@@ -4,6 +4,7 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"crypto/md5"
|
"crypto/md5"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
@@ -22,6 +23,7 @@ import (
|
|||||||
"github.com/lucas-clemente/quic-go/h2quic"
|
"github.com/lucas-clemente/quic-go/h2quic"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/testdata"
|
"github.com/lucas-clemente/quic-go/testdata"
|
||||||
|
"github.com/lucas-clemente/quic-go/utils"
|
||||||
"github.com/tebeka/selenium"
|
"github.com/tebeka/selenium"
|
||||||
|
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
@@ -45,6 +47,9 @@ var (
|
|||||||
clientPath string // path of the quic_client
|
clientPath string // path of the quic_client
|
||||||
serverPath string // path of the quic_server
|
serverPath string // path of the quic_server
|
||||||
|
|
||||||
|
logFileName string // the log file set in the ginkgo flags
|
||||||
|
logFile *os.File
|
||||||
|
|
||||||
docker *gexec.Session
|
docker *gexec.Session
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -66,6 +71,12 @@ var _ = AfterSuite(func() {
|
|||||||
stopSelenium()
|
stopSelenium()
|
||||||
}, 10)
|
}, 10)
|
||||||
|
|
||||||
|
// read the logfile command line flag
|
||||||
|
// to set call ginkgo -- -logfile=log.txt
|
||||||
|
func init() {
|
||||||
|
flag.StringVar(&logFileName, "logfile", "", "log file")
|
||||||
|
}
|
||||||
|
|
||||||
var _ = BeforeEach(func() {
|
var _ = BeforeEach(func() {
|
||||||
// create a new uploadDir for every test
|
// create a new uploadDir for every test
|
||||||
var err error
|
var err error
|
||||||
@@ -80,6 +91,13 @@ var _ = BeforeEach(func() {
|
|||||||
}
|
}
|
||||||
clientPath = filepath.Join(thisfile, fmt.Sprintf("../../../quic-clients/client-%s-debug", runtime.GOOS))
|
clientPath = filepath.Join(thisfile, fmt.Sprintf("../../../quic-clients/client-%s-debug", runtime.GOOS))
|
||||||
serverPath = filepath.Join(thisfile, fmt.Sprintf("../../../quic-clients/server-%s-debug", runtime.GOOS))
|
serverPath = filepath.Join(thisfile, fmt.Sprintf("../../../quic-clients/server-%s-debug", runtime.GOOS))
|
||||||
|
|
||||||
|
if len(logFileName) > 0 {
|
||||||
|
logFile, err = os.Create("./log.txt")
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
utils.SetLogWriter(logFile)
|
||||||
|
utils.SetLogLevel(utils.LogLevelDebug)
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
var _ = AfterEach(func() {
|
var _ = AfterEach(func() {
|
||||||
@@ -91,6 +109,10 @@ var _ = AfterEach(func() {
|
|||||||
|
|
||||||
// remove downloaded file in docker container
|
// remove downloaded file in docker container
|
||||||
removeDownload("data")
|
removeDownload("data")
|
||||||
|
|
||||||
|
if len(logFileName) > 0 {
|
||||||
|
_ = logFile.Close()
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
func setupHTTPHandlers() {
|
func setupHTTPHandlers() {
|
||||||
|
|||||||
Reference in New Issue
Block a user