blob: 2df22f48a2e131df650fdc3f3d0eaaa07f285228 [file] [log] [blame]
Alexander Polcynea282e92017-03-20 20:53:34 -07001#!/usr/bin/env ruby
2
Jan Tattermusch7897ae92017-06-07 22:57:36 +02003# Copyright 2016 gRPC authors.
Alexander Polcynea282e92017-03-20 20:53:34 -07004#
Jan Tattermusch7897ae92017-06-07 22:57:36 +02005# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
Alexander Polcynea282e92017-03-20 20:53:34 -07008#
Jan Tattermusch7897ae92017-06-07 22:57:36 +02009# http://www.apache.org/licenses/LICENSE-2.0
Alexander Polcynea282e92017-03-20 20:53:34 -070010#
Jan Tattermusch7897ae92017-06-07 22:57:36 +020011# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
Alexander Polcynea282e92017-03-20 20:53:34 -070016
17# abruptly end a process that has active calls to
18# Channel.watch_connectivity_state
19
20require_relative './end2end_common'
21
22def main
23 STDERR.puts 'start server'
Alexander Polcyn077f8902017-03-24 09:53:40 -070024 server_runner = ServerRunner.new(EchoServerImpl)
Alexander Polcynea282e92017-03-20 20:53:34 -070025 server_port = server_runner.run
Alexander Polcynea282e92017-03-20 20:53:34 -070026 STDERR.puts 'start client'
27 _, client_pid = start_client('sig_int_during_channel_watch_client.rb',
28 server_port)
Alexander Polcynea282e92017-03-20 20:53:34 -070029 # give time for the client to get into the middle
30 # of a channel state watch call
31 sleep 1
32 Process.kill('SIGINT', client_pid)
33
34 begin
35 Timeout.timeout(10) do
36 Process.wait(client_pid)
37 end
38 rescue Timeout::Error
39 STDERR.puts "timeout wait for client pid #{client_pid}"
40 Process.kill('SIGKILL', client_pid)
41 Process.wait(client_pid)
42 STDERR.puts 'killed client child'
43 raise 'Timed out waiting for client process. It likely hangs when a ' \
44 'SIGINT is sent while there is an active connectivity_state call'
45 end
Alexander Polcyn02d131b2017-03-22 15:12:32 -070046
Alexander Polcynb2c0b7b2017-04-27 00:26:25 -070047 client_exit_code = $CHILD_STATUS
48 if client_exit_code != 0
49 fail "sig_int_during_channel_watch_client failed: #{client_exit_code}"
50 end
51
Alexander Polcyn02d131b2017-03-22 15:12:32 -070052 server_runner.stop
Alexander Polcynea282e92017-03-20 20:53:34 -070053end
54
55main