aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools
diff options
context:
space:
mode:
Diffstat (limited to 'tools')
-rw-r--r--tools/README.md1
-rwxr-xr-xtools/buildgen/generate_projects.sh2
-rw-r--r--tools/distpackages/.gitignore1
-rwxr-xr-xtools/distpackages/build_deb_packages.sh116
-rw-r--r--tools/distpackages/templates/libgrpc-dev/DEBIAN/control10
-rw-r--r--tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/changelog.gzbin0 -> 136 bytes
-rw-r--r--tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/copyright34
-rw-r--r--tools/distpackages/templates/libgrpc/DEBIAN/control10
-rw-r--r--tools/distpackages/templates/libgrpc/DEBIAN/postinst7
-rw-r--r--tools/distpackages/templates/libgrpc/DEBIAN/postrm7
-rw-r--r--tools/distpackages/templates/libgrpc/DEBIAN/shlibs3
-rw-r--r--tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/changelog.gzbin0 -> 132 bytes
-rw-r--r--tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/copyright34
-rw-r--r--tools/dockerfile/grpc_build_deb/Dockerfile13
-rw-r--r--tools/dockerfile/grpc_node/Dockerfile7
-rw-r--r--tools/dockerfile/grpc_node_base/Dockerfile2
-rw-r--r--tools/dockerfile/grpc_php/Dockerfile3
-rw-r--r--tools/dockerfile/grpc_php_base/Dockerfile3
-rw-r--r--tools/dockerfile/grpc_python/Dockerfile17
-rw-r--r--tools/dockerfile/grpc_ruby/Dockerfile7
-rw-r--r--tools/dockerfile/grpc_ruby_base/Dockerfile5
-rw-r--r--tools/dockerfile/grpc_ruby_deb/Dockerfile31
-rw-r--r--tools/dockerfile/grpc_ruby_deb/README.md5
-rwxr-xr-xtools/run_tests/run_python.sh2
-rw-r--r--tools/run_tests/tests.json12
25 files changed, 312 insertions, 20 deletions
diff --git a/tools/README.md b/tools/README.md
index 7cee610e35..1dbbad886f 100644
--- a/tools/README.md
+++ b/tools/README.md
@@ -1,4 +1,5 @@
buildgen: contains the template renderer for our build system.
+distpackages: contains script to generate debian packages.
dockerfile: contains all of the docker files to test gRPC.
gce_setup: contains boilerplate for running the docker files under GCE.
run_tests: contains python scripts to properly run the tests in parallel.
diff --git a/tools/buildgen/generate_projects.sh b/tools/buildgen/generate_projects.sh
index d37288a078..7a12440db2 100755
--- a/tools/buildgen/generate_projects.sh
+++ b/tools/buildgen/generate_projects.sh
@@ -40,6 +40,8 @@ cd `dirname $0`/../..
mako_renderer=tools/buildgen/mako_renderer.py
gen_build_json=test/core/end2end/gen_build_json.py
+tools/buildgen/build-cleaner.py build.json
+
end2end_test_build=`mktemp /tmp/genXXXXXX`
$gen_build_json > $end2end_test_build
diff --git a/tools/distpackages/.gitignore b/tools/distpackages/.gitignore
new file mode 100644
index 0000000000..7a7d3f3fa9
--- /dev/null
+++ b/tools/distpackages/.gitignore
@@ -0,0 +1 @@
+deb_out
diff --git a/tools/distpackages/build_deb_packages.sh b/tools/distpackages/build_deb_packages.sh
new file mode 100755
index 0000000000..a5f945bd9a
--- /dev/null
+++ b/tools/distpackages/build_deb_packages.sh
@@ -0,0 +1,116 @@
+#!/bin/bash
+
+# Copyright 2015, Google Inc.
+# All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are
+# met:
+#
+# * Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above
+# copyright notice, this list of conditions and the following disclaimer
+# in the documentation and/or other materials provided with the
+# distribution.
+# * Neither the name of Google Inc. nor the names of its
+# contributors may be used to endorse or promote products derived from
+# this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+# Where to put resulting .deb packages.
+deb_dest="deb_out"
+mkdir -p $deb_dest
+
+version='0.8.0.0'
+
+if [ -f /.dockerinit ]; then
+ # We're in Docker where uname -p returns "unknown".
+ arch=x86_64
+else
+ arch=`uname -p`
+fi
+
+if [ $arch != "x86_64" ]
+then
+ echo Unsupported architecture.
+ exit 1
+fi
+
+# Build debian packages
+for pkg_name in libgrpc libgrpc-dev
+do
+ echo
+ echo "Building package $pkg_name"
+ tmp_dir=`mktemp -d`
+ echo "Using tmp dir $tmp_dir to build the package"
+
+ cp -a templates/$pkg_name $tmp_dir
+
+ arch_lib_dir=$tmp_dir/$pkg_name/usr/lib/$arch-linux-gnu
+
+ if [ $pkg_name == "libgrpc" ]
+ then
+ # Copy shared libraries
+ (cd ../..; make install-shared_c prefix=$tmp_dir/$pkg_name/usr/lib)
+ mv $tmp_dir/$pkg_name/usr/lib/lib $arch_lib_dir
+
+ # non-dev package should contain so.0 symlinks
+ for symlink in $arch_lib_dir/*.so
+ do
+ mv $symlink $symlink.0
+ done
+ fi
+
+ if [ $pkg_name == "libgrpc-dev" ]
+ then
+ # Copy headers and static libraries
+ (cd ../..; make install-headers_c install-static_c prefix=$tmp_dir/$pkg_name/usr/lib)
+ mv $tmp_dir/$pkg_name/usr/lib/include $tmp_dir/$pkg_name/usr/include
+ mv $tmp_dir/$pkg_name/usr/lib/lib $arch_lib_dir
+
+ # create symlinks to shared libraries
+ for libname in $arch_lib_dir/*.a
+ do
+ base=`basename $libname .a`
+ ln -s $base.so.$version $arch_lib_dir/$base.so
+ done
+ fi
+
+ # Adjust mode for some files in the package
+ find $tmp_dir/$pkg_name -type d | xargs chmod 755
+ find $tmp_dir/$pkg_name -type d | xargs chmod a-s
+ find $tmp_dir/$pkg_name -type f | xargs chmod 644
+ chmod 755 $tmp_dir/$pkg_name/DEBIAN/{postinst,postrm}
+
+ # Build the debian package
+ fakeroot dpkg-deb --build $tmp_dir/$pkg_name || { echo "dpkg-deb failed"; exit 1; }
+
+ deb_path=$deb_dest/${pkg_name}_amd64.deb
+
+ # Copy the .deb file to destination dir
+ cp $tmp_dir/$pkg_name.deb $deb_path
+
+ echo "Resulting package: $deb_path"
+ echo "Package info:"
+ dpkg-deb -I $deb_path
+ echo "Package contents:"
+ dpkg-deb -c $deb_path
+ echo "Problems reported by lintian:"
+ lintian $deb_path
+
+ echo
+done
+
+
diff --git a/tools/distpackages/templates/libgrpc-dev/DEBIAN/control b/tools/distpackages/templates/libgrpc-dev/DEBIAN/control
new file mode 100644
index 0000000000..64dc79af19
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc-dev/DEBIAN/control
@@ -0,0 +1,10 @@
+Package: libgrpc-dev
+Version: 0.8.0
+Architecture: amd64
+Maintainer: Jan Tattermusch <jtattermusch@google.com>
+Depends: libgrpc, libc6-dev | libc-dev
+Section: libdevel
+Priority: optional
+Homepage: https://github.com/grpc/grpc
+Description: gRPC C Core - header files
+ Core C libraries for gRPC - An RPC library and framework.
diff --git a/tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/changelog.gz b/tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/changelog.gz
new file mode 100644
index 0000000000..eabdf46e6e
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/changelog.gz
Binary files differ
diff --git a/tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/copyright b/tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/copyright
new file mode 100644
index 0000000000..83fb6f4577
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc-dev/usr/share/doc/libgrpc-dev/copyright
@@ -0,0 +1,34 @@
+Copyright:
+
+ Copyright (C) 2015 Google Inc.
+
+License (new style BSD, with Google Inc. as copyright holder):
+
+ Copyright 2015, Google Inc.
+ All rights reserved.
+
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions are
+ met:
+
+ * Redistributions of source code must retain the above copyright
+ notice, this list of conditions and the following disclaimer.
+ * Redistributions in binary form must reproduce the above
+ copyright notice, this list of conditions and the following disclaimer
+ in the documentation and/or other materials provided with the
+ distribution.
+ * Neither the name of Google Inc. nor the names of its
+ contributors may be used to endorse or promote products derived from
+ this software without specific prior written permission.
+
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. \ No newline at end of file
diff --git a/tools/distpackages/templates/libgrpc/DEBIAN/control b/tools/distpackages/templates/libgrpc/DEBIAN/control
new file mode 100644
index 0000000000..75c224e9a4
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc/DEBIAN/control
@@ -0,0 +1,10 @@
+Package: libgrpc
+Version: 0.8.0
+Architecture: amd64
+Maintainer: Jan Tattermusch <jtattermusch@google.com>
+Depends: libc6
+Section: libs
+Priority: optional
+Homepage: https://github.com/grpc/grpc
+Description: gRPC C Core
+ Core C libraries for gRPC - An RPC library and framework.
diff --git a/tools/distpackages/templates/libgrpc/DEBIAN/postinst b/tools/distpackages/templates/libgrpc/DEBIAN/postinst
new file mode 100644
index 0000000000..379f1fae0c
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc/DEBIAN/postinst
@@ -0,0 +1,7 @@
+#!/bin/sh
+set -e
+# Automatically added by dh_makeshlibs
+if [ "$1" = "configure" ]; then
+ ldconfig
+fi
+# End automatically added section
diff --git a/tools/distpackages/templates/libgrpc/DEBIAN/postrm b/tools/distpackages/templates/libgrpc/DEBIAN/postrm
new file mode 100644
index 0000000000..3e73d38a7e
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc/DEBIAN/postrm
@@ -0,0 +1,7 @@
+#!/bin/sh
+set -e
+# Automatically added by dh_makeshlibs
+if [ "$1" = "remove" ]; then
+ ldconfig
+fi
+# End automatically added section
diff --git a/tools/distpackages/templates/libgrpc/DEBIAN/shlibs b/tools/distpackages/templates/libgrpc/DEBIAN/shlibs
new file mode 100644
index 0000000000..31d0e0a3b3
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc/DEBIAN/shlibs
@@ -0,0 +1,3 @@
+libgpr 0
+libgrpc 0
+libgrpc_unsecure 0
diff --git a/tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/changelog.gz b/tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/changelog.gz
new file mode 100644
index 0000000000..c07b4d2637
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/changelog.gz
Binary files differ
diff --git a/tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/copyright b/tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/copyright
new file mode 100644
index 0000000000..83fb6f4577
--- /dev/null
+++ b/tools/distpackages/templates/libgrpc/usr/share/doc/libgrpc/copyright
@@ -0,0 +1,34 @@
+Copyright:
+
+ Copyright (C) 2015 Google Inc.
+
+License (new style BSD, with Google Inc. as copyright holder):
+
+ Copyright 2015, Google Inc.
+ All rights reserved.
+
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions are
+ met:
+
+ * Redistributions of source code must retain the above copyright
+ notice, this list of conditions and the following disclaimer.
+ * Redistributions in binary form must reproduce the above
+ copyright notice, this list of conditions and the following disclaimer
+ in the documentation and/or other materials provided with the
+ distribution.
+ * Neither the name of Google Inc. nor the names of its
+ contributors may be used to endorse or promote products derived from
+ this software without specific prior written permission.
+
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. \ No newline at end of file
diff --git a/tools/dockerfile/grpc_build_deb/Dockerfile b/tools/dockerfile/grpc_build_deb/Dockerfile
new file mode 100644
index 0000000000..ad26fb35d0
--- /dev/null
+++ b/tools/dockerfile/grpc_build_deb/Dockerfile
@@ -0,0 +1,13 @@
+# Dockerfile to build Debian packages for gRPC C core.
+FROM grpc/base
+
+# Install dependencies
+RUN apt-get update && apt-get install -y lintian
+
+# Get the source from GitHub
+RUN git clone git@github.com:grpc/grpc.git /var/local/git/grpc
+RUN cd /var/local/git/grpc && \
+ git pull --recurse-submodules && \
+ git submodule update --init --recursive
+
+RUN /bin/bash -l -c 'cd /var/local/git/grpc/tools/distpackages && ./build_deb_packages.sh'
diff --git a/tools/dockerfile/grpc_node/Dockerfile b/tools/dockerfile/grpc_node/Dockerfile
index 59aa8cfd1c..08d060a8de 100644
--- a/tools/dockerfile/grpc_node/Dockerfile
+++ b/tools/dockerfile/grpc_node/Dockerfile
@@ -1,13 +1,16 @@
# Dockerfile for gRPC Node
FROM grpc/node_base
-# Update the C libary
+# Pull the latest sources
RUN cd /var/local/git/grpc \
&& git pull --recurse-submodules \
&& git submodule update --init --recursive
+# Prevent breaking the build if header files are added/removed.
+RUN make clean -C /var/local/git/grpc
+
# Install the C core.
-RUN make install_c -C /var/local/git/grpc
+RUN make install_c -j12 -C /var/local/git/grpc
RUN cd /var/local/git/grpc/src/node && npm install && node-gyp rebuild
diff --git a/tools/dockerfile/grpc_node_base/Dockerfile b/tools/dockerfile/grpc_node_base/Dockerfile
index 20efde98ad..e14e03143f 100644
--- a/tools/dockerfile/grpc_node_base/Dockerfile
+++ b/tools/dockerfile/grpc_node_base/Dockerfile
@@ -15,6 +15,8 @@ RUN cd /var/local/git/grpc && \
git pull --recurse-submodules && \
git submodule update --init --recursive
+# TODO: pre-building seems unnecessary, because we need to run make clean
+# anyway to prevent build from crashing if header files are added/removed.
# Build the C core
RUN make static_c shared_c -j12 -C /var/local/git/grpc
diff --git a/tools/dockerfile/grpc_php/Dockerfile b/tools/dockerfile/grpc_php/Dockerfile
index 177587669c..6719208ce7 100644
--- a/tools/dockerfile/grpc_php/Dockerfile
+++ b/tools/dockerfile/grpc_php/Dockerfile
@@ -5,6 +5,9 @@ RUN cd /var/local/git/grpc \
&& git pull --recurse-submodules \
&& git submodule update --init --recursive
+# Prevent breaking the build if header files are added/removed.
+RUN make clean -C /var/local/git/grpc
+
RUN make install_c -j12 -C /var/local/git/grpc
RUN cd /var/local/git/grpc/src/php/ext/grpc && git pull && phpize
diff --git a/tools/dockerfile/grpc_php_base/Dockerfile b/tools/dockerfile/grpc_php_base/Dockerfile
index f4bf3b09a4..3d995e7a89 100644
--- a/tools/dockerfile/grpc_php_base/Dockerfile
+++ b/tools/dockerfile/grpc_php_base/Dockerfile
@@ -84,6 +84,9 @@ RUN wget https://phar.phpunit.de/phpunit.phar \
&& chmod +x phpunit.phar \
&& mv phpunit.phar /usr/local/bin/phpunit
+
+# TODO: pre-building seems unnecessary, because we need to run make clean
+# anyway to prevent build from crashing if header files are added/removed.
# Build the C core
RUN make static_c shared_c -j12 -C /var/local/git/grpc
diff --git a/tools/dockerfile/grpc_python/Dockerfile b/tools/dockerfile/grpc_python/Dockerfile
index d434b47351..901375c6bf 100644
--- a/tools/dockerfile/grpc_python/Dockerfile
+++ b/tools/dockerfile/grpc_python/Dockerfile
@@ -1,13 +1,13 @@
# Dockerfile for GRPC Python
FROM grpc/python_base
-# Build the C library
+# Pull the latest sources
RUN cd /var/local/git/grpc \
&& git pull --recurse-submodules \
&& git submodule update --init --recursive
# Build the C core.
-RUN make install_c -C /var/local/git/grpc
+RUN make install_c -j12 -C /var/local/git/grpc
# Build Python GRPC
RUN cd /var/local/git/grpc \
@@ -24,12 +24,13 @@ RUN cd /var/local/git/grpc \
&& python2.7 -B -m grpc._adapter._links_test
&& python2.7 -B -m grpc._adapter._lonely_rear_link_test
&& python2.7 -B -m grpc._adapter._low_test
- && python2.7 -B -m grpc._framework.base.packets.implementations_test
- && python2.7 -B -m grpc._framework.face.blocking_invocation_inline_service_test
- && python2.7 -B -m grpc._framework.face.event_invocation_synchronous_event_service_test
- && python2.7 -B -m grpc._framework.face.future_invocation_asynchronous_event_service_test
- && python2.7 -B -m grpc._framework.foundation._later_test
- && python2.7 -B -m grpc._framework.foundation._logging_pool_test
+ && python2.7 -B -m grpc.framework.assembly.implementations_test
+ && python2.7 -B -m grpc.framework.base.packets.implementations_test
+ && python2.7 -B -m grpc.framework.face.blocking_invocation_inline_service_test
+ && python2.7 -B -m grpc.framework.face.event_invocation_synchronous_event_service_test
+ && python2.7 -B -m grpc.framework.face.future_invocation_asynchronous_event_service_test
+ && python2.7 -B -m grpc.framework.foundation._later_test
+ && python2.7 -B -m grpc.framework.foundation._logging_pool_test
# Add a cacerts directory containing the Google root pem file, allowing the interop client to access the production test instance
ADD cacerts cacerts
diff --git a/tools/dockerfile/grpc_ruby/Dockerfile b/tools/dockerfile/grpc_ruby/Dockerfile
index ff1b99ba37..fda55719d9 100644
--- a/tools/dockerfile/grpc_ruby/Dockerfile
+++ b/tools/dockerfile/grpc_ruby/Dockerfile
@@ -1,13 +1,16 @@
# Dockerfile for gRPC Ruby
FROM grpc/ruby_base
-# Build the C libary
+# Pull the latest sources
RUN cd /var/local/git/grpc \
&& git pull --recurse-submodules \
&& git submodule update --init --recursive
+# Prevent breaking the build if header files are added/removed.
+RUN make clean -C /var/local/git/grpc
+
# Build the C core
-RUN make install_c -C /var/local/git/grpc
+RUN make install_c -j12 -C /var/local/git/grpc
# Build ruby gRPC and run its tests
RUN /bin/bash -l -c 'cd /var/local/git/grpc/src/ruby && bundle && rake'
diff --git a/tools/dockerfile/grpc_ruby_base/Dockerfile b/tools/dockerfile/grpc_ruby_base/Dockerfile
index a3a80daf9b..0d872069d7 100644
--- a/tools/dockerfile/grpc_ruby_base/Dockerfile
+++ b/tools/dockerfile/grpc_ruby_base/Dockerfile
@@ -54,5 +54,10 @@ RUN cd /var/local/git/grpc/third_party/protobuf && \
./configure --prefix=/usr && \
make -j12 && make check && make install && make clean
+# TODO: pre-building seems unnecessary, because we need to run make clean
+# anyway to prevent build from crashing if header files are added/removed.
# Build the C core
RUN make static_c shared_c -j12 -C /var/local/git/grpc
+
+# Define the default command.
+CMD ["bash"]
diff --git a/tools/dockerfile/grpc_ruby_deb/Dockerfile b/tools/dockerfile/grpc_ruby_deb/Dockerfile
new file mode 100644
index 0000000000..25ea2c54bd
--- /dev/null
+++ b/tools/dockerfile/grpc_ruby_deb/Dockerfile
@@ -0,0 +1,31 @@
+# Dockerfile for gRPC Ruby, but using Debian packages for gRPC C core.
+FROM grpc/ruby_base
+
+# Pull the latest sources
+RUN cd /var/local/git/grpc \
+ && git pull --recurse-submodules \
+ && git submodule update --init --recursive
+
+# Make sure we don't rely on things that shouldn't be there.
+RUN make clean -C /var/local/git/grpc
+
+# Debian packages need to be supplied externally
+ADD libgrpc_amd64.deb libgrpc_amd64.deb
+ADD libgrpc-dev_amd64.deb libgrpc-dev_amd64.deb
+
+# Install the C core .deb packages
+RUN /bin/bash -l -c 'dpkg -i libgrpc_amd64.deb libgrpc-dev_amd64.deb'
+
+# Build ruby gRPC and run its tests
+RUN /bin/bash -l -c 'cd /var/local/git/grpc/src/ruby && bundle && rake'
+
+# Add a cacerts directory containing the Google root pem file, allowing the
+# ruby client to access the production test instance
+ADD cacerts cacerts
+
+# Add a service_account directory containing the auth creds file
+ADD service_account service_account
+
+# Specify the default command such that the interop server runs on its known
+# testing port
+CMD ["/bin/bash", "-l", "-c", "ruby /var/local/git/grpc/src/ruby/bin/interop/interop_server.rb --use_tls --port 8060"]
diff --git a/tools/dockerfile/grpc_ruby_deb/README.md b/tools/dockerfile/grpc_ruby_deb/README.md
new file mode 100644
index 0000000000..0a3716b938
--- /dev/null
+++ b/tools/dockerfile/grpc_ruby_deb/README.md
@@ -0,0 +1,5 @@
+GRPC RUBY Base Dockerfile (Debian package version)
+========================
+
+Dockerfile for creating the Ruby gRPC development Docker instance.
+Uses gRPC C core Debian packages instead of installing it using make.
diff --git a/tools/run_tests/run_python.sh b/tools/run_tests/run_python.sh
index f21f854b09..fe40b51186 100755
--- a/tools/run_tests/run_python.sh
+++ b/tools/run_tests/run_python.sh
@@ -37,6 +37,7 @@ root=`pwd`
export LD_LIBRARY_PATH=$root/libs/opt
source python2.7_virtual_environment/bin/activate
# TODO(issue 215): Properly itemize these in run_tests.py so that they can be parallelized.
+python2.7 -B test/compiler/python_plugin_test.py
python2.7 -B -m grpc._adapter._blocking_invocation_inline_service_test
python2.7 -B -m grpc._adapter._c_test
python2.7 -B -m grpc._adapter._event_invocation_synchronous_event_service_test
@@ -44,6 +45,7 @@ python2.7 -B -m grpc._adapter._future_invocation_asynchronous_event_service_test
python2.7 -B -m grpc._adapter._links_test
python2.7 -B -m grpc._adapter._lonely_rear_link_test
python2.7 -B -m grpc._adapter._low_test
+python2.7 -B -m grpc.framework.assembly.implementations_test
python2.7 -B -m grpc.framework.base.packets.implementations_test
python2.7 -B -m grpc.framework.face.blocking_invocation_inline_service_test
python2.7 -B -m grpc.framework.face.event_invocation_synchronous_event_service_test
diff --git a/tools/run_tests/tests.json b/tools/run_tests/tests.json
index d2b125fc01..84f830c456 100644
--- a/tools/run_tests/tests.json
+++ b/tools/run_tests/tests.json
@@ -191,14 +191,6 @@
},
{
"language": "c",
- "name": "httpcli_test"
- },
- {
- "language": "c",
- "name": "interop_test"
- },
- {
- "language": "c",
"name": "json_rewrite_test"
},
{
@@ -291,6 +283,10 @@
},
{
"language": "c++",
+ "name": "interop_test"
+ },
+ {
+ "language": "c++",
"name": "pubsub_publisher_test"
},
{