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 'qps-common' 26*cc02d7e2SAndroid Build Coastguard Workerrequire 'src/proto/grpc/testing/messages_pb' 27*cc02d7e2SAndroid Build Coastguard Workerrequire 'src/proto/grpc/testing/benchmark_service_services_pb' 28*cc02d7e2SAndroid Build Coastguard Workerrequire 'src/proto/grpc/testing/stats_pb' 29*cc02d7e2SAndroid Build Coastguard Worker 30*cc02d7e2SAndroid Build Coastguard Workerclass BenchmarkServiceImpl < Grpc::Testing::BenchmarkService::Service 31*cc02d7e2SAndroid Build Coastguard Worker def unary_call(req, _call) 32*cc02d7e2SAndroid Build Coastguard Worker sr = Grpc::Testing::SimpleResponse 33*cc02d7e2SAndroid Build Coastguard Worker pl = Grpc::Testing::Payload 34*cc02d7e2SAndroid Build Coastguard Worker sr.new(payload: pl.new(body: nulls(req.response_size))) 35*cc02d7e2SAndroid Build Coastguard Worker end 36*cc02d7e2SAndroid Build Coastguard Worker def streaming_call(reqs) 37*cc02d7e2SAndroid Build Coastguard Worker PingPongEnumerator.new(reqs).each_item 38*cc02d7e2SAndroid Build Coastguard Worker end 39*cc02d7e2SAndroid Build Coastguard Workerend 40*cc02d7e2SAndroid Build Coastguard Worker 41*cc02d7e2SAndroid Build Coastguard Workerclass BenchmarkServer 42*cc02d7e2SAndroid Build Coastguard Worker def initialize(config, port) 43*cc02d7e2SAndroid Build Coastguard Worker if config.security_params 44*cc02d7e2SAndroid Build Coastguard Worker certs = load_test_certs 45*cc02d7e2SAndroid Build Coastguard Worker cred = GRPC::Core::ServerCredentials.new( 46*cc02d7e2SAndroid Build Coastguard Worker nil, [{private_key: certs[1], cert_chain: certs[2]}], false) 47*cc02d7e2SAndroid Build Coastguard Worker else 48*cc02d7e2SAndroid Build Coastguard Worker cred = :this_port_is_insecure 49*cc02d7e2SAndroid Build Coastguard Worker end 50*cc02d7e2SAndroid Build Coastguard Worker # Make sure server can handle the large number of calls in benchmarks 51*cc02d7e2SAndroid Build Coastguard Worker # TODO: @apolcyn, if scenario config increases total outstanding 52*cc02d7e2SAndroid Build Coastguard Worker # calls then will need to increase the pool size too 53*cc02d7e2SAndroid Build Coastguard Worker @server = GRPC::RpcServer.new(pool_size: 1024, max_waiting_requests: 1024) 54*cc02d7e2SAndroid Build Coastguard Worker @port = @server.add_http2_port("0.0.0.0:" + port.to_s, cred) 55*cc02d7e2SAndroid Build Coastguard Worker @server.handle(BenchmarkServiceImpl.new) 56*cc02d7e2SAndroid Build Coastguard Worker @start_time = Time.now 57*cc02d7e2SAndroid Build Coastguard Worker t = Thread.new { 58*cc02d7e2SAndroid Build Coastguard Worker @server.run 59*cc02d7e2SAndroid Build Coastguard Worker } 60*cc02d7e2SAndroid Build Coastguard Worker t.abort_on_exception 61*cc02d7e2SAndroid Build Coastguard Worker end 62*cc02d7e2SAndroid Build Coastguard Worker def mark(reset) 63*cc02d7e2SAndroid Build Coastguard Worker s = Grpc::Testing::ServerStats.new(time_elapsed: 64*cc02d7e2SAndroid Build Coastguard Worker (Time.now-@start_time).to_f) 65*cc02d7e2SAndroid Build Coastguard Worker @start_time = Time.now if reset 66*cc02d7e2SAndroid Build Coastguard Worker s 67*cc02d7e2SAndroid Build Coastguard Worker end 68*cc02d7e2SAndroid Build Coastguard Worker def get_port 69*cc02d7e2SAndroid Build Coastguard Worker @port 70*cc02d7e2SAndroid Build Coastguard Worker end 71*cc02d7e2SAndroid Build Coastguard Worker def stop 72*cc02d7e2SAndroid Build Coastguard Worker @server.stop 73*cc02d7e2SAndroid Build Coastguard Worker end 74*cc02d7e2SAndroid Build Coastguard Workerend 75