blob: 9872f8db560e505a053d5caf6053622c2d76ad2b [file] [log] [blame]
Filip Tehlarb15a0002022-11-10 12:34:17 +01001package main
2
Filip Tehlarc204c872022-12-21 08:59:16 +01003import (
Filip Tehlar8df3de42023-01-27 13:14:34 +01004 "fmt"
Filip Tehlarc204c872022-12-21 08:59:16 +01005 "os"
Filip Tehlar58113562023-04-15 20:41:18 +02006 "strings"
Filip Tehlarc204c872022-12-21 08:59:16 +01007)
8
Filip Tehlarb15a0002022-11-10 12:34:17 +01009func (s *NsSuite) TestHttpTps() {
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010010 iface := s.netInterfaces[clientInterface]
Maros Ondrejickae7625d02023-02-28 16:55:01 +010011 client_ip := iface.ip4AddressString()
Filip Tehlarb15a0002022-11-10 12:34:17 +010012 port := "8080"
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010013 finished := make(chan error, 1)
Maros Ondrejickadb823ed2022-12-14 16:30:04 +010014
15 container := s.getContainerByName("vpp")
Filip Tehlarb15a0002022-11-10 12:34:17 +010016
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010017 // configure vpp in the container
18 container.vppInstance.vppctl("http tps uri tcp://0.0.0.0/8080")
Filip Tehlarb15a0002022-11-10 12:34:17 +010019
Filip Tehlar4b3598e2023-09-02 08:54:21 +020020 go s.startWget(finished, client_ip, port, "test_file_10M", "client")
Filip Tehlarb15a0002022-11-10 12:34:17 +010021 // wait for client
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010022 err := <-finished
Maros Ondrejicka98a91e82022-12-06 15:38:05 +010023 s.assertNil(err)
Filip Tehlarb15a0002022-11-10 12:34:17 +010024}
25
Maros Ondrejicka11a03e92022-12-01 09:56:37 +010026func (s *VethsSuite) TestHttpCli() {
Maros Ondrejickadb823ed2022-12-14 16:30:04 +010027 serverContainer := s.getContainerByName("server-vpp")
28 clientContainer := s.getContainerByName("client-vpp")
Filip Tehlarb15a0002022-11-10 12:34:17 +010029
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010030 serverVeth := s.netInterfaces[serverInterfaceName]
Maros Ondrejickaffa3f602023-01-26 10:07:29 +010031
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010032 serverContainer.vppInstance.vppctl("http cli server")
Filip Tehlarb15a0002022-11-10 12:34:17 +010033
Maros Ondrejickae7625d02023-02-28 16:55:01 +010034 uri := "http://" + serverVeth.ip4AddressString() + "/80"
Maros Ondrejickaffa3f602023-01-26 10:07:29 +010035
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010036 o := clientContainer.vppInstance.vppctl("http cli client" +
Maros Ondrejickaffa3f602023-01-26 10:07:29 +010037 " uri " + uri + " query /show/version")
Filip Tehlarb15a0002022-11-10 12:34:17 +010038
Maros Ondrejickaffa3f602023-01-26 10:07:29 +010039 s.log(o)
Maros Ondrejicka98a91e82022-12-06 15:38:05 +010040 s.assertContains(o, "<html>", "<html> not found in the result!")
Filip Tehlarb15a0002022-11-10 12:34:17 +010041}
Filip Tehlarc204c872022-12-21 08:59:16 +010042
Filip Tehlar31eaea92023-06-15 10:06:57 +020043func (s *NoTopoSuite) TestNginxHttp3() {
44 s.SkipUnlessExtendedTestsBuilt()
45
46 query := "index.html"
47 nginxCont := s.getContainerByName("nginx-http3")
48 s.assertNil(nginxCont.run())
49
50 vpp := s.getContainerByName("vpp").vppInstance
51 vpp.waitForApp("nginx-", 5)
52 serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
53
54 defer func() { os.Remove(query) }()
55 curlCont := s.getContainerByName("curl")
Filip Tehlar87241fe2024-01-17 21:45:28 +010056 args := fmt.Sprintf("curl --noproxy '*' --local-port 55444 --http3-only -k https://%s:8443/%s", serverAddress, query)
Filip Tehlar31eaea92023-06-15 10:06:57 +020057 curlCont.extraRunningArgs = args
58 o, err := curlCont.combinedOutput()
59 s.assertNil(err)
60 s.assertContains(o, "<http>", "<http> not found in the result!")
61}
62
Filip Tehlarcc1475c2023-11-29 12:59:05 +010063func (s *NoTopoSuite) TestHttpStaticProm() {
64 finished := make(chan error, 1)
65 query := "stats.prom"
66 vpp := s.getContainerByName("vpp").vppInstance
67 serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
68 s.log(vpp.vppctl("http static server uri tcp://" + serverAddress + "/80 url-handlers"))
69 s.log(vpp.vppctl("prom enable"))
70 go s.startWget(finished, serverAddress, "80", query, "")
71 err := <-finished
72 s.assertNil(err)
73}
74
Maros Ondrejickaad406072023-02-24 14:16:25 +010075func (s *NoTopoSuite) TestNginxAsServer() {
Filip Tehlarc204c872022-12-21 08:59:16 +010076 query := "return_ok"
77 finished := make(chan error, 1)
Filip Tehlarc204c872022-12-21 08:59:16 +010078
79 nginxCont := s.getContainerByName("nginx")
80 s.assertNil(nginxCont.run())
81
Maros Ondrejicka7550dd22023-02-07 20:40:27 +010082 vpp := s.getContainerByName("vpp").vppInstance
Florin Corase2415f72023-02-28 14:51:03 -080083 vpp.waitForApp("nginx-", 5)
Filip Tehlarc204c872022-12-21 08:59:16 +010084
Maros Ondrejickae7625d02023-02-28 16:55:01 +010085 serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
Maros Ondrejicka7550dd22023-02-07 20:40:27 +010086
Filip Tehlarc204c872022-12-21 08:59:16 +010087 defer func() { os.Remove(query) }()
Filip Tehlar4b3598e2023-09-02 08:54:21 +020088 go s.startWget(finished, serverAddress, "80", query, "")
Filip Tehlarc204c872022-12-21 08:59:16 +010089 s.assertNil(<-finished)
90}
Filip Tehlar8df3de42023-01-27 13:14:34 +010091
Filip Tehlar58113562023-04-15 20:41:18 +020092func parseString(s, pattern string) string {
93 temp := strings.Split(s, "\n")
94 for _, item := range temp {
95 if strings.Contains(item, pattern) {
96 return item
97 }
98 }
99 return ""
100}
101
Filip Tehlar8df3de42023-01-27 13:14:34 +0100102func runNginxPerf(s *NoTopoSuite, mode, ab_or_wrk string) error {
103 nRequests := 1000000
Filip Tehlardda1f682023-04-24 17:52:50 +0200104 nClients := 1000
Filip Tehlar8df3de42023-01-27 13:14:34 +0100105
Maros Ondrejickae7625d02023-02-28 16:55:01 +0100106 serverAddress := s.netInterfaces[tapInterfaceName].peer.ip4AddressString()
Maros Ondrejicka7550dd22023-02-07 20:40:27 +0100107
Maros Ondrejicka7550dd22023-02-07 20:40:27 +0100108 vpp := s.getContainerByName("vpp").vppInstance
Filip Tehlar8df3de42023-01-27 13:14:34 +0100109
110 nginxCont := s.getContainerByName("nginx")
111 s.assertNil(nginxCont.run())
Florin Corase2415f72023-02-28 14:51:03 -0800112 vpp.waitForApp("nginx-", 5)
Filip Tehlar8df3de42023-01-27 13:14:34 +0100113
Filip Tehlarb41b0af2023-03-20 12:39:20 +0100114 if ab_or_wrk == "ab" {
115 abCont := s.getContainerByName("ab")
116 args := fmt.Sprintf("-n %d -c %d", nRequests, nClients)
117 if mode == "rps" {
118 args += " -k"
119 } else if mode != "cps" {
120 return fmt.Errorf("invalid mode %s; expected cps/rps", mode)
121 }
Filip Tehlardda1f682023-04-24 17:52:50 +0200122 // don't exit on socket receive errors
123 args += " -r"
Filip Tehlarb41b0af2023-03-20 12:39:20 +0100124 args += " http://" + serverAddress + ":80/64B.json"
125 abCont.extraRunningArgs = args
126 o, err := abCont.combinedOutput()
Filip Tehlar58113562023-04-15 20:41:18 +0200127 rps := parseString(o, "Requests per second:")
128 s.log(rps, err)
Filip Tehlarb41b0af2023-03-20 12:39:20 +0100129 s.assertNil(err)
130 } else {
131 wrkCont := s.getContainerByName("wrk")
132 args := fmt.Sprintf("-c %d -t 2 -d 30 http://%s:80/64B.json", nClients,
133 serverAddress)
134 wrkCont.extraRunningArgs = args
135 o, err := wrkCont.combinedOutput()
Filip Tehlar58113562023-04-15 20:41:18 +0200136 rps := parseString(o, "requests")
137 s.log(rps, err)
Filip Tehlarb41b0af2023-03-20 12:39:20 +0100138 s.assertNil(err)
139 }
Filip Tehlar8df3de42023-01-27 13:14:34 +0100140 return nil
141}
142
143func (s *NoTopoSuite) TestNginxPerfCps() {
144 s.assertNil(runNginxPerf(s, "cps", "ab"))
145}
146
147func (s *NoTopoSuite) TestNginxPerfRps() {
148 s.assertNil(runNginxPerf(s, "rps", "ab"))
149}
150
151func (s *NoTopoSuite) TestNginxPerfWrk() {
152 s.assertNil(runNginxPerf(s, "", "wrk"))
153}