hs-test: add http prom test
[vpp.git] / extras / hs-test / http_test.go
old mode 100755 (executable)
new mode 100644 (file)
index 665a3e4..53e6ec2
@@ -1,26 +1,25 @@
 package main
 
 import (
+       "fmt"
        "os"
-       "time"
+       "strings"
 )
 
 func (s *NsSuite) TestHttpTps() {
-       finished := make(chan error, 1)
-       server_ip := "10.0.0.2"
+       iface := s.netInterfaces[clientInterface]
+       client_ip := iface.ip4AddressString()
        port := "8080"
+       finished := make(chan error, 1)
 
        container := s.getContainerByName("vpp")
 
-       s.log("starting vpp..")
+       // configure vpp in the container
+       container.vppInstance.vppctl("http tps uri tcp://0.0.0.0/8080")
 
-       // start & configure vpp in the container
-       _, err := container.execAction("ConfigureHttpTps")
-       s.assertNil(err)
-
-       go startWget(finished, server_ip, port, "test_file_10M", "client")
+       go s.startWget(finished, client_ip, port, "test_file_10M", "client")
        // wait for client
-       err = <-finished
+       err := <-finished
        s.assertNil(err)
 }
 
@@ -28,39 +27,127 @@ func (s *VethsSuite) TestHttpCli() {
        serverContainer := s.getContainerByName("server-vpp")
        clientContainer := s.getContainerByName("client-vpp")
 
-       _, err := serverContainer.execAction("Configure2Veths srv")
-       s.assertNil(err)
+       serverVeth := s.netInterfaces[serverInterfaceName]
 
-       _, err = clientContainer.execAction("Configure2Veths cln")
-       s.assertNil(err)
+       serverContainer.vppInstance.vppctl("http cli server")
 
-       s.log("configured IPs...")
+       uri := "http://" + serverVeth.ip4AddressString() + "/80"
 
-       _, err = serverContainer.execAction("RunHttpCliSrv")
-       s.assertNil(err)
+       o := clientContainer.vppInstance.vppctl("http cli client" +
+               " uri " + uri + " query /show/version")
 
-       s.log("configured http server")
+       s.log(o)
+       s.assertContains(o, "<html>", "<html> not found in the result!")
+}
 
-       o, err := clientContainer.execAction("RunHttpCliCln /show/version")
+func (s *NoTopoSuite) TestNginxHttp3() {
+       s.SkipUnlessExtendedTestsBuilt()
+
+       query := "index.html"
+       nginxCont := s.getContainerByName("nginx-http3")
+       s.assertNil(nginxCont.run())
+
+       vpp := s.getContainerByName("vpp").vppInstance
+       vpp.waitForApp("nginx-", 5)
+       serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
+
+       defer func() { os.Remove(query) }()
+       curlCont := s.getContainerByName("curl")
+       args := fmt.Sprintf("curl --noproxy '*' --http3-only -k https://%s:8443/%s", serverAddress, query)
+       curlCont.extraRunningArgs = args
+       o, err := curlCont.combinedOutput()
        s.assertNil(err)
+       s.assertContains(o, "<http>", "<http> not found in the result!")
+}
 
-       s.assertContains(o, "<html>", "<html> not found in the result!")
+func (s *NoTopoSuite) TestHttpStaticProm() {
+       finished := make(chan error, 1)
+       query := "stats.prom"
+       vpp := s.getContainerByName("vpp").vppInstance
+       serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
+       s.log(vpp.vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers"))
+       s.log(vpp.vppctl("prom enable"))
+       go s.startWget(finished, serverAddress, "80", query, "")
+       err := <-finished
+       s.assertNil(err)
 }
 
-func (s *NoTopoSuite) TestNginx() {
+func (s *NoTopoSuite) TestNginxAsServer() {
        query := "return_ok"
        finished := make(chan error, 1)
-       vppCont := s.getContainerByName("vpp")
-       vppInst := NewVppInstance(vppCont)
-       vppInst.actionFuncName = "ConfigureTap"
-       s.assertNil(vppInst.start(), "failed to start vpp")
 
        nginxCont := s.getContainerByName("nginx")
        s.assertNil(nginxCont.run())
 
-       time.Sleep(3 * time.Second)
+       vpp := s.getContainerByName("vpp").vppInstance
+       vpp.waitForApp("nginx-", 5)
+
+       serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
 
        defer func() { os.Remove(query) }()
-       go startWget(finished, "10.10.10.1", "80", query, "")
+       go s.startWget(finished, serverAddress, "80", query, "")
        s.assertNil(<-finished)
 }
+
+func parseString(s, pattern string) string {
+       temp := strings.Split(s, "\n")
+       for _, item := range temp {
+               if strings.Contains(item, pattern) {
+                       return item
+               }
+       }
+       return ""
+}
+
+func runNginxPerf(s *NoTopoSuite, mode, ab_or_wrk string) error {
+       nRequests := 1000000
+       nClients := 1000
+
+       serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
+
+       vpp := s.getContainerByName("vpp").vppInstance
+
+       nginxCont := s.getContainerByName("nginx")
+       s.assertNil(nginxCont.run())
+       vpp.waitForApp("nginx-", 5)
+
+       if ab_or_wrk == "ab" {
+               abCont := s.getContainerByName("ab")
+               args := fmt.Sprintf("-n %d -c %d", nRequests, nClients)
+               if mode == "rps" {
+                       args += " -k"
+               } else if mode != "cps" {
+                       return fmt.Errorf("invalid mode %s; expected cps/rps", mode)
+               }
+               // don't exit on socket receive errors
+               args += " -r"
+               args += " http://" + serverAddress + ":80/64B.json"
+               abCont.extraRunningArgs = args
+               o, err := abCont.combinedOutput()
+               rps := parseString(o, "Requests per second:")
+               s.log(rps, err)
+               s.assertNil(err)
+       } else {
+               wrkCont := s.getContainerByName("wrk")
+               args := fmt.Sprintf("-c %d -t 2 -d 30 http://%s:80/64B.json", nClients,
+                       serverAddress)
+               wrkCont.extraRunningArgs = args
+               o, err := wrkCont.combinedOutput()
+               rps := parseString(o, "requests")
+               s.log(rps, err)
+               s.assertNil(err)
+       }
+       return nil
+}
+
+func (s *NoTopoSuite) TestNginxPerfCps() {
+       s.assertNil(runNginxPerf(s, "cps", "ab"))
+}
+
+func (s *NoTopoSuite) TestNginxPerfRps() {
+       s.assertNil(runNginxPerf(s, "rps", "ab"))
+}
+
+func (s *NoTopoSuite) TestNginxPerfWrk() {
+       s.assertNil(runNginxPerf(s, "", "wrk"))
+}