From e82435922df57b9dc98c0fd0fbe3b830c0724c41 Mon Sep 17 00:00:00 2001
From: Jan Tattermusch <jtattermusch@google.com>
Date: Fri, 17 Apr 2015 14:14:01 -0700
Subject: [PATCH] fixes to run_tests.py to at least start building tests on
 Windows

---
 tools/run_tests/jobset.py    |  4 +++-
 tools/run_tests/run_tests.py |  4 ++--
 vsprojects/README.md         | 11 ++++++++---
 vsprojects/make.bat          |  7 +++++--
 4 files changed, 18 insertions(+), 8 deletions(-)

diff --git a/tools/run_tests/jobset.py b/tools/run_tests/jobset.py
index efe040aeb6..b8b4cf0001 100755
--- a/tools/run_tests/jobset.py
+++ b/tools/run_tests/jobset.py
@@ -144,7 +144,7 @@ def which(filename):
 class JobSpec(object):
   """Specifies what to run for a job."""
 
-  def __init__(self, cmdline, shortname=None, environ=None, hash_targets=None, cwd=None):
+  def __init__(self, cmdline, shortname=None, environ=None, hash_targets=None, cwd=None, shell=False):
     """
     Arguments:
       cmdline: a list of arguments to pass as the command line
@@ -161,6 +161,7 @@ class JobSpec(object):
     self.shortname = cmdline[0] if shortname is None else shortname
     self.hash_targets = hash_targets or []
     self.cwd = cwd
+    self.shell = shell
 
   def identity(self):
     return '%r %r %r' % (self.cmdline, self.environ, self.hash_targets)
@@ -187,6 +188,7 @@ class Job(object):
                                      stderr=subprocess.STDOUT,
                                      stdout=self._tempfile,
                                      cwd=spec.cwd,
+                                     shell=spec.shell,
                                      env=env)
     self._state = _RUNNING
     self._newline_on_success = newline_on_success
diff --git a/tools/run_tests/run_tests.py b/tools/run_tests/run_tests.py
index 8c8e78d859..4e24f4b510 100755
--- a/tools/run_tests/run_tests.py
+++ b/tools/run_tests/run_tests.py
@@ -346,8 +346,8 @@ if len(build_configs) > 1:
 
 if platform.system() == 'Windows':
   def make_jobspec(cfg, targets):
-    return jobset.JobSpec(['nmake', '/f', 'Grpc.mak', 'CONFIG=%s' % cfg] + targets,
-                          cwd='vsprojects\\vs2013')
+    return jobset.JobSpec(['make.bat', 'CONFIG=%s' % cfg] + targets,
+                          cwd='vsprojects', shell=True)
 else:
   def make_jobspec(cfg, targets):
     return jobset.JobSpec(['make',
diff --git a/vsprojects/README.md b/vsprojects/README.md
index 7026bf7704..e30b99c7b8 100644
--- a/vsprojects/README.md
+++ b/vsprojects/README.md
@@ -19,9 +19,14 @@ After that, open `grpc.sln` with Visual Studio and hit "Build".
 
 #Testing
 
-Use `make.bat` to build gRPC tests.
+Use `run_tests.py`, that also supports Windows (with a bit limited experience).
 ```
-make.bat test
+REM Run from repository root.
+python tools\run_tests\run_tests.py -l c
 ```
 
-
+Also, you can `make.bat` directly to build and run gRPC tests.
+```
+REM Run from this directory.
+make.bat alarm_test
+```
\ No newline at end of file
diff --git a/vsprojects/make.bat b/vsprojects/make.bat
index 4e17b40fcf..782952f944 100644
--- a/vsprojects/make.bat
+++ b/vsprojects/make.bat
@@ -2,8 +2,11 @@
 @rem Usage: make.bat TARGET_NAME
 
 setlocal
-@rem Set VS variables
+@rem Set VS variables (uses Visual Studio 2013)
 @call "%VS120COMNTOOLS%\..\..\vc\vcvarsall.bat" x86
 
-nmake.exe /f Grpc.mak %1
+echo %*
+
+nmake /f Grpc.mak %*
+exit /b %ERRORLEVEL%
 endlocal
\ No newline at end of file
-- 
GitLab