1*cc02d7e2SAndroid Build Coastguard Worker#!/usr/bin/env ruby 2*cc02d7e2SAndroid Build Coastguard Worker 3*cc02d7e2SAndroid Build Coastguard Worker# Copyright 2016 gRPC authors. 4*cc02d7e2SAndroid Build Coastguard Worker# 5*cc02d7e2SAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 6*cc02d7e2SAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 7*cc02d7e2SAndroid Build Coastguard Worker# You may obtain a copy of the License at 8*cc02d7e2SAndroid Build Coastguard Worker# 9*cc02d7e2SAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 10*cc02d7e2SAndroid Build Coastguard Worker# 11*cc02d7e2SAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 12*cc02d7e2SAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, 13*cc02d7e2SAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*cc02d7e2SAndroid Build Coastguard Worker# See the License for the specific language governing permissions and 15*cc02d7e2SAndroid Build Coastguard Worker# limitations under the License. 16*cc02d7e2SAndroid Build Coastguard Worker 17*cc02d7e2SAndroid Build Coastguard Worker# Worker and worker service implementation 18*cc02d7e2SAndroid Build Coastguard Worker 19*cc02d7e2SAndroid Build Coastguard Workerthis_dir = File.expand_path(File.dirname(__FILE__)) 20*cc02d7e2SAndroid Build Coastguard Workerlib_dir = File.join(File.dirname(this_dir), 'lib') 21*cc02d7e2SAndroid Build Coastguard Worker$LOAD_PATH.unshift(lib_dir) unless $LOAD_PATH.include?(lib_dir) 22*cc02d7e2SAndroid Build Coastguard Worker$LOAD_PATH.unshift(this_dir) unless $LOAD_PATH.include?(this_dir) 23*cc02d7e2SAndroid Build Coastguard Worker 24*cc02d7e2SAndroid Build Coastguard Workerrequire 'grpc' 25*cc02d7e2SAndroid Build Coastguard Workerrequire 'optparse' 26*cc02d7e2SAndroid Build Coastguard Workerrequire 'histogram' 27*cc02d7e2SAndroid Build Coastguard Workerrequire 'etc' 28*cc02d7e2SAndroid Build Coastguard Workerrequire 'facter' 29*cc02d7e2SAndroid Build Coastguard Workerrequire 'client' 30*cc02d7e2SAndroid Build Coastguard Workerrequire 'qps-common' 31*cc02d7e2SAndroid Build Coastguard Workerrequire 'server' 32*cc02d7e2SAndroid Build Coastguard Workerrequire 'src/proto/grpc/testing/worker_service_services_pb' 33*cc02d7e2SAndroid Build Coastguard Worker 34*cc02d7e2SAndroid Build Coastguard Workerclass WorkerServiceImpl < Grpc::Testing::WorkerService::Service 35*cc02d7e2SAndroid Build Coastguard Worker def cpu_cores 36*cc02d7e2SAndroid Build Coastguard Worker Facter.value('processors')['count'] 37*cc02d7e2SAndroid Build Coastguard Worker end 38*cc02d7e2SAndroid Build Coastguard Worker def run_server(reqs) 39*cc02d7e2SAndroid Build Coastguard Worker q = EnumeratorQueue.new(self) 40*cc02d7e2SAndroid Build Coastguard Worker Thread.new { 41*cc02d7e2SAndroid Build Coastguard Worker bms = '' 42*cc02d7e2SAndroid Build Coastguard Worker gtss = Grpc::Testing::ServerStatus 43*cc02d7e2SAndroid Build Coastguard Worker reqs.each do |req| 44*cc02d7e2SAndroid Build Coastguard Worker case req.argtype.to_s 45*cc02d7e2SAndroid Build Coastguard Worker when 'setup' 46*cc02d7e2SAndroid Build Coastguard Worker bms = BenchmarkServer.new(req.setup, @server_port) 47*cc02d7e2SAndroid Build Coastguard Worker q.push(gtss.new(stats: bms.mark(false), port: bms.get_port)) 48*cc02d7e2SAndroid Build Coastguard Worker when 'mark' 49*cc02d7e2SAndroid Build Coastguard Worker q.push(gtss.new(stats: bms.mark(req.mark.reset), cores: cpu_cores)) 50*cc02d7e2SAndroid Build Coastguard Worker end 51*cc02d7e2SAndroid Build Coastguard Worker end 52*cc02d7e2SAndroid Build Coastguard Worker bms.stop 53*cc02d7e2SAndroid Build Coastguard Worker q.push(self) 54*cc02d7e2SAndroid Build Coastguard Worker } 55*cc02d7e2SAndroid Build Coastguard Worker q.each_item 56*cc02d7e2SAndroid Build Coastguard Worker end 57*cc02d7e2SAndroid Build Coastguard Worker def run_client(reqs) 58*cc02d7e2SAndroid Build Coastguard Worker q = EnumeratorQueue.new(self) 59*cc02d7e2SAndroid Build Coastguard Worker Thread.new { 60*cc02d7e2SAndroid Build Coastguard Worker client = '' 61*cc02d7e2SAndroid Build Coastguard Worker reqs.each do |req| 62*cc02d7e2SAndroid Build Coastguard Worker case req.argtype.to_s 63*cc02d7e2SAndroid Build Coastguard Worker when 'setup' 64*cc02d7e2SAndroid Build Coastguard Worker client = BenchmarkClient.new(req.setup) 65*cc02d7e2SAndroid Build Coastguard Worker q.push(Grpc::Testing::ClientStatus.new(stats: client.mark(false))) 66*cc02d7e2SAndroid Build Coastguard Worker when 'mark' 67*cc02d7e2SAndroid Build Coastguard Worker q.push(Grpc::Testing::ClientStatus.new(stats: 68*cc02d7e2SAndroid Build Coastguard Worker client.mark(req.mark.reset))) 69*cc02d7e2SAndroid Build Coastguard Worker end 70*cc02d7e2SAndroid Build Coastguard Worker end 71*cc02d7e2SAndroid Build Coastguard Worker client.shutdown 72*cc02d7e2SAndroid Build Coastguard Worker q.push(self) 73*cc02d7e2SAndroid Build Coastguard Worker } 74*cc02d7e2SAndroid Build Coastguard Worker q.each_item 75*cc02d7e2SAndroid Build Coastguard Worker end 76*cc02d7e2SAndroid Build Coastguard Worker def core_count(_args, _call) 77*cc02d7e2SAndroid Build Coastguard Worker Grpc::Testing::CoreResponse.new(cores: cpu_cores) 78*cc02d7e2SAndroid Build Coastguard Worker end 79*cc02d7e2SAndroid Build Coastguard Worker def quit_worker(_args, _call) 80*cc02d7e2SAndroid Build Coastguard Worker @shutdown_thread = Thread.new { 81*cc02d7e2SAndroid Build Coastguard Worker @server.stop 82*cc02d7e2SAndroid Build Coastguard Worker } 83*cc02d7e2SAndroid Build Coastguard Worker Grpc::Testing::Void.new 84*cc02d7e2SAndroid Build Coastguard Worker end 85*cc02d7e2SAndroid Build Coastguard Worker def initialize(s, sp) 86*cc02d7e2SAndroid Build Coastguard Worker @server = s 87*cc02d7e2SAndroid Build Coastguard Worker @server_port = sp 88*cc02d7e2SAndroid Build Coastguard Worker end 89*cc02d7e2SAndroid Build Coastguard Worker def join_shutdown_thread 90*cc02d7e2SAndroid Build Coastguard Worker @shutdown_thread.join 91*cc02d7e2SAndroid Build Coastguard Worker end 92*cc02d7e2SAndroid Build Coastguard Workerend 93*cc02d7e2SAndroid Build Coastguard Worker 94*cc02d7e2SAndroid Build Coastguard Workerdef main 95*cc02d7e2SAndroid Build Coastguard Worker options = { 96*cc02d7e2SAndroid Build Coastguard Worker 'driver_port' => 0, 97*cc02d7e2SAndroid Build Coastguard Worker 'server_port' => 0 98*cc02d7e2SAndroid Build Coastguard Worker } 99*cc02d7e2SAndroid Build Coastguard Worker OptionParser.new do |opts| 100*cc02d7e2SAndroid Build Coastguard Worker opts.banner = 'Usage: [--driver_port <port>] [--server_port <port>]' 101*cc02d7e2SAndroid Build Coastguard Worker opts.on('--driver_port PORT', '<port>') do |v| 102*cc02d7e2SAndroid Build Coastguard Worker options['driver_port'] = v 103*cc02d7e2SAndroid Build Coastguard Worker end 104*cc02d7e2SAndroid Build Coastguard Worker opts.on('--server_port PORT', '<port>') do |v| 105*cc02d7e2SAndroid Build Coastguard Worker options['server_port'] = v 106*cc02d7e2SAndroid Build Coastguard Worker end 107*cc02d7e2SAndroid Build Coastguard Worker end.parse! 108*cc02d7e2SAndroid Build Coastguard Worker 109*cc02d7e2SAndroid Build Coastguard Worker # Configure any errors with client or server child threads to surface 110*cc02d7e2SAndroid Build Coastguard Worker Thread.abort_on_exception = true 111*cc02d7e2SAndroid Build Coastguard Worker 112*cc02d7e2SAndroid Build Coastguard Worker s = GRPC::RpcServer.new(poll_period: 3) 113*cc02d7e2SAndroid Build Coastguard Worker s.add_http2_port("0.0.0.0:" + options['driver_port'].to_s, 114*cc02d7e2SAndroid Build Coastguard Worker :this_port_is_insecure) 115*cc02d7e2SAndroid Build Coastguard Worker worker_service = WorkerServiceImpl.new(s, options['server_port'].to_i) 116*cc02d7e2SAndroid Build Coastguard Worker s.handle(worker_service) 117*cc02d7e2SAndroid Build Coastguard Worker s.run 118*cc02d7e2SAndroid Build Coastguard Worker worker_service.join_shutdown_thread 119*cc02d7e2SAndroid Build Coastguard Workerend 120*cc02d7e2SAndroid Build Coastguard Worker 121*cc02d7e2SAndroid Build Coastguard Workermain 122