mirror of https://github.com/grpc/grpc.git
commit
c59eef024f
20 changed files with 326 additions and 30 deletions
@ -0,0 +1,45 @@ |
|||||||
|
%YAML 1.2 |
||||||
|
--- | |
||||||
|
# Copyright 2016, 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. |
||||||
|
|
||||||
|
FROM debian:jessie |
||||||
|
|
||||||
|
<%include file="../../apt_get_basic.include"/> |
||||||
|
<%include file="../../ccache_setup.include"/> |
||||||
|
<%include file="../../cxx_deps.include"/> |
||||||
|
<%include file="../../gcp_api_libraries.include"/> |
||||||
|
<%include file="../../python_deps.include"/> |
||||||
|
|
||||||
|
RUN pip install coverage |
||||||
|
RUN pip install oauth2client |
||||||
|
|
||||||
|
# Define the default command. |
||||||
|
CMD ["bash"] |
||||||
|
|
@ -0,0 +1,103 @@ |
|||||||
|
# Copyright 2016, 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. |
||||||
|
|
||||||
|
FROM debian:jessie |
||||||
|
|
||||||
|
# Install Git and basic packages. |
||||||
|
RUN apt-get update && apt-get install -y \ |
||||||
|
autoconf \ |
||||||
|
autotools-dev \ |
||||||
|
build-essential \ |
||||||
|
bzip2 \ |
||||||
|
ccache \ |
||||||
|
curl \ |
||||||
|
gcc \ |
||||||
|
gcc-multilib \ |
||||||
|
git \ |
||||||
|
golang \ |
||||||
|
gyp \ |
||||||
|
lcov \ |
||||||
|
libc6 \ |
||||||
|
libc6-dbg \ |
||||||
|
libc6-dev \ |
||||||
|
libgtest-dev \ |
||||||
|
libtool \ |
||||||
|
make \ |
||||||
|
perl \ |
||||||
|
strace \ |
||||||
|
python-dev \ |
||||||
|
python-setuptools \ |
||||||
|
python-yaml \ |
||||||
|
telnet \ |
||||||
|
unzip \ |
||||||
|
wget \ |
||||||
|
zip && apt-get clean |
||||||
|
|
||||||
|
#================ |
||||||
|
# Build profiling |
||||||
|
RUN apt-get update && apt-get install -y time && apt-get clean |
||||||
|
|
||||||
|
# Prepare ccache |
||||||
|
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/cc |
||||||
|
RUN ln -s /usr/bin/ccache /usr/local/bin/c++ |
||||||
|
RUN ln -s /usr/bin/ccache /usr/local/bin/clang |
||||||
|
RUN ln -s /usr/bin/ccache /usr/local/bin/clang++ |
||||||
|
|
||||||
|
#================= |
||||||
|
# C++ dependencies |
||||||
|
RUN apt-get update && apt-get -y install libgflags-dev libgtest-dev libc++-dev clang && apt-get clean |
||||||
|
|
||||||
|
# Google Cloud platform API libraries |
||||||
|
RUN apt-get update && apt-get install -y python-pip && apt-get clean |
||||||
|
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 tox |
||||||
|
|
||||||
|
|
||||||
|
RUN pip install coverage |
||||||
|
RUN pip install oauth2client |
||||||
|
|
||||||
|
# Define the default command. |
||||||
|
CMD ["bash"] |
@ -0,0 +1,46 @@ |
|||||||
|
#!/bin/bash |
||||||
|
# Copyright 2016, 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. |
||||||
|
# |
||||||
|
# Builds Python interop server and client in a base image. |
||||||
|
set -e |
||||||
|
|
||||||
|
mkdir -p /var/local/git |
||||||
|
git clone --recursive /var/local/jenkins/grpc /var/local/git/grpc |
||||||
|
|
||||||
|
# copy service account keys if available |
||||||
|
cp -r /var/local/jenkins/service_account $HOME || true |
||||||
|
|
||||||
|
cd /var/local/git/grpc |
||||||
|
|
||||||
|
tools/run_tests/run_tests.py -l python -c opt --build_only |
||||||
|
|
||||||
|
# Build c++ interop client |
||||||
|
make metrics_client -j |
||||||
|
|
@ -0,0 +1,98 @@ |
|||||||
|
{ |
||||||
|
"dockerImages": { |
||||||
|
"grpc_stress_python" : { |
||||||
|
"buildScript": "tools/run_tests/dockerize/build_interop_stress_image.sh", |
||||||
|
"dockerFileDir": "grpc_interop_stress_python" |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
"clientTemplates": { |
||||||
|
"baseTemplates": { |
||||||
|
"default": { |
||||||
|
"wrapperScriptPath": "/var/local/git/grpc/tools/gcp/stress_test/run_client.py", |
||||||
|
"pollIntervalSecs": 60, |
||||||
|
"clientArgs": { |
||||||
|
"num_channels_per_server":5, |
||||||
|
"num_stubs_per_channel":10, |
||||||
|
"test_cases": "empty_unary:1,large_unary:1,client_streaming:1,server_streaming:1,empty_stream:1", |
||||||
|
"metrics_port": 8081 |
||||||
|
}, |
||||||
|
"metricsPort": 8081, |
||||||
|
"metricsArgs": { |
||||||
|
"metrics_server_address": "localhost:8081", |
||||||
|
"total_only": "true" |
||||||
|
}, |
||||||
|
"env": { |
||||||
|
"PYTHONPATH": "/var/local/git/grpc/src/python/gens:/var/local/git/grpc/src/python/grpcio", |
||||||
|
"LD_LIBRARY_PATH":"/var/local/git/grpc/libs/opt" |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
"templates": { |
||||||
|
"python_client": { |
||||||
|
"baseTemplate": "default", |
||||||
|
"stressClientCmd": [ |
||||||
|
"python", |
||||||
|
"/var/local/git/grpc/src/python/grpcio/tests/stress/client.py" |
||||||
|
], |
||||||
|
"metricsClientCmd": ["/var/local/git/grpc/bins/opt/metrics_client"] |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
"serverTemplates": { |
||||||
|
"baseTemplates":{ |
||||||
|
"default": { |
||||||
|
"wrapperScriptPath": "/var/local/git/grpc/tools/gcp/stress_test/run_server.py", |
||||||
|
"serverPort": 8080, |
||||||
|
"serverArgs": { |
||||||
|
"port": 8080 |
||||||
|
}, |
||||||
|
"env": { |
||||||
|
"PYTHONPATH": "/var/local/git/grpc/src/python/gens:/var/local/git/grpc/src/python/grpcio", |
||||||
|
"LD_LIBRARY_PATH":"/var/local/git/grpc/libs/opt" |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
"templates": { |
||||||
|
"python_server": { |
||||||
|
"baseTemplate": "default", |
||||||
|
"stressServerCmd": [ |
||||||
|
"python", |
||||||
|
"/var/local/git/grpc/src/python/grpcio/tests/interop/server.py" |
||||||
|
] |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
"testMatrix": { |
||||||
|
"serverPodSpecs": { |
||||||
|
"python-stress-server": { |
||||||
|
"serverTemplate": "python_server", |
||||||
|
"dockerImage": "grpc_stress_python", |
||||||
|
"numInstances": 1 |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
"clientPodSpecs": { |
||||||
|
"python-stress-client": { |
||||||
|
"clientTemplate": "python_client", |
||||||
|
"dockerImage": "grpc_stress_python", |
||||||
|
"numInstances": 5, |
||||||
|
"serverPodSpec": "python-stress-server" |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
"globalSettings": { |
||||||
|
"buildDockerImages": true, |
||||||
|
"pollIntervalSecs": 60, |
||||||
|
"testDurationSecs": 7200, |
||||||
|
"kubernetesProxyPort": 8011, |
||||||
|
"datasetIdNamePrefix": "stress_test_python", |
||||||
|
"summaryTableId": "summary", |
||||||
|
"qpsTableId": "qps", |
||||||
|
"podWarmupSecs": 60 |
||||||
|
} |
||||||
|
} |
||||||
|
|
Loading…
Reference in new issue