hs-test: proxy testing improvements
- nginx and curl timeouts are extended if debug flag is set - added write-out for curl (outputs extra info after transfer is done) Type: test Change-Id: I3f6c336a14cd00b9ae8669d2fa26e00709162100 Signed-off-by: Matus Fabian <matfabia@cisco.com>
This commit is contained in:

committed by
Florin Coras

parent
147585e7f6
commit
05f7137389
@ -7,6 +7,7 @@ RUN apt-get update \
|
|||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
COPY script/build_curl.sh /build_curl.sh
|
COPY script/build_curl.sh /build_curl.sh
|
||||||
|
COPY resources/curl/* /tmp/
|
||||||
RUN fallocate -l 10MB /tmp/testFile
|
RUN fallocate -l 10MB /tmp/testFile
|
||||||
RUN apt-get update && apt-get install wget
|
RUN apt-get update && apt-get install wget
|
||||||
RUN /build_curl.sh
|
RUN /build_curl.sh
|
||||||
|
@ -22,6 +22,7 @@ type EnvoyProxySuite struct {
|
|||||||
HstSuite
|
HstSuite
|
||||||
nginxPort uint16
|
nginxPort uint16
|
||||||
proxyPort uint16
|
proxyPort uint16
|
||||||
|
maxTimeout int
|
||||||
}
|
}
|
||||||
|
|
||||||
var envoyProxyTests = map[string][]func(s *EnvoyProxySuite){}
|
var envoyProxyTests = map[string][]func(s *EnvoyProxySuite){}
|
||||||
@ -39,6 +40,12 @@ func (s *EnvoyProxySuite) SetupSuite() {
|
|||||||
s.HstSuite.SetupSuite()
|
s.HstSuite.SetupSuite()
|
||||||
s.LoadNetworkTopology("2taps")
|
s.LoadNetworkTopology("2taps")
|
||||||
s.LoadContainerTopology("envoyProxy")
|
s.LoadContainerTopology("envoyProxy")
|
||||||
|
|
||||||
|
if *IsVppDebug {
|
||||||
|
s.maxTimeout = 600
|
||||||
|
} else {
|
||||||
|
s.maxTimeout = 60
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *EnvoyProxySuite) SetupTest() {
|
func (s *EnvoyProxySuite) SetupTest() {
|
||||||
@ -71,10 +78,12 @@ func (s *EnvoyProxySuite) SetupTest() {
|
|||||||
LogPrefix string
|
LogPrefix string
|
||||||
Address string
|
Address string
|
||||||
Port uint16
|
Port uint16
|
||||||
|
Timeout int
|
||||||
}{
|
}{
|
||||||
LogPrefix: nginxContainer.Name,
|
LogPrefix: nginxContainer.Name,
|
||||||
Address: serverInterface.Ip4AddressString(),
|
Address: serverInterface.Ip4AddressString(),
|
||||||
Port: s.nginxPort,
|
Port: s.nginxPort,
|
||||||
|
Timeout: s.maxTimeout,
|
||||||
}
|
}
|
||||||
nginxContainer.CreateConfig(
|
nginxContainer.CreateConfig(
|
||||||
"/nginx.conf",
|
"/nginx.conf",
|
||||||
@ -130,16 +139,18 @@ func (s *EnvoyProxySuite) ProxyAddr() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s *EnvoyProxySuite) CurlDownloadResource(uri string) {
|
func (s *EnvoyProxySuite) CurlDownloadResource(uri string) {
|
||||||
args := fmt.Sprintf("--insecure --noproxy '*' --remote-name --output-dir /tmp %s", uri)
|
args := fmt.Sprintf("-w @/tmp/write_out_download --max-time %d --insecure --noproxy '*' --remote-name --output-dir /tmp %s", s.maxTimeout, uri)
|
||||||
_, log := s.RunCurlContainer(args)
|
writeOut, log := s.RunCurlContainer(args)
|
||||||
s.AssertNotContains(log, "Recv failure")
|
s.AssertContains(writeOut, "GET response code: 200")
|
||||||
s.AssertContains(log, "HTTP/1.1 200")
|
s.AssertNotContains(log, "bytes remaining to read")
|
||||||
|
s.AssertNotContains(log, "Operation timed out")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *EnvoyProxySuite) CurlUploadResource(uri, file string) {
|
func (s *EnvoyProxySuite) CurlUploadResource(uri, file string) {
|
||||||
args := fmt.Sprintf("--insecure --noproxy '*' -T %s %s", file, uri)
|
args := fmt.Sprintf("-w @/tmp/write_out_upload --max-time %d --insecure --noproxy '*' -T %s %s", s.maxTimeout, file, uri)
|
||||||
_, log := s.RunCurlContainer(args)
|
writeOut, log := s.RunCurlContainer(args)
|
||||||
s.AssertContains(log, "HTTP/1.1 201")
|
s.AssertContains(writeOut, "PUT response code: 201")
|
||||||
|
s.AssertNotContains(log, "Operation timed out")
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ = Describe("EnvoyProxySuite", Ordered, ContinueOnFailure, func() {
|
var _ = Describe("EnvoyProxySuite", Ordered, ContinueOnFailure, func() {
|
||||||
|
@ -23,6 +23,7 @@ var nginxProxySoloTests = map[string][]func(s *NginxProxySuite){}
|
|||||||
type NginxProxySuite struct {
|
type NginxProxySuite struct {
|
||||||
HstSuite
|
HstSuite
|
||||||
proxyPort uint16
|
proxyPort uint16
|
||||||
|
maxTimeout int
|
||||||
}
|
}
|
||||||
|
|
||||||
func RegisterNginxProxyTests(tests ...func(s *NginxProxySuite)) {
|
func RegisterNginxProxyTests(tests ...func(s *NginxProxySuite)) {
|
||||||
@ -36,6 +37,12 @@ func (s *NginxProxySuite) SetupSuite() {
|
|||||||
s.HstSuite.SetupSuite()
|
s.HstSuite.SetupSuite()
|
||||||
s.LoadNetworkTopology("2taps")
|
s.LoadNetworkTopology("2taps")
|
||||||
s.LoadContainerTopology("nginxProxy")
|
s.LoadContainerTopology("nginxProxy")
|
||||||
|
|
||||||
|
if *IsVppDebug {
|
||||||
|
s.maxTimeout = 600
|
||||||
|
} else {
|
||||||
|
s.maxTimeout = 60
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *NginxProxySuite) SetupTest() {
|
func (s *NginxProxySuite) SetupTest() {
|
||||||
@ -85,9 +92,11 @@ func (s *NginxProxySuite) SetupTest() {
|
|||||||
nginxSettings := struct {
|
nginxSettings := struct {
|
||||||
LogPrefix string
|
LogPrefix string
|
||||||
Address string
|
Address string
|
||||||
|
Timeout int
|
||||||
}{
|
}{
|
||||||
LogPrefix: nginxServerContainer.Name,
|
LogPrefix: nginxServerContainer.Name,
|
||||||
Address: serverInterface.Ip4AddressString(),
|
Address: serverInterface.Ip4AddressString(),
|
||||||
|
Timeout: s.maxTimeout,
|
||||||
}
|
}
|
||||||
nginxServerContainer.CreateConfig(
|
nginxServerContainer.CreateConfig(
|
||||||
"/nginx.conf",
|
"/nginx.conf",
|
||||||
@ -116,10 +125,11 @@ func (s *NginxProxySuite) ProxyAddr() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s *NginxProxySuite) CurlDownloadResource(uri string) {
|
func (s *NginxProxySuite) CurlDownloadResource(uri string) {
|
||||||
args := fmt.Sprintf("--insecure --noproxy '*' --remote-name --output-dir /tmp %s", uri)
|
args := fmt.Sprintf("-w @/tmp/write_out_download --max-time %d --insecure --noproxy '*' --remote-name --output-dir /tmp %s", s.maxTimeout, uri)
|
||||||
_, log := s.RunCurlContainer(args)
|
writeOut, log := s.RunCurlContainer(args)
|
||||||
s.AssertNotContains(log, "Recv failure")
|
s.AssertContains(writeOut, "GET response code: 200")
|
||||||
s.AssertContains(log, "HTTP/1.1 200")
|
s.AssertNotContains(log, "bytes remaining to read")
|
||||||
|
s.AssertNotContains(log, "Operation timed out")
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ = Describe("NginxProxySuite", Ordered, ContinueOnFailure, func() {
|
var _ = Describe("NginxProxySuite", Ordered, ContinueOnFailure, func() {
|
||||||
|
@ -24,6 +24,7 @@ const (
|
|||||||
type VppProxySuite struct {
|
type VppProxySuite struct {
|
||||||
HstSuite
|
HstSuite
|
||||||
nginxPort uint16
|
nginxPort uint16
|
||||||
|
maxTimeout int
|
||||||
}
|
}
|
||||||
|
|
||||||
var vppProxyTests = map[string][]func(s *VppProxySuite){}
|
var vppProxyTests = map[string][]func(s *VppProxySuite){}
|
||||||
@ -41,6 +42,12 @@ func (s *VppProxySuite) SetupSuite() {
|
|||||||
s.HstSuite.SetupSuite()
|
s.HstSuite.SetupSuite()
|
||||||
s.LoadNetworkTopology("2taps")
|
s.LoadNetworkTopology("2taps")
|
||||||
s.LoadContainerTopology("vppProxy")
|
s.LoadContainerTopology("vppProxy")
|
||||||
|
|
||||||
|
if *IsVppDebug {
|
||||||
|
s.maxTimeout = 600
|
||||||
|
} else {
|
||||||
|
s.maxTimeout = 60
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *VppProxySuite) SetupTest() {
|
func (s *VppProxySuite) SetupTest() {
|
||||||
@ -64,10 +71,12 @@ func (s *VppProxySuite) SetupTest() {
|
|||||||
LogPrefix string
|
LogPrefix string
|
||||||
Address string
|
Address string
|
||||||
Port uint16
|
Port uint16
|
||||||
|
Timeout int
|
||||||
}{
|
}{
|
||||||
LogPrefix: nginxContainer.Name,
|
LogPrefix: nginxContainer.Name,
|
||||||
Address: serverInterface.Ip4AddressString(),
|
Address: serverInterface.Ip4AddressString(),
|
||||||
Port: s.nginxPort,
|
Port: s.nginxPort,
|
||||||
|
Timeout: s.maxTimeout,
|
||||||
}
|
}
|
||||||
nginxContainer.CreateConfig(
|
nginxContainer.CreateConfig(
|
||||||
"/nginx.conf",
|
"/nginx.conf",
|
||||||
@ -78,7 +87,10 @@ func (s *VppProxySuite) SetupTest() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s *VppProxySuite) TearDownTest() {
|
func (s *VppProxySuite) TearDownTest() {
|
||||||
|
vpp := s.GetContainerByName(VppProxyContainerName).VppInstance
|
||||||
if CurrentSpecReport().Failed() {
|
if CurrentSpecReport().Failed() {
|
||||||
|
s.Log(vpp.Vppctl("show session verbose 2"))
|
||||||
|
s.Log(vpp.Vppctl("show error"))
|
||||||
s.CollectNginxLogs(NginxServerContainerName)
|
s.CollectNginxLogs(NginxServerContainerName)
|
||||||
}
|
}
|
||||||
s.HstSuite.TearDownTest()
|
s.HstSuite.TearDownTest()
|
||||||
@ -103,40 +115,41 @@ func (s *VppProxySuite) CurlRequest(targetUri string) (string, string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s *VppProxySuite) CurlRequestViaTunnel(targetUri string, proxyUri string) (string, string) {
|
func (s *VppProxySuite) CurlRequestViaTunnel(targetUri string, proxyUri string) (string, string) {
|
||||||
args := fmt.Sprintf("--max-time 60 --insecure -p -x %s %s", proxyUri, targetUri)
|
args := fmt.Sprintf("--max-time %d --insecure -p -x %s %s", s.maxTimeout, proxyUri, targetUri)
|
||||||
body, log := s.RunCurlContainer(args)
|
body, log := s.RunCurlContainer(args)
|
||||||
return body, log
|
return body, log
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *VppProxySuite) CurlDownloadResource(uri string) {
|
func (s *VppProxySuite) CurlDownloadResource(uri string) {
|
||||||
args := fmt.Sprintf("--insecure --noproxy '*' --remote-name --output-dir /tmp %s", uri)
|
args := fmt.Sprintf("-w @/tmp/write_out_download --max-time %d --insecure --noproxy '*' --remote-name --output-dir /tmp %s", s.maxTimeout, uri)
|
||||||
_, log := s.RunCurlContainer(args)
|
writeOut, log := s.RunCurlContainer(args)
|
||||||
s.AssertNotContains(log, "Recv failure")
|
s.AssertContains(writeOut, "GET response code: 200")
|
||||||
s.AssertContains(log, "HTTP/1.1 200")
|
s.AssertNotContains(log, "bytes remaining to read")
|
||||||
|
s.AssertNotContains(log, "Operation timed out")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *VppProxySuite) CurlUploadResource(uri, file string) {
|
func (s *VppProxySuite) CurlUploadResource(uri, file string) {
|
||||||
args := fmt.Sprintf("--insecure --noproxy '*' -T %s %s", file, uri)
|
args := fmt.Sprintf("-w @/tmp/write_out_upload --max-time %d --insecure --noproxy '*' -T %s %s", s.maxTimeout, file, uri)
|
||||||
_, log := s.RunCurlContainer(args)
|
writeOut, log := s.RunCurlContainer(args)
|
||||||
s.AssertContains(log, "HTTP/1.1 201")
|
s.AssertContains(writeOut, "PUT response code: 201")
|
||||||
|
s.AssertNotContains(log, "Operation timed out")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *VppProxySuite) CurlDownloadResourceViaTunnel(uri string, proxyUri string) {
|
func (s *VppProxySuite) CurlDownloadResourceViaTunnel(uri string, proxyUri string) {
|
||||||
args := fmt.Sprintf("--max-time 180 --insecure -p -x %s --remote-name --output-dir /tmp %s", proxyUri, uri)
|
args := fmt.Sprintf("-w @/tmp/write_out_download_connect --max-time %d --insecure -p -x %s --remote-name --output-dir /tmp %s", s.maxTimeout, proxyUri, uri)
|
||||||
_, log := s.RunCurlContainer(args)
|
writeOut, log := s.RunCurlContainer(args)
|
||||||
s.AssertNotContains(log, "Recv failure")
|
s.AssertContains(writeOut, "CONNECT response code: 200")
|
||||||
s.AssertNotContains(log, "Operation timed out")
|
s.AssertContains(writeOut, "GET response code: 200")
|
||||||
s.AssertContains(log, "CONNECT tunnel established")
|
|
||||||
s.AssertContains(log, "HTTP/1.1 200")
|
|
||||||
s.AssertNotContains(log, "bytes remaining to read")
|
s.AssertNotContains(log, "bytes remaining to read")
|
||||||
|
s.AssertNotContains(log, "Operation timed out")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *VppProxySuite) CurlUploadResourceViaTunnel(uri, proxyUri, file string) {
|
func (s *VppProxySuite) CurlUploadResourceViaTunnel(uri, proxyUri, file string) {
|
||||||
args := fmt.Sprintf("--max-time 180 --insecure -p -x %s -T %s %s", proxyUri, file, uri)
|
args := fmt.Sprintf("-w @/tmp/write_out_upload_connect --max-time %d --insecure -p -x %s -T %s %s", s.maxTimeout, proxyUri, file, uri)
|
||||||
_, log := s.RunCurlContainer(args)
|
writeOut, log := s.RunCurlContainer(args)
|
||||||
|
s.AssertContains(writeOut, "CONNECT response code: 200")
|
||||||
|
s.AssertContains(writeOut, "PUT response code: 201")
|
||||||
s.AssertNotContains(log, "Operation timed out")
|
s.AssertNotContains(log, "Operation timed out")
|
||||||
s.AssertContains(log, "CONNECT tunnel established")
|
|
||||||
s.AssertContains(log, "HTTP/1.1 201")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ = Describe("VppProxySuite", Ordered, ContinueOnFailure, func() {
|
var _ = Describe("VppProxySuite", Ordered, ContinueOnFailure, func() {
|
||||||
|
1
extras/hs-test/resources/curl/write_out_download
Normal file
1
extras/hs-test/resources/curl/write_out_download
Normal file
@ -0,0 +1 @@
|
|||||||
|
Download size: %{size_download} bytes\nDownload speed: %{speed_download} bytes per second\nGET response code: %{response_code}\n
|
1
extras/hs-test/resources/curl/write_out_download_connect
Normal file
1
extras/hs-test/resources/curl/write_out_download_connect
Normal file
@ -0,0 +1 @@
|
|||||||
|
Download size: %{size_download} bytes\nDownload speed: %{speed_download} bytes per second\nCONNECT response code: %{http_connect}\nGET response code: %{response_code}\n
|
1
extras/hs-test/resources/curl/write_out_upload
Normal file
1
extras/hs-test/resources/curl/write_out_upload
Normal file
@ -0,0 +1 @@
|
|||||||
|
Upload size: %{size_upload} bytes\nUpload speed: %{speed_upload} bytes per second\nPUT response code: %{response_code}\n
|
1
extras/hs-test/resources/curl/write_out_upload_connect
Normal file
1
extras/hs-test/resources/curl/write_out_upload_connect
Normal file
@ -0,0 +1 @@
|
|||||||
|
Upload size: %{size_upload} bytes\nUpload speed: %{speed_upload} bytes per second\nCONNECT response code: %{http_connect}\nPUT response code: %{response_code}\n
|
@ -15,6 +15,9 @@ events {
|
|||||||
http {
|
http {
|
||||||
keepalive_timeout 300s;
|
keepalive_timeout 300s;
|
||||||
keepalive_requests 1000000;
|
keepalive_requests 1000000;
|
||||||
|
client_body_timeout {{.Timeout}}s;
|
||||||
|
client_header_timeout {{.Timeout}}s;
|
||||||
|
send_timeout {{.Timeout}}s;
|
||||||
sendfile on;
|
sendfile on;
|
||||||
server {
|
server {
|
||||||
access_log /tmp/nginx/{{.LogPrefix}}-access.log;
|
access_log /tmp/nginx/{{.LogPrefix}}-access.log;
|
||||||
|
Reference in New Issue
Block a user