+
+func runNginxPerf(s *NoTopoSuite, mode, ab_or_wrk string) error {
+ nRequests := 1000000
+ nClients := 2000
+ var args []string
+ var exeName string
+
+ if ab_or_wrk == "ab" {
+ args = []string{"-n", fmt.Sprintf("%d", nRequests), "-c",
+ fmt.Sprintf("%d", nClients)}
+ if mode == "rps" {
+ args = append(args, "-k")
+ } else if mode != "cps" {
+ return fmt.Errorf("invalid mode %s; expected cps/rps", mode)
+ }
+ args = append(args, "http://10.10.10.1:80/64B.json")
+ exeName = "ab"
+ } else {
+ args = []string{"-c", fmt.Sprintf("%d", nClients), "-t", "2", "-d", "30",
+ "http://10.10.10.1:80"}
+ exeName = "wrk"
+ }
+
+ 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())
+ err := waitForApp(vppInst, "-app", 5)
+ s.assertNil(err)
+
+ cmd := exec.Command(exeName, args...)
+ fmt.Println(cmd)
+ o, _ := cmd.CombinedOutput()
+ fmt.Print(string(o))
+ 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"))
+}