Imported Upstream version 1.41.0
[platform/upstream/grpc.git] / tools / internal_ci / linux / run_performance_profile_daily.sh
1 #!/bin/bash
2 # Copyright 2016 gRPC authors.
3 #
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
7 #
8 #     http://www.apache.org/licenses/LICENSE-2.0
9 #
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
15
16 set -ex
17
18 cd $(dirname $0)/../../..
19
20 # try to use pypy for generating reports
21 # each trace dumps 7-8gig of text to disk, and processing this into a report is
22 # heavyweight - so any speed boost is worthwhile
23 # TODO(ctiller): consider rewriting report generation in C++ for performance
24 if which pypy >/dev/null; then
25   PYTHON=pypy
26 else
27   PYTHON=python2.7
28 fi
29
30 BENCHMARKS_TO_RUN="bm_fullstack_unary_ping_pong bm_fullstack_streaming_ping_pong bm_fullstack_streaming_pump bm_closure bm_cq bm_call_create bm_error bm_chttp2_hpack bm_chttp2_transport bm_pollset bm_metadata"
31
32 ./tools/run_tests/start_port_server.py || true
33
34 $PYTHON tools/run_tests/run_microbenchmark.py --collect summary perf latency -b $BENCHMARKS_TO_RUN