blob: 94a6f8acfab9a99ab40d9eae92aec3c8f4bbbeff [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"
vjpai4f5146d2016-01-19 15:28:52 -080045#include "test/cpp/qps/limit_cores.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 Paic64736d2016-02-01 09:33:11 -080054 cores_ = LimitCores(config.core_list().data(), config.core_list_size());
vjpai72a63322015-10-29 02:23:11 -070055 if (config.port()) {
56 port_ = config.port();
Vijay Paic64736d2016-02-01 09:33:11 -080057
vjpai72a63322015-10-29 02:23:11 -070058 } else {
59 port_ = grpc_pick_unused_port_or_die();
60 }
61 }
Craig Tiller26598a32015-03-02 16:16:00 -080062 virtual ~Server() {}
Craig Tiller6af9ed02015-03-02 22:42:10 -080063
vjpai119c1032015-10-29 01:21:04 -070064 ServerStats Mark(bool reset) {
65 Timer::Result timer_result;
66 if (reset) {
67 std::unique_ptr<Timer> timer(new Timer);
68 timer.swap(timer_);
69 timer_result = timer->Mark();
70 } else {
71 timer_result = timer_->Mark();
72 }
Craig Tillerd6479d62015-03-04 12:50:11 -080073
74 ServerStats stats;
75 stats.set_time_elapsed(timer_result.wall);
76 stats.set_time_system(timer_result.system);
77 stats.set_time_user(timer_result.user);
78 return stats;
79 }
80
Craig Tillera182bf12015-03-04 13:54:39 -080081 static bool SetPayload(PayloadType type, int size, Payload* payload) {
Craig Tillera182bf12015-03-04 13:54:39 -080082 // TODO(yangg): Support UNCOMPRESSABLE payload.
83 if (type != PayloadType::COMPRESSABLE) {
84 return false;
85 }
vjpaib6df94a2015-11-30 15:52:50 -080086 payload->set_type(type);
Craig Tillera182bf12015-03-04 13:54:39 -080087 std::unique_ptr<char[]> body(new char[size]());
88 payload->set_body(body.get(), size);
89 return true;
90 }
Craig Tillerd6479d62015-03-04 12:50:11 -080091
vjpaifba20c92015-11-04 14:49:17 -080092 int port() const { return port_; }
Vijay Pai3448c272016-01-13 11:17:13 -080093 int cores() const { return cores_; }
Vijay Paice846702015-11-04 00:30:12 -080094 static std::shared_ptr<ServerCredentials> CreateServerCredentials(
95 const ServerConfig& config) {
vjpai780a7f22015-11-04 00:19:09 -080096 if (config.has_security_params()) {
97 SslServerCredentialsOptions::PemKeyCertPair pkcp = {test_server1_key,
Vijay Paice846702015-11-04 00:30:12 -080098 test_server1_cert};
vjpai780a7f22015-11-04 00:19:09 -080099 SslServerCredentialsOptions ssl_opts;
100 ssl_opts.pem_root_certs = "";
101 ssl_opts.pem_key_cert_pairs.push_back(pkcp);
102 return SslServerCredentials(ssl_opts);
103 } else {
104 return InsecureServerCredentials();
105 }
106 }
Vijay Paice846702015-11-04 00:30:12 -0800107
Craig Tillerd6479d62015-03-04 12:50:11 -0800108 private:
vjpai72a63322015-10-29 02:23:11 -0700109 int port_;
Vijay Pai0e66efd2016-01-13 11:15:49 -0800110 int cores_;
Craig Tillerd6479d62015-03-04 12:50:11 -0800111 std::unique_ptr<Timer> timer_;
Craig Tiller26598a32015-03-02 16:16:00 -0800112};
113
vjpai72a63322015-10-29 02:23:11 -0700114std::unique_ptr<Server> CreateSynchronousServer(const ServerConfig& config);
115std::unique_ptr<Server> CreateAsyncServer(const ServerConfig& config);
vjpaia00f9982016-01-26 17:51:35 -0800116std::unique_ptr<Server> CreateAsyncGenericServer(const ServerConfig& config);
Craig Tiller26598a32015-03-02 16:16:00 -0800117
118} // namespace testing
119} // namespace grpc
120
121#endif