浏览代码

handle empty string for qps workers in driver and dont quit them on netperf

Alex Polcyn 9 年之前
父节点
当前提交
fcf09ea42e
共有 2 个文件被更改,包括 5 次插入4 次删除
  1. 1 1
      test/cpp/qps/driver.cc
  2. 4 3
      tools/run_tests/run_performance_tests.py

+ 1 - 1
test/cpp/qps/driver.cc

@@ -101,7 +101,7 @@ static std::unordered_map<string, std::deque<int>> get_hosts_and_cores(
 
 static deque<string> get_workers(const string& name) {
   char* env = gpr_getenv(name.c_str());
-  if (!env) return deque<string>();
+  if (!env || strlen(env) == 0) return deque<string>();
 
   deque<string> out;
   char* p = env;

+ 4 - 3
tools/run_tests/run_performance_tests.py

@@ -464,9 +464,10 @@ for scenario in scenarios:
     try:
       for worker in scenario.workers:
         worker.start()
-      scenario_failures, resultset = jobset.run([scenario.jobspec,
-                                                create_quit_jobspec(scenario.workers, remote_host=args.remote_driver_host)],
-                                                newline_on_success=True, maxjobs=1)
+      jobs = [scenario.jobspec]
+      if len(scenario.workers) > 0:
+        jobs.append(create_quit_jobspec(scenario.workers, remote_host=args.remote_driver_host))
+      scenario_failures, resultset = jobset.run(jobs, newline_on_success=True, maxjobs=1)
       total_scenario_failures += scenario_failures
       merged_resultset = dict(itertools.chain(merged_resultset.iteritems(),
                                               resultset.iteritems()))