blob: 0c6e264a50d6c056133111a2627a7268d8804b93 [file] [log] [blame]
Craig Tiller26598a32015-03-02 16:16:00 -08001/*
2 *
murgatroid99eeb02ba2016-01-13 20:43:33 -08003 * Copyright 2015-2016, Google Inc.
Craig Tiller26598a32015-03-02 16:16:00 -08004 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are
8 * met:
9 *
10 * * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * * Redistributions in binary form must reproduce the above
13 * copyright notice, this list of conditions and the following disclaimer
14 * in the documentation and/or other materials provided with the
15 * distribution.
16 * * Neither the name of Google Inc. nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 *
32 */
33
34#ifndef TEST_QPS_SERVER_H
35#define TEST_QPS_SERVER_H
36
vjpai780a7f22015-11-04 00:19:09 -080037#include <grpc++/security/server_credentials.h>
Vijay Pai3448c272016-01-13 11:17:13 -080038#include <grpc/support/cpu.h>
39#include <vector>
vjpaid08a7382015-11-02 16:45:08 -080040
Vijay Pai3448c272016-01-13 11:17:13 -080041#include "src/proto/grpc/testing/control.grpc.pb.h"
42#include "src/proto/grpc/testing/messages.grpc.pb.h"
vjpai780a7f22015-11-04 00:19:09 -080043#include "test/core/end2end/data/ssl_test_data.h"
vjpai72a63322015-10-29 02:23:11 -070044#include "test/core/util/port.h"
Vijay Pai0e66efd2016-01-13 11:15:49 -080045#include "test/cpp/qps/coresched.h"
Craig Tillerd6479d62015-03-04 12:50:11 -080046#include "test/cpp/qps/timer.h"
Craig Tiller26598a32015-03-02 16:16:00 -080047
48namespace grpc {
49namespace testing {
50
51class Server {
52 public:
vjpai72a63322015-10-29 02:23:11 -070053 explicit Server(const ServerConfig& config) : timer_(new Timer) {
Vijay Pai0e66efd2016-01-13 11:15:49 -080054 int clsize = config.core_list_size();
55 if (clsize > 0) {
56 std::vector<int> core_list;
57 for (int i = 0; i < clsize; i++) {
58 core_list.push_back(config.core_list(i));
59 }
60 cores_ = LimitCores(core_list);
61 } else {
62 cores_ = gpr_cpu_num_cores();
63 }
vjpai72a63322015-10-29 02:23:11 -070064 if (config.port()) {
65 port_ = config.port();
66 } else {
67 port_ = grpc_pick_unused_port_or_die();
68 }
69 }
Craig Tiller26598a32015-03-02 16:16:00 -080070 virtual ~Server() {}
Craig Tiller6af9ed02015-03-02 22:42:10 -080071
vjpai119c1032015-10-29 01:21:04 -070072 ServerStats Mark(bool reset) {
73 Timer::Result timer_result;
74 if (reset) {
75 std::unique_ptr<Timer> timer(new Timer);
76 timer.swap(timer_);
77 timer_result = timer->Mark();
78 } else {
79 timer_result = timer_->Mark();
80 }
Craig Tillerd6479d62015-03-04 12:50:11 -080081
82 ServerStats stats;
83 stats.set_time_elapsed(timer_result.wall);
84 stats.set_time_system(timer_result.system);
85 stats.set_time_user(timer_result.user);
86 return stats;
87 }
88
Craig Tillera182bf12015-03-04 13:54:39 -080089 static bool SetPayload(PayloadType type, int size, Payload* payload) {
Craig Tillera182bf12015-03-04 13:54:39 -080090 // TODO(yangg): Support UNCOMPRESSABLE payload.
91 if (type != PayloadType::COMPRESSABLE) {
92 return false;
93 }
vjpaib6df94a2015-11-30 15:52:50 -080094 payload->set_type(type);
Craig Tillera182bf12015-03-04 13:54:39 -080095 std::unique_ptr<char[]> body(new char[size]());
96 payload->set_body(body.get(), size);
97 return true;
98 }
Craig Tillerd6479d62015-03-04 12:50:11 -080099
vjpaifba20c92015-11-04 14:49:17 -0800100 int port() const { return port_; }
Vijay Pai3448c272016-01-13 11:17:13 -0800101 int cores() const { return cores_; }
Vijay Paice846702015-11-04 00:30:12 -0800102 static std::shared_ptr<ServerCredentials> CreateServerCredentials(
103 const ServerConfig& config) {
vjpai780a7f22015-11-04 00:19:09 -0800104 if (config.has_security_params()) {
105 SslServerCredentialsOptions::PemKeyCertPair pkcp = {test_server1_key,
Vijay Paice846702015-11-04 00:30:12 -0800106 test_server1_cert};
vjpai780a7f22015-11-04 00:19:09 -0800107 SslServerCredentialsOptions ssl_opts;
108 ssl_opts.pem_root_certs = "";
109 ssl_opts.pem_key_cert_pairs.push_back(pkcp);
110 return SslServerCredentials(ssl_opts);
111 } else {
112 return InsecureServerCredentials();
113 }
114 }
Vijay Paice846702015-11-04 00:30:12 -0800115
Craig Tillerd6479d62015-03-04 12:50:11 -0800116 private:
vjpai72a63322015-10-29 02:23:11 -0700117 int port_;
Vijay Pai0e66efd2016-01-13 11:15:49 -0800118 int cores_;
Craig Tillerd6479d62015-03-04 12:50:11 -0800119 std::unique_ptr<Timer> timer_;
Craig Tiller26598a32015-03-02 16:16:00 -0800120};
121
vjpai72a63322015-10-29 02:23:11 -0700122std::unique_ptr<Server> CreateSynchronousServer(const ServerConfig& config);
123std::unique_ptr<Server> CreateAsyncServer(const ServerConfig& config);
Craig Tiller26598a32015-03-02 16:16:00 -0800124
125} // namespace testing
126} // namespace grpc
127
128#endif