blob: d6d09b6cc887e7f2f316069e8665484c614e7db7 [file] [log] [blame]
Jan Tattermuschb2758442016-03-28 09:32:20 -07001#!/bin/bash
Craig Tiller084aa622016-04-05 08:36:49 -07002# Copyright 2015, Google Inc.
Jan Tattermuschb2758442016-03-28 09:32:20 -07003# All rights reserved.
4#
5# Redistribution and use in source and binary forms, with or without
6# modification, are permitted provided that the following conditions are
7# met:
8#
9# * Redistributions of source code must retain the above copyright
10# notice, this list of conditions and the following disclaimer.
11# * Redistributions in binary form must reproduce the above
12# copyright notice, this list of conditions and the following disclaimer
13# in the documentation and/or other materials provided with the
14# distribution.
15# * Neither the name of Google Inc. nor the names of its
16# contributors may be used to endorse or promote products derived from
17# this software without specific prior written permission.
18#
19# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
31set -ex
32
33cd $(dirname $0)/../../..
34
Jan Tattermuschbb1a4532016-03-30 18:04:01 -070035# TODO(jtattermusch): To be sure there are no running processes that would
Jan Tattermuschb2758442016-03-28 09:32:20 -070036# mess with the results, be rough and reboot the slave here
37# and wait for it to come back online.
Jan Tattermusch2de47cb2016-11-16 14:11:22 +010038ssh "${USER_AT_HOST}" "killall -9 qps_worker dotnet mono node ruby worker || true"
39
40# On Windows, killall is not supported & we need to kill all pending workers
41# before attempting to delete the workspace
42ssh "${USER_AT_HOST}" "ps -e | egrep 'qps_worker|dotnet' | awk '{print $1}' | xargs kill -9 || true"
43
44# cleanup after previous builds
45ssh "${USER_AT_HOST}" "rm -rf ~/performance_workspace && mkdir -p ~/performance_workspace"
Jan Tattermuschb2758442016-03-28 09:32:20 -070046
47# push the current sources to the slave and unpack it.
48scp ../grpc.tar "${USER_AT_HOST}:~/performance_workspace"
Jan Tattermusch2de47cb2016-11-16 14:11:22 +010049# Windows workaround: attempt to untar twice, first run is going to fail
50# with symlink creation error(s).
51ssh "${USER_AT_HOST}" "tar -xf ~/performance_workspace/grpc.tar -C ~/performance_workspace || tar -xf ~/performance_workspace/grpc.tar -C ~/performance_workspace"
Jan Tattermusch14089202016-04-27 17:55:27 -070052
53# For consistency with local run, invoke the kill_workers script remotely.
54ssh "${USER_AT_HOST}" "~/performance_workspace/grpc/tools/run_tests/performance/kill_workers.sh"