resp, err := client.Do(req)
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
_, err = io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
duration := time.Since(t)
func HttpTpsTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
url := "http://" + serverAddress + ":8080/test_file_10M"
vpp.Vppctl("http tps uri tcp://0.0.0.0/8080")
// testing url handler app do not support multi-thread
s.SkipIfMultiWorker()
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers"))
s.Log(vpp.Vppctl("test-url-handler enable"))
s.AssertNil(err, fmt.Sprint(err))
resp, err := client.Do(req)
s.AssertNil(err, fmt.Sprint(err))
- defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
s.AssertEqual(false, resp.Close)
- body, err := io.ReadAll(resp.Body)
- s.AssertNil(err, fmt.Sprint(err))
- s.AssertEqual(string(body), "hello")
+ s.AssertHttpBody(resp, "hello")
o1 := vpp.Vppctl("show session verbose proto http state ready")
s.Log(o1)
s.AssertContains(o1, "ESTABLISHED")
req, err = http.NewRequest("GET", "http://"+serverAddress+":80/test2", nil)
- s.AssertNil(err, fmt.Sprint(err))
clientTrace := &httptrace.ClientTrace{
GotConn: func(info httptrace.GotConnInfo) {
s.AssertEqual(true, info.Reused, "connection not reused")
},
}
+ s.AssertNil(err, fmt.Sprint(err))
req = req.WithContext(httptrace.WithClientTrace(req.Context(), clientTrace))
resp, err = client.Do(req)
s.AssertNil(err, fmt.Sprint(err))
- defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
s.AssertEqual(false, resp.Close)
- body, err = io.ReadAll(resp.Body)
- s.AssertNil(err, fmt.Sprint(err))
- s.AssertEqual(string(body), "some data")
+ s.AssertHttpBody(resp, "some data")
o2 := vpp.Vppctl("show session verbose proto http state ready")
s.Log(o2)
s.AssertContains(o2, "ESTABLISHED")
s.AssertEqual(o1, o2)
+
}
func HttpPipeliningTest(s *NoTopoSuite) {
// testing url handler app do not support multi-thread
s.SkipIfMultiWorker()
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
s.Log(vpp.Vppctl("test-url-handler enable"))
}
func HttpClientTest(s *NoTopoSuite) {
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Ip4AddressString()
+ serverAddress := s.HostAddr()
server := ghttp.NewUnstartedServer()
l, err := net.Listen("tcp", serverAddress+":80")
s.AssertNil(err, fmt.Sprint(err))
}
func HttpClientErrRespTest(s *NoTopoSuite) {
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Ip4AddressString()
+ serverAddress := s.HostAddr()
server := ghttp.NewUnstartedServer()
l, err := net.Listen("tcp", serverAddress+":80")
s.AssertNil(err, fmt.Sprint(err))
}
func HttpClientPostFormTest(s *NoTopoSuite) {
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Ip4AddressString()
+ serverAddress := s.HostAddr()
body := "field1=value1&field2=value2"
server := ghttp.NewUnstartedServer()
}
func httpClientPostFile(s *NoTopoSuite, usePtr bool, fileSize int) {
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Ip4AddressString()
+ serverAddress := s.HostAddr()
vpp := s.GetContainerByName("vpp").VppInstance
fileName := "/tmp/test_file.txt"
s.Log(vpp.Container.Exec("fallocate -l " + strconv.Itoa(fileSize) + " " + fileName))
func HttpStaticPromTest(s *NoTopoSuite) {
query := "stats.prom"
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers"))
s.Log(vpp.Vppctl("prom enable"))
time.Sleep(time.Second * 5)
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, false))
- s.AssertEqual(200, resp.StatusCode)
- s.AssertContains(resp.Header.Get("Content-Type"), "text")
- s.AssertContains(resp.Header.Get("Content-Type"), "plain")
- s.AssertNotEqual(int64(0), resp.ContentLength)
+ s.AssertHttpStatus(resp, 200)
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "text/plain")
+ s.AssertGreaterThan(resp.ContentLength, 0)
_, err = io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
}
resp, err := client.Do(req)
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
_, err = io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
}
func PromConcurrentConnectionsTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
url := "http://" + serverAddress + ":80/stats.prom"
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers"))
s.SkipUnlessLeakCheck()
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
url := "http://" + serverAddress + ":80/stats.prom"
/* no goVPP less noise */
func HttpClientPostMemLeakTest(s *NoTopoSuite) {
s.SkipUnlessLeakCheck()
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Ip4AddressString()
+ serverAddress := s.HostAddr()
body := "field1=value1&field2=value2"
uri := "http://" + serverAddress + "/80"
s.SkipUnlessLeakCheck()
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
/* no goVPP less noise */
vpp.Disconnect()
}
func HttpStaticFileHandlerTestFunction(s *NoTopoSuite, max_age string) {
- var max_age_formatted string
+ var maxAgeFormatted string
if max_age == "default" {
- max_age_formatted = ""
+ maxAgeFormatted = ""
max_age = "600"
} else {
- max_age_formatted = "max-age " + max_age
+ maxAgeFormatted = "max-age " + max_age
}
content := "<html><body><p>Hello</p></body></html>"
content2 := "<html><body><p>Page</p></body></html>"
- currentDate := time.Now().In(time.FixedZone("GMT", 0)).Format(http.TimeFormat)[:17]
vpp := s.GetContainerByName("vpp").VppInstance
vpp.Container.Exec("mkdir -p " + wwwRootPath)
s.AssertNil(err, fmt.Sprint(err))
err = vpp.Container.CreateFile(wwwRootPath+"/page.html", content2)
s.AssertNil(err, fmt.Sprint(err))
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
- s.Log(vpp.Vppctl("http static server www-root " + wwwRootPath + " uri tcp://" + serverAddress + "/80 debug cache-size 2m " + max_age_formatted))
+ serverAddress := s.VppAddr()
+ s.Log(vpp.Vppctl("http static server www-root " + wwwRootPath + " uri tcp://" + serverAddress + "/80 debug cache-size 2m " + maxAgeFormatted))
client := NewHttpClient()
req, err := http.NewRequest("GET", "http://"+serverAddress+":80/index.html", nil)
s.AssertNil(err, fmt.Sprint(err))
resp, err := client.Do(req)
s.AssertNil(err, fmt.Sprint(err))
- defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
- s.AssertContains(resp.Header.Get("Content-Type"), "html")
- s.AssertContains(resp.Header.Get("Cache-Control"), "max-age="+max_age)
- // only checking date
- s.AssertContains(resp.Header.Get("Last-Modified"), currentDate)
- s.AssertEqual(len(resp.Header.Get("Last-Modified")), 29)
- s.AssertEqual(int64(len([]rune(content))), resp.ContentLength)
-
- body, err := io.ReadAll(resp.Body)
+ s.AssertHttpStatus(resp, 200)
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "text/html")
+ s.AssertHttpHeaderWithValue(resp, "Cache-Control", "max-age="+max_age)
+ parsedTime, err := time.Parse(time.RFC1123, resp.Header.Get("Last-Modified"))
s.AssertNil(err, fmt.Sprint(err))
- s.AssertEqual(string(body), content)
+ s.AssertTimeEqualWithinThreshold(parsedTime, time.Now(), time.Minute*5)
+ s.AssertEqual(len(resp.Header.Get("Last-Modified")), 29)
+ s.AssertHttpContentLength(resp, int64(len([]rune(content))))
+ s.AssertHttpBody(resp, content)
o := vpp.Vppctl("show http static server cache verbose")
s.Log(o)
s.AssertContains(o, "index.html")
resp, err = client.Do(req)
s.AssertNil(err, fmt.Sprint(err))
- defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
- s.AssertContains(resp.Header.Get("Content-Type"), "html")
- s.AssertContains(resp.Header.Get("Cache-Control"), "max-age="+max_age)
- s.AssertEqual(int64(len([]rune(content))), resp.ContentLength)
-
- body, err = io.ReadAll(resp.Body)
- s.AssertNil(err, fmt.Sprint(err))
- s.AssertEqual(string(body), content)
+ s.AssertHttpStatus(resp, 200)
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "text/html")
+ s.AssertHttpHeaderWithValue(resp, "Cache-Control", "max-age="+max_age)
+ s.AssertHttpContentLength(resp, int64(len([]rune(content))))
+ s.AssertHttpBody(resp, content)
req, err = http.NewRequest("GET", "http://"+serverAddress+":80/page.html", nil)
s.AssertNil(err, fmt.Sprint(err))
resp, err = client.Do(req)
s.AssertNil(err, fmt.Sprint(err))
- defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
- s.AssertContains(resp.Header.Get("Content-Type"), "html")
- s.AssertContains(resp.Header.Get("Cache-Control"), "max-age="+max_age)
- s.AssertEqual(int64(len([]rune(content2))), resp.ContentLength)
-
- body, err = io.ReadAll(resp.Body)
- s.AssertNil(err, fmt.Sprint(err))
- s.AssertEqual(string(body), content2)
+ s.AssertHttpStatus(resp, 200)
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "text/html")
+ s.AssertHttpHeaderWithValue(resp, "Cache-Control", "max-age="+max_age)
+ s.AssertHttpContentLength(resp, int64(len([]rune(content2))))
+ s.AssertHttpBody(resp, content2)
o = vpp.Vppctl("show http static server cache verbose")
s.Log(o)
s.AssertContains(o, "index.html")
vpp.Container.Exec("mkdir -p " + "/tmp/secret_folder")
err := vpp.Container.CreateFile("/tmp/secret_folder/secret_file.txt", "secret")
s.AssertNil(err, fmt.Sprint(err))
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server www-root " + wwwRootPath + " uri tcp://" + serverAddress + "/80 debug"))
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(404, resp.StatusCode)
- s.AssertEmpty(resp.Header.Get("Content-Type"))
- s.AssertEmpty(resp.Header.Get("Cache-Control"))
- s.AssertEqual(int64(0), resp.ContentLength)
+ s.AssertHttpStatus(resp, 404)
+ s.AssertHttpHeaderNotPresent(resp, "Content-Type")
+ s.AssertHttpHeaderNotPresent(resp, "Cache-Control")
+ s.AssertHttpContentLength(resp, int64(0))
}
func HttpStaticMovedTest(s *NoTopoSuite) {
vpp.Container.Exec("mkdir -p " + wwwRootPath + "/tmp.aaa")
err := vpp.Container.CreateFile(wwwRootPath+"/tmp.aaa/index.html", "<html><body><p>Hello</p></body></html>")
s.AssertNil(err, fmt.Sprint(err))
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server www-root " + wwwRootPath + " uri tcp://" + serverAddress + "/80 debug"))
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(301, resp.StatusCode)
- s.AssertEqual("http://"+serverAddress+"/tmp.aaa/index.html", resp.Header.Get("Location"))
- s.AssertEmpty(resp.Header.Get("Content-Type"))
- s.AssertEmpty(resp.Header.Get("Cache-Control"))
- s.AssertEqual(int64(0), resp.ContentLength)
+ s.AssertHttpStatus(resp, 301)
+ s.AssertHttpHeaderWithValue(resp, "Location", "http://"+serverAddress+"/tmp.aaa/index.html")
+ s.AssertHttpHeaderNotPresent(resp, "Content-Type")
+ s.AssertHttpHeaderNotPresent(resp, "Cache-Control")
+ s.AssertHttpContentLength(resp, int64(0))
}
func HttpStaticNotFoundTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
vpp.Container.Exec("mkdir -p " + wwwRootPath)
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server www-root " + wwwRootPath + " uri tcp://" + serverAddress + "/80 debug"))
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(404, resp.StatusCode)
- s.AssertEmpty(resp.Header.Get("Content-Type"))
- s.AssertEmpty(resp.Header.Get("Cache-Control"))
- s.AssertEqual(int64(0), resp.ContentLength)
+ s.AssertHttpStatus(resp, 404)
+ s.AssertHttpHeaderNotPresent(resp, "Content-Type")
+ s.AssertHttpHeaderNotPresent(resp, "Cache-Control")
+ s.AssertHttpContentLength(resp, int64(0))
}
func HttpCliMethodNotAllowedTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(405, resp.StatusCode)
- s.AssertNotEqual("", resp.Header.Get("Allow"), "server MUST generate an Allow header")
- s.AssertEmpty(resp.Header.Get("Content-Type"))
- s.AssertEqual(int64(0), resp.ContentLength)
+ s.AssertHttpStatus(resp, 405)
+ s.AssertHttpHeaderWithValue(resp, "Allow", "GET", "server MUST generate an Allow header")
+ s.AssertHttpHeaderNotPresent(resp, "Content-Type")
+ s.AssertHttpContentLength(resp, int64(0))
}
func HttpCliBadRequestTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(400, resp.StatusCode)
- s.AssertEmpty(resp.Header.Get("Content-Type"))
- s.AssertEqual(int64(0), resp.ContentLength)
+ s.AssertHttpStatus(resp, 400)
+ s.AssertHttpHeaderNotPresent(resp, "Content-Type")
+ s.AssertHttpContentLength(resp, int64(0))
}
func HttpStaticBuildInUrlGetVersionTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
data, err := io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
s.AssertContains(string(data), "vpp_details")
s.AssertNotContains(string(data), "build_by")
s.AssertNotContains(string(data), "build_host")
s.AssertNotContains(string(data), "build_dir")
- s.AssertContains(resp.Header.Get("Content-Type"), "json")
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "application/json")
}
func HttpStaticBuildInUrlGetVersionVerboseTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
data, err := io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
s.AssertContains(string(data), "vpp_details")
s.AssertContains(string(data), "build_by")
s.AssertContains(string(data), "build_host")
s.AssertContains(string(data), "build_dir")
- s.AssertContains(resp.Header.Get("Content-Type"), "json")
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "application/json")
}
func HttpStaticBuildInUrlGetIfListTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
data, err := io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
s.AssertContains(string(data), "interface_list")
- s.AssertContains(string(data), s.GetInterfaceByName(TapInterfaceName).Peer.Name())
- s.AssertContains(resp.Header.Get("Content-Type"), "json")
+ s.AssertContains(string(data), s.VppIfName())
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "application/json")
}
func HttpStaticBuildInUrlGetIfStatsTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
data, err := io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
s.AssertContains(string(data), "interface_stats")
s.AssertContains(string(data), "local0")
- s.AssertContains(string(data), s.GetInterfaceByName(TapInterfaceName).Peer.Name())
- s.AssertContains(resp.Header.Get("Content-Type"), "json")
+ s.AssertContains(string(data), s.VppIfName())
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "application/json")
}
func validatePostInterfaceStats(s *NoTopoSuite, data string) {
s.AssertContains(data, "interface_stats")
- s.AssertContains(data, s.GetInterfaceByName(TapInterfaceName).Peer.Name())
+ s.AssertContains(data, s.VppIfName())
s.AssertNotContains(data, "error")
s.AssertNotContains(data, "local0")
}
func HttpStaticBuildInUrlPostIfStatsTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
- body := []byte(s.GetInterfaceByName(TapInterfaceName).Peer.Name())
+ body := []byte(s.VppIfName())
client := NewHttpClient()
req, err := http.NewRequest("POST",
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
data, err := io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
validatePostInterfaceStats(s, string(data))
- s.AssertContains(resp.Header.Get("Content-Type"), "json")
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "application/json")
}
func HttpStaticMacTimeTest(s *NoTopoSuite) {
- currentDate := time.Now().In(time.FixedZone("GMT", 0)).Format(http.TimeFormat)[:17]
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
- s.Log(vpp.Vppctl("mactime enable-disable " + s.GetInterfaceByName(TapInterfaceName).Peer.Name()))
+ s.Log(vpp.Vppctl("mactime enable-disable " + s.VppIfName()))
client := NewHttpClient()
req, err := http.NewRequest("GET", "http://"+serverAddress+":80/mactime.json", nil)
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
data, err := io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
s.AssertContains(string(data), "mactime")
- s.AssertContains(string(data), s.GetInterfaceByName(TapInterfaceName).Ip4AddressString())
+ s.AssertContains(string(data), s.HostAddr())
s.AssertContains(string(data), s.GetInterfaceByName(TapInterfaceName).HwAddress.String())
- s.AssertContains(resp.Header.Get("Content-Type"), "json")
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "application/json")
+ parsedTime, err := time.Parse(time.RFC1123, resp.Header.Get("Date"))
+ s.AssertNil(err, fmt.Sprint(err))
+ s.AssertTimeEqualWithinThreshold(parsedTime, time.Now(), time.Minute*5)
s.AssertEqual(len(resp.Header.Get("Date")), 29)
- // only checking date
- s.AssertContains(resp.Header.Get("Date"), currentDate)
}
func HttpInvalidRequestLineTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
resp, err := TcpSendReceive(serverAddress+":80", " GET / HTTP/1.1")
func HttpRequestLineTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
resp, err := TcpSendReceive(serverAddress+":80", "\r\nGET /show/version HTTP/1.1\r\nHost:"+serverAddress+":80\r\nUser-Agent:test\r\n\r\n")
func HttpInvalidTargetSyntaxTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
resp, err := TcpSendReceive(serverAddress+":80", "GET /interface|stats.json HTTP/1.1\r\n\r\n")
func HttpInvalidContentLengthTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
resp, err := TcpSendReceive(serverAddress+":80", "GET /show/version HTTP/1.1\r\nContent-Length:\r\n\r\n")
func HttpContentLengthTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
s.Log(vpp.Vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers debug"))
- ifName := s.GetInterfaceByName(TapInterfaceName).Peer.Name()
+ ifName := s.VppIfName()
resp, err := TcpSendReceive(serverAddress+":80",
"POST /interface_stats.json HTTP/1.1\r\nContent-Length:4\r\n\r\n"+ifName)
func HttpMethodNotImplementedTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(501, resp.StatusCode)
- s.AssertEmpty(resp.Header.Get("Content-Type"))
- s.AssertEqual(int64(0), resp.ContentLength)
+ s.AssertHttpStatus(resp, 501)
+ s.AssertHttpHeaderNotPresent(resp, "Content-Type")
+ s.AssertHttpContentLength(resp, int64(0))
}
func HttpVersionNotSupportedTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
resp, err := TcpSendReceive(serverAddress+":80", "GET / HTTP/2\r\n\r\n")
func HttpUriDecodeTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
+ s.AssertHttpStatus(resp, 200)
data, err := io.ReadAll(resp.Body)
s.AssertNil(err, fmt.Sprint(err))
s.AssertNotContains(string(data), "unknown input")
s.AssertContains(string(data), "Compiler")
- s.AssertContains(resp.Header.Get("Content-Type"), "html")
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "text/html")
}
func HttpHeadersTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
resp, err := TcpSendReceive(
func HttpInvalidHeadersTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
resp, err := TcpSendReceive(serverAddress+":80", "GET /show/version HTTP/1.1\r\nUser-Agent: test\r\n")
func HeaderServerTest(s *NoTopoSuite) {
vpp := s.GetContainerByName("vpp").VppInstance
- serverAddress := s.GetInterfaceByName(TapInterfaceName).Peer.Ip4AddressString()
+ serverAddress := s.VppAddr()
vpp.Vppctl("http cli server")
client := NewHttpClient()
s.AssertNil(err, fmt.Sprint(err))
defer resp.Body.Close()
s.Log(DumpHttpResp(resp, true))
- s.AssertEqual(200, resp.StatusCode)
- s.AssertEqual("http_cli_server", resp.Header.Get("Server"))
- s.AssertContains(resp.Header.Get("Content-Type"), "html")
+ s.AssertHttpStatus(resp, 200)
+ s.AssertHttpHeaderWithValue(resp, "Server", "http_cli_server")
+ s.AssertHttpHeaderWithValue(resp, "Content-Type", "text/html")
}