Merge pull request #7265 from thunderboltsid/issue-7094-retry

Retrying: Make the testing scripts executable on Python 3.x
pull/7373/head
Nicolas Noble 9 years ago committed by GitHub
commit 7a70bb5486
  1. 1
      templates/tools/dockerfile/interoptest/grpc_interop_csharp/Dockerfile.template
  2. 1
      templates/tools/dockerfile/interoptest/grpc_interop_cxx/Dockerfile.template
  3. 1
      templates/tools/dockerfile/interoptest/grpc_interop_go/Dockerfile.template
  4. 1
      templates/tools/dockerfile/interoptest/grpc_interop_http2/Dockerfile.template
  5. 1
      templates/tools/dockerfile/interoptest/grpc_interop_java/Dockerfile.template
  6. 1
      templates/tools/dockerfile/interoptest/grpc_interop_node/Dockerfile.template
  7. 1
      templates/tools/dockerfile/interoptest/grpc_interop_php/Dockerfile.template
  8. 1
      templates/tools/dockerfile/interoptest/grpc_interop_ruby/Dockerfile.template
  9. 2
      templates/tools/dockerfile/python_deps.include
  10. 1
      templates/tools/dockerfile/stress_test/grpc_interop_stress_csharp/Dockerfile.template
  11. 1
      templates/tools/dockerfile/stress_test/grpc_interop_stress_cxx/Dockerfile.template
  12. 1
      templates/tools/dockerfile/stress_test/grpc_interop_stress_go/Dockerfile.template
  13. 1
      templates/tools/dockerfile/stress_test/grpc_interop_stress_java/Dockerfile.template
  14. 1
      templates/tools/dockerfile/stress_test/grpc_interop_stress_node/Dockerfile.template
  15. 1
      templates/tools/dockerfile/stress_test/grpc_interop_stress_php/Dockerfile.template
  16. 1
      templates/tools/dockerfile/stress_test/grpc_interop_stress_ruby/Dockerfile.template
  17. 1
      templates/tools/dockerfile/test/csharp_coreclr_x64/Dockerfile.template
  18. 1
      templates/tools/dockerfile/test/csharp_jessie_x64/Dockerfile.template
  19. 1
      templates/tools/dockerfile/test/cxx_jessie_x64/Dockerfile.template
  20. 2
      templates/tools/dockerfile/test/cxx_jessie_x86/Dockerfile.template
  21. 1
      templates/tools/dockerfile/test/cxx_ubuntu1404_x64/Dockerfile.template
  22. 2
      templates/tools/dockerfile/test/cxx_ubuntu1604_x64/Dockerfile.template
  23. 1
      templates/tools/dockerfile/test/cxx_wheezy_x64/Dockerfile.template
  24. 1
      templates/tools/dockerfile/test/fuzzer/Dockerfile.template
  25. 2
      templates/tools/dockerfile/test/node_jessie_x64/Dockerfile.template
  26. 2
      templates/tools/dockerfile/test/php_jessie_x64/Dockerfile.template
  27. 2
      templates/tools/dockerfile/test/ruby_jessie_x64/Dockerfile.template
  28. 1
      templates/tools/dockerfile/test/sanity/Dockerfile.template
  29. 15
      tools/dockerfile/interoptest/grpc_interop_csharp/Dockerfile
  30. 15
      tools/dockerfile/interoptest/grpc_interop_cxx/Dockerfile
  31. 15
      tools/dockerfile/interoptest/grpc_interop_go/Dockerfile
  32. 15
      tools/dockerfile/interoptest/grpc_interop_http2/Dockerfile
  33. 15
      tools/dockerfile/interoptest/grpc_interop_java/Dockerfile
  34. 15
      tools/dockerfile/interoptest/grpc_interop_node/Dockerfile
  35. 15
      tools/dockerfile/interoptest/grpc_interop_php/Dockerfile
  36. 2
      tools/dockerfile/interoptest/grpc_interop_python/Dockerfile
  37. 15
      tools/dockerfile/interoptest/grpc_interop_ruby/Dockerfile
  38. 15
      tools/dockerfile/stress_test/grpc_interop_stress_csharp/Dockerfile
  39. 15
      tools/dockerfile/stress_test/grpc_interop_stress_cxx/Dockerfile
  40. 15
      tools/dockerfile/stress_test/grpc_interop_stress_go/Dockerfile
  41. 15
      tools/dockerfile/stress_test/grpc_interop_stress_java/Dockerfile
  42. 15
      tools/dockerfile/stress_test/grpc_interop_stress_node/Dockerfile
  43. 15
      tools/dockerfile/stress_test/grpc_interop_stress_php/Dockerfile
  44. 2
      tools/dockerfile/stress_test/grpc_interop_stress_python/Dockerfile
  45. 15
      tools/dockerfile/stress_test/grpc_interop_stress_ruby/Dockerfile
  46. 15
      tools/dockerfile/test/csharp_coreclr_x64/Dockerfile
  47. 15
      tools/dockerfile/test/csharp_jessie_x64/Dockerfile
  48. 15
      tools/dockerfile/test/cxx_jessie_x64/Dockerfile
  49. 15
      tools/dockerfile/test/cxx_jessie_x86/Dockerfile
  50. 15
      tools/dockerfile/test/cxx_ubuntu1404_x64/Dockerfile
  51. 15
      tools/dockerfile/test/cxx_ubuntu1604_x64/Dockerfile
  52. 15
      tools/dockerfile/test/cxx_wheezy_x64/Dockerfile
  53. 15
      tools/dockerfile/test/fuzzer/Dockerfile
  54. 2
      tools/dockerfile/test/multilang_jessie_x64/Dockerfile
  55. 15
      tools/dockerfile/test/node_jessie_x64/Dockerfile
  56. 15
      tools/dockerfile/test/php_jessie_x64/Dockerfile
  57. 2
      tools/dockerfile/test/python_jessie_x64/Dockerfile
  58. 15
      tools/dockerfile/test/ruby_jessie_x64/Dockerfile
  59. 15
      tools/dockerfile/test/sanity/Dockerfile
  60. 2
      tools/run_tests/artifact_targets.py
  61. 2
      tools/run_tests/distribtest_targets.py
  62. 4
      tools/run_tests/dockerjob.py
  63. 8
      tools/run_tests/jobset.py
  64. 2
      tools/run_tests/package_targets.py
  65. 12
      tools/run_tests/port_server.py
  66. 8
      tools/run_tests/report_utils.py
  67. 28
      tools/run_tests/run_interop_tests.py
  68. 12
      tools/run_tests/run_performance_tests.py
  69. 16
      tools/run_tests/run_stress_tests.py
  70. 82
      tools/run_tests/run_tests.py
  71. 4
      tools/run_tests/task_runner.py

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../csharp_deps.include"/> <%include file="../../csharp_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.

@ -32,6 +32,7 @@
FROM golang:1.5 FROM golang:1.5
<%include file="../../go_path.include"/> <%include file="../../go_path.include"/>
<%include file="../../python_deps.include"/>
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,6 +32,7 @@
FROM golang:1.5 FROM golang:1.5
<%include file="../../go_path.include"/> <%include file="../../go_path.include"/>
<%include file="../../python_deps.include"/>
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../java_deps.include"/> <%include file="../../java_deps.include"/>
<%include file="../../python_deps.include"/>
# Trigger download of as many Gradle artifacts as possible. # Trigger download of as many Gradle artifacts as possible.
RUN git clone --recursive --depth 1 https://github.com/grpc/grpc-java.git && ${'\\'} RUN git clone --recursive --depth 1 https://github.com/grpc/grpc-java.git && ${'\\'}

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../node_deps.include"/> <%include file="../../node_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ruby_deps.include"/> <%include file="../../ruby_deps.include"/>
<%include file="../../php_deps.include"/> <%include file="../../php_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ruby_deps.include"/> <%include file="../../ruby_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.

@ -11,4 +11,4 @@ RUN apt-get update && apt-get install -y ${'\\'}
# Install Python packages from PyPI # Install Python packages from PyPI
RUN pip install pip --upgrade RUN pip install pip --upgrade
RUN pip install virtualenv RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ccache_setup.include"/> <%include file="../../ccache_setup.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../gcp_api_libraries.include"/> <%include file="../../gcp_api_libraries.include"/>

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ccache_setup.include"/> <%include file="../../ccache_setup.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../gcp_api_libraries.include"/> <%include file="../../gcp_api_libraries.include"/>

@ -32,6 +32,7 @@
FROM golang:1.5 FROM golang:1.5
<%include file="../../gcp_api_libraries.include"/> <%include file="../../gcp_api_libraries.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../go_path.include"/> <%include file="../../go_path.include"/>
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ccache_setup.include"/> <%include file="../../ccache_setup.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../gcp_api_libraries.include"/> <%include file="../../gcp_api_libraries.include"/>

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../node_deps.include"/> <%include file="../../node_deps.include"/>
<%include file="../../gcp_api_libraries.include"/> <%include file="../../gcp_api_libraries.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ruby_deps.include"/> <%include file="../../ruby_deps.include"/>
<%include file="../../gcp_api_libraries.include"/> <%include file="../../gcp_api_libraries.include"/>
<%include file="../../php_deps.include"/> <%include file="../../php_deps.include"/>

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ccache_setup.include"/> <%include file="../../ccache_setup.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../gcp_api_libraries.include"/> <%include file="../../gcp_api_libraries.include"/>

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../csharp_deps.include"/> <%include file="../../csharp_deps.include"/>
# Install dotnet SDK based on https://www.microsoft.com/net/core#debian # Install dotnet SDK based on https://www.microsoft.com/net/core#debian

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../csharp_deps.include"/> <%include file="../../csharp_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../clang_update.include"/> <%include file="../../clang_update.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>

@ -32,8 +32,8 @@
FROM 32bit/debian:jessie FROM 32bit/debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,6 +32,7 @@
FROM ubuntu:14.04 FROM ubuntu:14.04
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../run_tests_addons_nocache.include"/> <%include file="../../run_tests_addons_nocache.include"/>
# Define the default command. # Define the default command.

@ -32,6 +32,7 @@
FROM ubuntu:16.04 FROM ubuntu:16.04
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
@ -42,4 +43,3 @@
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,6 +32,7 @@
FROM debian:wheezy FROM debian:wheezy
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
RUN apt-get update && apt-get install -y ${'\\'} RUN apt-get update && apt-get install -y ${'\\'}

@ -32,6 +32,7 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../cxx_deps.include"/> <%include file="../../cxx_deps.include"/>
<%include file="../../clang_update.include"/> <%include file="../../clang_update.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>

@ -32,8 +32,8 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../node_deps.include"/> <%include file="../../node_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,8 +32,8 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../php_deps.include"/> <%include file="../../php_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,8 +32,8 @@
FROM debian:jessie FROM debian:jessie
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
<%include file="../../ruby_deps.include"/> <%include file="../../ruby_deps.include"/>
<%include file="../../run_tests_addons.include"/> <%include file="../../run_tests_addons.include"/>
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,6 +32,7 @@
FROM ubuntu:15.10 FROM ubuntu:15.10
<%include file="../../apt_get_basic.include"/> <%include file="../../apt_get_basic.include"/>
<%include file="../../python_deps.include"/>
#======================== #========================
# Sanity test dependencies # Sanity test dependencies
RUN apt-get update && apt-get install -y ${"\\"} RUN apt-get update && apt-get install -y ${"\\"}

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================ #================
# C# dependencies # C# dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# C++ dependencies # C++ dependencies
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean

@ -32,5 +32,20 @@ FROM golang:1.5
# Using login shell removes Go from path, so we add it. # Using login shell removes Go from path, so we add it.
RUN ln -s /usr/local/go/bin/go /usr/local/bin RUN ln -s /usr/local/go/bin/go /usr/local/bin
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -32,5 +32,20 @@ FROM golang:1.5
# Using login shell removes Go from path, so we add it. # Using login shell removes Go from path, so we add it.
RUN ln -s /usr/local/go/bin/go /usr/local/bin RUN ln -s /usr/local/go/bin/go /usr/local/bin
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Define the default command. # Define the default command.
CMD ["bash"] CMD ["bash"]

@ -47,6 +47,21 @@ ENV JAVA_HOME /usr/lib/jvm/java-8-oracle
ENV PATH $PATH:$JAVA_HOME/bin ENV PATH $PATH:$JAVA_HOME/bin
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Trigger download of as many Gradle artifacts as possible. # Trigger download of as many Gradle artifacts as possible.
RUN git clone --recursive --depth 1 https://github.com/grpc/grpc-java.git && \ RUN git clone --recursive --depth 1 https://github.com/grpc/grpc-java.git && \

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================== #==================
# Node dependencies # Node dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================== #==================
# Ruby dependencies # Ruby dependencies

@ -76,7 +76,7 @@ RUN apt-get update && apt-get install -y \
# Install Python packages from PyPI # Install Python packages from PyPI
RUN pip install pip --upgrade RUN pip install pip --upgrade
RUN pip install virtualenv RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Prepare ccache # Prepare ccache
RUN ln -s /usr/bin/ccache /usr/local/bin/gcc RUN ln -s /usr/bin/ccache /usr/local/bin/gcc

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================== #==================
# Ruby dependencies # Ruby dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Prepare ccache # Prepare ccache
RUN ln -s /usr/bin/ccache /usr/local/bin/gcc RUN ln -s /usr/bin/ccache /usr/local/bin/gcc
RUN ln -s /usr/bin/ccache /usr/local/bin/g++ RUN ln -s /usr/bin/ccache /usr/local/bin/g++

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Prepare ccache # Prepare ccache
RUN ln -s /usr/bin/ccache /usr/local/bin/gcc RUN ln -s /usr/bin/ccache /usr/local/bin/gcc
RUN ln -s /usr/bin/ccache /usr/local/bin/g++ RUN ln -s /usr/bin/ccache /usr/local/bin/g++

@ -34,6 +34,21 @@ RUN apt-get update && apt-get install -y python-pip && apt-get clean
RUN pip install --upgrade google-api-python-client RUN pip install --upgrade google-api-python-client
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Using login shell removes Go from path, so we add it. # Using login shell removes Go from path, so we add it.
RUN ln -s /usr/local/go/bin/go /usr/local/bin RUN ln -s /usr/local/go/bin/go /usr/local/bin

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Prepare ccache # Prepare ccache
RUN ln -s /usr/bin/ccache /usr/local/bin/gcc RUN ln -s /usr/bin/ccache /usr/local/bin/gcc
RUN ln -s /usr/bin/ccache /usr/local/bin/g++ RUN ln -s /usr/bin/ccache /usr/local/bin/g++

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================== #==================
# Node dependencies # Node dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================== #==================
# Ruby dependencies # Ruby dependencies

@ -93,7 +93,7 @@ RUN apt-get update && apt-get install -y \
# Install Python packages from PyPI # Install Python packages from PyPI
RUN pip install pip --upgrade RUN pip install pip --upgrade
RUN pip install virtualenv RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
RUN pip install coverage RUN pip install coverage

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Prepare ccache # Prepare ccache
RUN ln -s /usr/bin/ccache /usr/local/bin/gcc RUN ln -s /usr/bin/ccache /usr/local/bin/gcc
RUN ln -s /usr/bin/ccache /usr/local/bin/g++ RUN ln -s /usr/bin/ccache /usr/local/bin/g++

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================ #================
# C# dependencies # C# dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================ #================
# C# dependencies # C# dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# C++ dependencies # C++ dependencies
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# C++ dependencies # C++ dependencies
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# C++ dependencies # C++ dependencies
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# C++ dependencies # C++ dependencies
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# C++ dependencies # C++ dependencies
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# C++ dependencies # C++ dependencies
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean

@ -137,7 +137,7 @@ RUN apt-get update && apt-get install -y \
# Install Python packages from PyPI # Install Python packages from PyPI
RUN pip install pip --upgrade RUN pip install pip --upgrade
RUN pip install virtualenv RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Prepare ccache # Prepare ccache
RUN ln -s /usr/bin/ccache /usr/local/bin/gcc RUN ln -s /usr/bin/ccache /usr/local/bin/gcc

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================== #==================
# Node dependencies # Node dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================= #=================
# PHP dependencies # PHP dependencies

@ -76,7 +76,7 @@ RUN apt-get update && apt-get install -y \
# Install Python packages from PyPI # Install Python packages from PyPI
RUN pip install pip --upgrade RUN pip install pip --upgrade
RUN pip install virtualenv RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
# Prepare ccache # Prepare ccache
RUN ln -s /usr/bin/ccache /usr/local/bin/gcc RUN ln -s /usr/bin/ccache /usr/local/bin/gcc

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#================== #==================
# Ruby dependencies # Ruby dependencies

@ -63,6 +63,21 @@ RUN apt-get update && apt-get install -y \
# Build profiling # Build profiling
RUN apt-get update && apt-get install -y time && apt-get clean RUN apt-get update && apt-get install -y time && apt-get clean
#====================
# Python dependencies
# Install dependencies
RUN apt-get update && apt-get install -y \
python-all-dev \
python3-all-dev \
python-pip
# Install Python packages from PyPI
RUN pip install pip --upgrade
RUN pip install virtualenv
RUN pip install futures==2.2.0 enum34==1.0.4 protobuf==3.0.0a2 six==1.10.0
#======================== #========================
# Sanity test dependencies # Sanity test dependencies
RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \

@ -40,7 +40,7 @@ def create_docker_jobspec(name, dockerfile_dir, shell_command, environ={},
environ['RUN_COMMAND'] = shell_command environ['RUN_COMMAND'] = shell_command
docker_args=[] docker_args=[]
for k,v in environ.iteritems(): for k,v in environ.items():
docker_args += ['-e', '%s=%s' % (k, v)] docker_args += ['-e', '%s=%s' % (k, v)]
docker_env = {'DOCKERFILE_DIR': dockerfile_dir, docker_env = {'DOCKERFILE_DIR': dockerfile_dir,
'DOCKER_RUN_SCRIPT': 'tools/run_tests/dockerize/docker_run.sh', 'DOCKER_RUN_SCRIPT': 'tools/run_tests/dockerize/docker_run.sh',

@ -41,7 +41,7 @@ def create_docker_jobspec(name, dockerfile_dir, shell_command, environ={},
environ['RELATIVE_COPY_PATH'] = 'test/distrib' environ['RELATIVE_COPY_PATH'] = 'test/distrib'
docker_args=[] docker_args=[]
for k,v in environ.iteritems(): for k,v in environ.items():
docker_args += ['-e', '%s=%s' % (k, v)] docker_args += ['-e', '%s=%s' % (k, v)]
docker_env = {'DOCKERFILE_DIR': dockerfile_dir, docker_env = {'DOCKERFILE_DIR': dockerfile_dir,
'DOCKER_RUN_SCRIPT': 'tools/run_tests/dockerize/docker_run.sh'} 'DOCKER_RUN_SCRIPT': 'tools/run_tests/dockerize/docker_run.sh'}

@ -29,6 +29,8 @@
"""Helpers to run docker instances as jobs.""" """Helpers to run docker instances as jobs."""
from __future__ import print_function
import jobset import jobset
import tempfile import tempfile
import time import time
@ -95,7 +97,7 @@ def remove_image(image, skip_nonexistent=False, max_retries=10):
stderr=subprocess.STDOUT) == 0: stderr=subprocess.STDOUT) == 0:
return True return True
time.sleep(2) time.sleep(2)
print 'Failed to remove docker image %s' % image print('Failed to remove docker image %s' % image)
return False return False

@ -29,6 +29,8 @@
"""Run a group of subprocesses and then finish.""" """Run a group of subprocesses and then finish."""
from __future__ import print_function
import multiprocessing import multiprocessing
import os import os
import platform import platform
@ -123,8 +125,8 @@ def message(tag, msg, explanatory_text=None, do_newline=False):
try: try:
if platform_string() == 'windows' or not sys.stdout.isatty(): if platform_string() == 'windows' or not sys.stdout.isatty():
if explanatory_text: if explanatory_text:
print explanatory_text print(explanatory_text)
print '%s: %s' % (tag, msg) print('%s: %s' % (tag, msg))
return return
sys.stdout.write('%s%s%s\x1b[%d;%dm%s\x1b[0m: %s%s' % ( sys.stdout.write('%s%s%s\x1b[%d;%dm%s\x1b[0m: %s%s' % (
_BEGINNING_OF_LINE, _BEGINNING_OF_LINE,
@ -368,7 +370,7 @@ class Jobset(object):
self._travis, self._travis,
self._add_env) self._add_env)
self._running.add(job) self._running.add(job)
if not self.resultset.has_key(job.GetSpec().shortname): if job.GetSpec().shortname not in self.resultset:
self.resultset[job.GetSpec().shortname] = [] self.resultset[job.GetSpec().shortname] = []
return True return True

@ -39,7 +39,7 @@ def create_docker_jobspec(name, dockerfile_dir, shell_command, environ={},
environ['RUN_COMMAND'] = shell_command environ['RUN_COMMAND'] = shell_command
docker_args=[] docker_args=[]
for k,v in environ.iteritems(): for k,v in environ.items():
docker_args += ['-e', '%s=%s' % (k, v)] docker_args += ['-e', '%s=%s' % (k, v)]
docker_env = {'DOCKERFILE_DIR': dockerfile_dir, docker_env = {'DOCKERFILE_DIR': dockerfile_dir,
'DOCKER_RUN_SCRIPT': 'tools/run_tests/dockerize/docker_run.sh', 'DOCKER_RUN_SCRIPT': 'tools/run_tests/dockerize/docker_run.sh',

@ -30,8 +30,10 @@
"""Manage TCP ports for unit tests; started by run_tests.py""" """Manage TCP ports for unit tests; started by run_tests.py"""
from __future__ import print_function
import argparse import argparse
import BaseHTTPServer from six.moves import BaseHTTPServer
import hashlib import hashlib
import os import os
import socket import socket
@ -46,7 +48,7 @@ _MY_VERSION = 9
if len(sys.argv) == 2 and sys.argv[1] == 'dump_version': if len(sys.argv) == 2 and sys.argv[1] == 'dump_version':
print _MY_VERSION print(_MY_VERSION)
sys.exit(0) sys.exit(0)
@ -62,7 +64,7 @@ if args.logfile is not None:
sys.stderr = open(args.logfile, 'w') sys.stderr = open(args.logfile, 'w')
sys.stdout = sys.stderr sys.stdout = sys.stderr
print 'port server running on port %d' % args.port print('port server running on port %d' % args.port)
pool = [] pool = []
in_use = {} in_use = {}
@ -152,7 +154,7 @@ class Handler(BaseHTTPServer.BaseHTTPRequestHandler):
self.send_header('Content-Type', 'text/plain') self.send_header('Content-Type', 'text/plain')
self.end_headers() self.end_headers()
now = time.time() now = time.time()
self.wfile.write(yaml.dump({'pool': pool, 'in_use': dict((k, now - v) for k, v in in_use.iteritems())})) self.wfile.write(yaml.dump({'pool': pool, 'in_use': dict((k, now - v) for k, v in in_use.items())}))
elif self.path == '/quitquitquit': elif self.path == '/quitquitquit':
self.send_response(200) self.send_response(200)
self.end_headers() self.end_headers()
@ -164,4 +166,4 @@ while keep_running:
httpd.handle_request() httpd.handle_request()
sys.stderr.flush() sys.stderr.flush()
print 'done' print('done')

@ -29,6 +29,8 @@
"""Generate XML and HTML test reports.""" """Generate XML and HTML test reports."""
from __future__ import print_function
try: try:
from mako.runtime import Context from mako.runtime import Context
from mako.template import Template from mako.template import Template
@ -60,7 +62,7 @@ def render_junit_xml_report(resultset, xml_report):
root = ET.Element('testsuites') root = ET.Element('testsuites')
testsuite = ET.SubElement(root, 'testsuite', id='1', package='grpc', testsuite = ET.SubElement(root, 'testsuite', id='1', package='grpc',
name='tests') name='tests')
for shortname, results in resultset.iteritems(): for shortname, results in resultset.items():
for result in results: for result in results:
xml_test = ET.SubElement(testsuite, 'testcase', name=shortname) xml_test = ET.SubElement(testsuite, 'testcase', name=shortname)
if result.elapsed_time: if result.elapsed_time:
@ -83,10 +85,10 @@ def render_interop_html_report(
try: try:
mytemplate = Template(filename=template_file, format_exceptions=True) mytemplate = Template(filename=template_file, format_exceptions=True)
except NameError: except NameError:
print 'Mako template is not installed. Skipping HTML report generation.' print('Mako template is not installed. Skipping HTML report generation.')
return return
except IOError as e: except IOError as e:
print 'Failed to find the template %s: %s' % (template_file, e) print('Failed to find the template %s: %s' % (template_file, e))
return return
sorted_test_cases = sorted(test_cases) sorted_test_cases = sorted(test_cases)

@ -30,6 +30,8 @@
"""Run interop (cross-language) tests in parallel.""" """Run interop (cross-language) tests in parallel."""
from __future__ import print_function
import argparse import argparse
import atexit import atexit
import dockerjob import dockerjob
@ -372,7 +374,7 @@ def docker_run_cmdline(cmdline, image, docker_args=[], cwd=None, environ=None):
# turn environ into -e docker args # turn environ into -e docker args
if environ: if environ:
for k,v in environ.iteritems(): for k,v in environ.items():
docker_cmdline += ['-e', '%s=%s' % (k,v)] docker_cmdline += ['-e', '%s=%s' % (k,v)]
# set working directory # set working directory
@ -674,15 +676,15 @@ servers = set(s for s in itertools.chain.from_iterable(_SERVERS
if args.use_docker: if args.use_docker:
if not args.travis: if not args.travis:
print 'Seen --use_docker flag, will run interop tests under docker.' print('Seen --use_docker flag, will run interop tests under docker.')
print print('')
print 'IMPORTANT: The changes you are testing need to be locally committed' print('IMPORTANT: The changes you are testing need to be locally committed')
print 'because only the committed changes in the current branch will be' print('because only the committed changes in the current branch will be')
print 'copied to the docker environment.' print('copied to the docker environment.')
time.sleep(5) time.sleep(5)
if not args.use_docker and servers: if not args.use_docker and servers:
print 'Running interop servers is only supported with --use_docker option enabled.' print('Running interop servers is only supported with --use_docker option enabled.')
sys.exit(1) sys.exit(1)
languages = set(_LANGUAGES[l] languages = set(_LANGUAGES[l]
@ -768,7 +770,7 @@ try:
(server_host, server_port) = server[1].split(':') (server_host, server_port) = server[1].split(':')
server_addresses[server_name] = (server_host, server_port) server_addresses[server_name] = (server_host, server_port)
for server_name, server_address in server_addresses.iteritems(): for server_name, server_address in server_addresses.items():
(server_host, server_port) = server_address (server_host, server_port) = server_address
server_language = _LANGUAGES.get(server_name, None) server_language = _LANGUAGES.get(server_name, None)
skip_server = [] # test cases unimplemented by server skip_server = [] # test cases unimplemented by server
@ -800,7 +802,7 @@ try:
jobs.append(test_job) jobs.append(test_job)
if not jobs: if not jobs:
print 'No jobs to run.' print('No jobs to run.')
for image in docker_images.itervalues(): for image in docker_images.itervalues():
dockerjob.remove_image(image, skip_nonexistent=True) dockerjob.remove_image(image, skip_nonexistent=True)
sys.exit(1) sys.exit(1)
@ -814,7 +816,7 @@ try:
report_utils.render_junit_xml_report(resultset, 'report.xml') report_utils.render_junit_xml_report(resultset, 'report.xml')
for name, job in resultset.iteritems(): for name, job in resultset.items():
if "http2" in name: if "http2" in name:
job[0].http2results = aggregate_http2_results(job[0].message) job[0].http2results = aggregate_http2_results(job[0].message)
@ -826,12 +828,12 @@ try:
finally: finally:
# Check if servers are still running. # Check if servers are still running.
for server, job in server_jobs.iteritems(): for server, job in server_jobs.items():
if not job.is_running(): if not job.is_running():
print 'Server "%s" has exited prematurely.' % server print('Server "%s" has exited prematurely.' % server)
dockerjob.finish_jobs([j for j in server_jobs.itervalues()]) dockerjob.finish_jobs([j for j in server_jobs.itervalues()])
for image in docker_images.itervalues(): for image in docker_images.itervalues():
print 'Removing docker image %s' % image print('Removing docker image %s' % image)
dockerjob.remove_image(image) dockerjob.remove_image(image)

@ -30,6 +30,8 @@
"""Run performance tests locally or remotely.""" """Run performance tests locally or remotely."""
from __future__ import print_function
import argparse import argparse
import itertools import itertools
import jobset import jobset
@ -310,7 +312,7 @@ def create_scenarios(languages, workers_by_lang, remote_host=None, regex='.*',
'in the same scenario') 'in the same scenario')
if custom_server_lang: if custom_server_lang:
if not workers_by_lang.get(custom_server_lang, []): if not workers_by_lang.get(custom_server_lang, []):
print 'Warning: Skipping scenario %s as' % scenario_json['name'] print('Warning: Skipping scenario %s as' % scenario_json['name'])
print('SERVER_LANGUAGE is set to %s yet the language has ' print('SERVER_LANGUAGE is set to %s yet the language has '
'not been selected with -l' % custom_server_lang) 'not been selected with -l' % custom_server_lang)
continue continue
@ -319,7 +321,7 @@ def create_scenarios(languages, workers_by_lang, remote_host=None, regex='.*',
workers[idx] = workers_by_lang[custom_server_lang][idx] workers[idx] = workers_by_lang[custom_server_lang][idx]
if custom_client_lang: if custom_client_lang:
if not workers_by_lang.get(custom_client_lang, []): if not workers_by_lang.get(custom_client_lang, []):
print 'Warning: Skipping scenario %s as' % scenario_json['name'] print('Warning: Skipping scenario %s as' % scenario_json['name'])
print('CLIENT_LANGUAGE is set to %s yet the language has ' print('CLIENT_LANGUAGE is set to %s yet the language has '
'not been selected with -l' % custom_client_lang) 'not been selected with -l' % custom_client_lang)
continue continue
@ -344,14 +346,14 @@ def finish_qps_workers(jobs):
while any(job.is_running() for job in jobs): while any(job.is_running() for job in jobs):
for job in qpsworker_jobs: for job in qpsworker_jobs:
if job.is_running(): if job.is_running():
print 'QPS worker "%s" is still running.' % job.host_and_port print('QPS worker "%s" is still running.' % job.host_and_port)
if retries > 10: if retries > 10:
print 'Killing all QPS workers.' print('Killing all QPS workers.')
for job in jobs: for job in jobs:
job.kill() job.kill()
retries += 1 retries += 1
time.sleep(3) time.sleep(3)
print 'All QPS workers finished.' print('All QPS workers finished.')
argp = argparse.ArgumentParser(description='Run performance tests.') argp = argparse.ArgumentParser(description='Run performance tests.')

@ -29,6 +29,8 @@
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
"""Run stress test in C++""" """Run stress test in C++"""
from __future__ import print_function
import argparse import argparse
import atexit import atexit
import dockerjob import dockerjob
@ -93,7 +95,7 @@ def docker_run_cmdline(cmdline, image, docker_args=[], cwd=None, environ=None):
# turn environ into -e docker args # turn environ into -e docker args
if environ: if environ:
for k, v in environ.iteritems(): for k, v in environ.items():
docker_cmdline += ['-e', '%s=%s' % (k, v)] docker_cmdline += ['-e', '%s=%s' % (k, v)]
# set working directory # set working directory
@ -140,7 +142,7 @@ def cloud_to_cloud_jobspec(language,
'--num_channels_per_server=%s' % num_channels_per_server, '--num_channels_per_server=%s' % num_channels_per_server,
'--metrics_port=%s' % metrics_port '--metrics_port=%s' % metrics_port
])) ]))
print cmdline print(cmdline)
cwd = language.client_cwd cwd = language.client_cwd
environ = language.global_env() environ = language.global_env()
if docker_image: if docker_image:
@ -287,7 +289,7 @@ try:
(server_host, server_port) = server[1].split(':') (server_host, server_port) = server[1].split(':')
server_addresses[server_name] = (server_host, server_port) server_addresses[server_name] = (server_host, server_port)
for server_name, server_address in server_addresses.iteritems(): for server_name, server_address in server_addresses.items():
(server_host, server_port) = server_address (server_host, server_port) = server_address
for language in languages: for language in languages:
test_job = cloud_to_cloud_jobspec( test_job = cloud_to_cloud_jobspec(
@ -302,7 +304,7 @@ try:
jobs.append(test_job) jobs.append(test_job)
if not jobs: if not jobs:
print 'No jobs to run.' print('No jobs to run.')
for image in docker_images.itervalues(): for image in docker_images.itervalues():
dockerjob.remove_image(image, skip_nonexistent=True) dockerjob.remove_image(image, skip_nonexistent=True)
sys.exit(1) sys.exit(1)
@ -317,12 +319,12 @@ try:
finally: finally:
# Check if servers are still running. # Check if servers are still running.
for server, job in server_jobs.iteritems(): for server, job in server_jobs.items():
if not job.is_running(): if not job.is_running():
print 'Server "%s" has exited prematurely.' % server print('Server "%s" has exited prematurely.' % server)
dockerjob.finish_jobs([j for j in server_jobs.itervalues()]) dockerjob.finish_jobs([j for j in server_jobs.itervalues()])
for image in docker_images.itervalues(): for image in docker_images.itervalues():
print 'Removing docker image %s' % image print('Removing docker image %s' % image)
dockerjob.remove_image(image) dockerjob.remove_image(image)

@ -30,6 +30,8 @@
"""Run tests in parallel.""" """Run tests in parallel."""
from __future__ import print_function
import argparse import argparse
import ast import ast
import collections import collections
@ -48,7 +50,7 @@ import sys
import tempfile import tempfile
import traceback import traceback
import time import time
import urllib2 from six.moves import urllib
import uuid import uuid
import jobset import jobset
@ -93,7 +95,7 @@ class Config(object):
would like to run would like to run
""" """
actual_environ = self.environ.copy() actual_environ = self.environ.copy()
for k, v in environ.iteritems(): for k, v in environ.items():
actual_environ[k] = v actual_environ[k] = v
return jobset.JobSpec(cmdline=self.tool_prefix + cmdline, return jobset.JobSpec(cmdline=self.tool_prefix + cmdline,
shortname=shortname, shortname=shortname,
@ -202,7 +204,7 @@ class CLanguage(object):
flaky=target.get('flaky', False), flaky=target.get('flaky', False),
environ=env)) environ=env))
elif self.args.regex == '.*' or self.platform == 'windows': elif self.args.regex == '.*' or self.platform == 'windows':
print '\nWARNING: binary not found, skipping', binary print('\nWARNING: binary not found, skipping', binary)
return sorted(out) return sorted(out)
def make_targets(self): def make_targets(self):
@ -393,7 +395,7 @@ class PythonLanguage(object):
return [self.config.job_spec( return [self.config.job_spec(
config.run, config.run,
timeout_seconds=5*60, timeout_seconds=5*60,
environ=dict(environment.items() + environ=dict(list(environment.items()) +
[('GRPC_PYTHON_TESTRUNNER_FILTER', suite_name)]), [('GRPC_PYTHON_TESTRUNNER_FILTER', suite_name)]),
shortname='%s.test.%s' % (config.name, suite_name),) shortname='%s.test.%s' % (config.name, suite_name),)
for suite_name in tests_json for suite_name in tests_json
@ -764,7 +766,7 @@ def _windows_arch_option(arch):
elif arch == 'x64': elif arch == 'x64':
return '/p:Platform=x64' return '/p:Platform=x64'
else: else:
print 'Architecture %s not supported.' % arch print('Architecture %s not supported.' % arch)
sys.exit(1) sys.exit(1)
@ -782,11 +784,11 @@ def _check_arch_option(arch):
elif runtime_arch == '32bit' and arch == 'x86': elif runtime_arch == '32bit' and arch == 'x86':
return return
else: else:
print 'Architecture %s does not match current runtime architecture.' % arch print('Architecture %s does not match current runtime architecture.' % arch)
sys.exit(1) sys.exit(1)
else: else:
if args.arch != 'default': if args.arch != 'default':
print 'Architecture %s not supported on current platform.' % args.arch print('Architecture %s not supported on current platform.' % args.arch)
sys.exit(1) sys.exit(1)
@ -800,7 +802,7 @@ def _windows_build_bat(compiler):
elif compiler == 'vs2010': elif compiler == 'vs2010':
return 'vsprojects\\build_vs2010.bat' return 'vsprojects\\build_vs2010.bat'
else: else:
print 'Compiler %s not supported.' % compiler print('Compiler %s not supported.' % compiler)
sys.exit(1) sys.exit(1)
@ -814,7 +816,7 @@ def _windows_toolset_option(compiler):
elif compiler == 'vs2010': elif compiler == 'vs2010':
return '/p:PlatformToolset=v100' return '/p:PlatformToolset=v100'
else: else:
print 'Compiler %s not supported.' % compiler print('Compiler %s not supported.' % compiler)
sys.exit(1) sys.exit(1)
@ -825,7 +827,7 @@ def _docker_arch_suffix(arch):
elif arch == 'x86': elif arch == 'x86':
return 'x86' return 'x86'
else: else:
print 'Architecture %s not supported with current settings.' % arch print('Architecture %s not supported with current settings.' % arch)
sys.exit(1) sys.exit(1)
@ -941,7 +943,7 @@ for spec in args.update_submodules:
branch = spec[1] branch = spec[1]
cwd = 'third_party/%s' % submodule cwd = 'third_party/%s' % submodule
def git(cmd, cwd=cwd): def git(cmd, cwd=cwd):
print 'in %s: git %s' % (cwd, cmd) print('in %s: git %s' % (cwd, cmd))
subprocess.check_call('git %s' % cmd, cwd=cwd, shell=True) subprocess.check_call('git %s' % cmd, cwd=cwd, shell=True)
git('fetch') git('fetch')
git('checkout %s' % branch) git('checkout %s' % branch)
@ -952,8 +954,8 @@ if need_to_regenerate_projects:
if jobset.platform_string() == 'linux': if jobset.platform_string() == 'linux':
subprocess.check_call('tools/buildgen/generate_projects.sh', shell=True) subprocess.check_call('tools/buildgen/generate_projects.sh', shell=True)
else: else:
print 'WARNING: may need to regenerate projects, but since we are not on' print('WARNING: may need to regenerate projects, but since we are not on')
print ' Linux this step is being skipped. Compilation MAY fail.' print(' Linux this step is being skipped. Compilation MAY fail.')
# grab config # grab config
@ -980,18 +982,18 @@ for l in languages:
language_make_options=[] language_make_options=[]
if any(language.make_options() for language in languages): if any(language.make_options() for language in languages):
if not 'gcov' in args.config and len(languages) != 1: if not 'gcov' in args.config and len(languages) != 1:
print 'languages with custom make options cannot be built simultaneously with other languages' print('languages with custom make options cannot be built simultaneously with other languages')
sys.exit(1) sys.exit(1)
else: else:
language_make_options = next(iter(languages)).make_options() language_make_options = next(iter(languages)).make_options()
if args.use_docker: if args.use_docker:
if not args.travis: if not args.travis:
print 'Seen --use_docker flag, will run tests under docker.' print('Seen --use_docker flag, will run tests under docker.')
print print('')
print 'IMPORTANT: The changes you are testing need to be locally committed' print('IMPORTANT: The changes you are testing need to be locally committed')
print 'because only the committed changes in the current branch will be' print('because only the committed changes in the current branch will be')
print 'copied to the docker environment.' print('copied to the docker environment.')
time.sleep(5) time.sleep(5)
dockerfile_dirs = set([l.dockerfile_dir() for l in languages]) dockerfile_dirs = set([l.dockerfile_dir() for l in languages])
@ -1075,7 +1077,7 @@ build_steps = list(set(
for l in languages for l in languages
for cmdline in l.pre_build_steps())) for cmdline in l.pre_build_steps()))
if make_targets: if make_targets:
make_commands = itertools.chain.from_iterable(make_jobspec(build_config, list(targets), makefile) for (makefile, targets) in make_targets.iteritems()) make_commands = itertools.chain.from_iterable(make_jobspec(build_config, list(targets), makefile) for (makefile, targets) in make_targets.items())
build_steps.extend(set(make_commands)) build_steps.extend(set(make_commands))
build_steps.extend(set( build_steps.extend(set(
jobset.JobSpec(cmdline, environ=build_step_environ(build_config), timeout_seconds=None) jobset.JobSpec(cmdline, environ=build_step_environ(build_config), timeout_seconds=None)
@ -1092,13 +1094,13 @@ forever = args.forever
def _shut_down_legacy_server(legacy_server_port): def _shut_down_legacy_server(legacy_server_port):
try: try:
version = int(urllib2.urlopen( version = int(urllib.request.urlopen(
'http://localhost:%d/version_number' % legacy_server_port, 'http://localhost:%d/version_number' % legacy_server_port,
timeout=10).read()) timeout=10).read())
except: except:
pass pass
else: else:
urllib2.urlopen( urllib.request.urlopen(
'http://localhost:%d/quitquitquit' % legacy_server_port).read() 'http://localhost:%d/quitquitquit' % legacy_server_port).read()
@ -1120,29 +1122,29 @@ def _start_port_server(port_server_port):
# if not running ==> start a new one # if not running ==> start a new one
# otherwise, leave it up # otherwise, leave it up
try: try:
version = int(urllib2.urlopen( version = int(urllib.request.urlopen(
'http://localhost:%d/version_number' % port_server_port, 'http://localhost:%d/version_number' % port_server_port,
timeout=10).read()) timeout=10).read())
print 'detected port server running version %d' % version print('detected port server running version %d' % version)
running = True running = True
except Exception as e: except Exception as e:
print 'failed to detect port server: %s' % sys.exc_info()[0] print('failed to detect port server: %s' % sys.exc_info()[0])
print e.strerror print(e.strerror)
running = False running = False
if running: if running:
current_version = int(subprocess.check_output( current_version = int(subprocess.check_output(
[sys.executable, os.path.abspath('tools/run_tests/port_server.py'), [sys.executable, os.path.abspath('tools/run_tests/port_server.py'),
'dump_version'])) 'dump_version']))
print 'my port server is version %d' % current_version print('my port server is version %d' % current_version)
running = (version >= current_version) running = (version >= current_version)
if not running: if not running:
print 'port_server version mismatch: killing the old one' print('port_server version mismatch: killing the old one')
urllib2.urlopen('http://localhost:%d/quitquitquit' % port_server_port).read() urllib.request.urlopen('http://localhost:%d/quitquitquit' % port_server_port).read()
time.sleep(1) time.sleep(1)
if not running: if not running:
fd, logfile = tempfile.mkstemp() fd, logfile = tempfile.mkstemp()
os.close(fd) os.close(fd)
print 'starting port_server, with log file %s' % logfile print('starting port_server, with log file %s' % logfile)
args = [sys.executable, os.path.abspath('tools/run_tests/port_server.py'), args = [sys.executable, os.path.abspath('tools/run_tests/port_server.py'),
'-p', '%d' % port_server_port, '-l', logfile] '-p', '%d' % port_server_port, '-l', logfile]
env = dict(os.environ) env = dict(os.environ)
@ -1168,34 +1170,34 @@ def _start_port_server(port_server_port):
waits = 0 waits = 0
while True: while True:
if waits > 10: if waits > 10:
print 'killing port server due to excessive start up waits' print('killing port server due to excessive start up waits')
port_server.kill() port_server.kill()
if port_server.poll() is not None: if port_server.poll() is not None:
print 'port_server failed to start' print('port_server failed to start')
# try one final time: maybe another build managed to start one # try one final time: maybe another build managed to start one
time.sleep(1) time.sleep(1)
try: try:
urllib2.urlopen('http://localhost:%d/get' % port_server_port, urllib.request.urlopen('http://localhost:%d/get' % port_server_port,
timeout=1).read() timeout=1).read()
print 'last ditch attempt to contact port server succeeded' print('last ditch attempt to contact port server succeeded')
break break
except: except:
traceback.print_exc() traceback.print_exc()
port_log = open(logfile, 'r').read() port_log = open(logfile, 'r').read()
print port_log print(port_log)
sys.exit(1) sys.exit(1)
try: try:
urllib2.urlopen('http://localhost:%d/get' % port_server_port, urllib.request.urlopen('http://localhost:%d/get' % port_server_port,
timeout=1).read() timeout=1).read()
print 'port server is up and ready' print('port server is up and ready')
break break
except socket.timeout: except socket.timeout:
print 'waiting for port_server: timeout' print('waiting for port_server: timeout')
traceback.print_exc(); traceback.print_exc();
time.sleep(1) time.sleep(1)
waits += 1 waits += 1
except urllib2.URLError: except urllib.error.URLError:
print 'waiting for port_server: urlerror' print('waiting for port_server: urlerror')
traceback.print_exc(); traceback.print_exc();
time.sleep(1) time.sleep(1)
waits += 1 waits += 1

@ -30,6 +30,8 @@
"""Runs selected gRPC test/build tasks.""" """Runs selected gRPC test/build tasks."""
from __future__ import print_function
import argparse import argparse
import atexit import atexit
import jobset import jobset
@ -111,7 +113,7 @@ build_jobs = []
for target in targets: for target in targets:
build_jobs.append(target.build_jobspec()) build_jobs.append(target.build_jobspec())
if not build_jobs: if not build_jobs:
print 'Nothing to build.' print('Nothing to build.')
sys.exit(1) sys.exit(1)
jobset.message('START', 'Building targets.', do_newline=True) jobset.message('START', 'Building targets.', do_newline=True)

Loading…
Cancel
Save