xref: /aosp_15_r20/external/grpc-grpc/src/ruby/qps/worker.rb (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
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