Merge pull request #8792 from jtattermusch/interop_less_verbose

Reduce noise in interop test output
pull/8242/merge
Jan Tattermusch 8 years ago committed by GitHub
commit eed43d9128
  1. 34
      tools/run_tests/interop/with_nvm.sh
  2. 34
      tools/run_tests/interop/with_rvm.sh
  3. 26
      tools/run_tests/run_interop_tests.py

@ -0,0 +1,34 @@
#!/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.
# Makes sure NVM is loaded before executing the command passed as an argument
source ~/.nvm/nvm.sh
$@

@ -0,0 +1,34 @@
#!/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.
# Makes sure RVM is loaded before executing the command passed as an argument
source /usr/local/rvm/scripts/rvm
$@

@ -254,13 +254,16 @@ class NodeLanguage:
self.safename = str(self) self.safename = str(self)
def client_cmd(self, args): def client_cmd(self, args):
return ['node', 'src/node/interop/interop_client.js'] + args return ['tools/run_tests/interop/with_nvm.sh',
'node', 'src/node/interop/interop_client.js'] + args
def cloud_to_prod_env(self): def cloud_to_prod_env(self):
return {} return {}
def server_cmd(self, args): def server_cmd(self, args):
return ['node', 'src/node/interop/interop_server.js', '--use_tls=true'] + args return ['tools/run_tests/interop/with_nvm.sh',
'node', 'src/node/interop/interop_server.js',
'--use_tls=true'] + args
def global_env(self): def global_env(self):
return {} return {}
@ -333,13 +336,15 @@ class RubyLanguage:
self.safename = str(self) self.safename = str(self)
def client_cmd(self, args): def client_cmd(self, args):
return ['ruby', 'src/ruby/pb/test/client.rb'] + args return ['tools/run_tests/interop/with_rvm.sh',
'ruby', 'src/ruby/pb/test/client.rb'] + args
def cloud_to_prod_env(self): def cloud_to_prod_env(self):
return {} return {}
def server_cmd(self, args): def server_cmd(self, args):
return ['ruby', 'src/ruby/pb/test/server.rb', '--use_tls=true'] + args return ['tools/run_tests/interop/with_rvm.sh',
'ruby', 'src/ruby/pb/test/server.rb', '--use_tls=true'] + args
def global_env(self): def global_env(self):
return {} return {}
@ -447,12 +452,11 @@ def docker_run_cmdline(cmdline, image, docker_args=[], cwd=None, environ=None):
return docker_cmdline return docker_cmdline
def bash_login_cmdline(cmdline): def bash_cmdline(cmdline):
"""Creates bash -l -c cmdline from args list.""" """Creates bash -c cmdline from args list."""
# Use login shell: # Use login shell:
# * rvm and nvm require it
# * makes error messages clearer if executables are missing # * makes error messages clearer if executables are missing
return ['bash', '-l', '-c', ' '.join(cmdline)] return ['bash', '-c', ' '.join(cmdline)]
def auth_options(language, test_case): def auth_options(language, test_case):
@ -512,7 +516,7 @@ def cloud_to_prod_jobspec(language, test_case, server_host_name,
auth_cmdargs, auth_env = auth_options(language, test_case) auth_cmdargs, auth_env = auth_options(language, test_case)
cmdargs += auth_cmdargs cmdargs += auth_cmdargs
environ.update(auth_env) environ.update(auth_env)
cmdline = bash_login_cmdline(language.client_cmd(cmdargs)) cmdline = bash_cmdline(language.client_cmd(cmdargs))
cwd = language.client_cwd cwd = language.client_cwd
if docker_image: if docker_image:
@ -546,7 +550,7 @@ def cloud_to_prod_jobspec(language, test_case, server_host_name,
def cloud_to_cloud_jobspec(language, test_case, server_name, server_host, def cloud_to_cloud_jobspec(language, test_case, server_name, server_host,
server_port, docker_image=None): server_port, docker_image=None):
"""Creates jobspec for cloud-to-cloud interop test""" """Creates jobspec for cloud-to-cloud interop test"""
cmdline = bash_login_cmdline(language.client_cmd([ cmdline = bash_cmdline(language.client_cmd([
'--server_host_override=foo.test.google.fr', '--server_host_override=foo.test.google.fr',
'--use_tls=true', '--use_tls=true',
'--use_test_ca=true', '--use_test_ca=true',
@ -583,7 +587,7 @@ def cloud_to_cloud_jobspec(language, test_case, server_name, server_host,
def server_jobspec(language, docker_image): def server_jobspec(language, docker_image):
"""Create jobspec for running a server""" """Create jobspec for running a server"""
container_name = dockerjob.random_name('interop_server_%s' % language.safename) container_name = dockerjob.random_name('interop_server_%s' % language.safename)
cmdline = bash_login_cmdline( cmdline = bash_cmdline(
language.server_cmd(['--port=%s' % _DEFAULT_SERVER_PORT])) language.server_cmd(['--port=%s' % _DEFAULT_SERVER_PORT]))
environ = language.global_env() environ = language.global_env()
docker_cmdline = docker_run_cmdline(cmdline, docker_cmdline = docker_run_cmdline(cmdline,

Loading…
Cancel
Save