Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(238)

Unified Diff: components/grpc_support/test/quic_test_server.cc

Issue 2492703002: Third try at landing gRPC refactoring. Previous issue failed on the waterfall (Closed)
Patch Set: Change DCHECK Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « components/grpc_support/test/quic_test_server.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/grpc_support/test/quic_test_server.cc
diff --git a/components/cronet/ios/test/quic_test_server.cc b/components/grpc_support/test/quic_test_server.cc
similarity index 75%
rename from components/cronet/ios/test/quic_test_server.cc
rename to components/grpc_support/test/quic_test_server.cc
index 5b719a984d7e6f6f435d934cdfc119a616781ed9..169241db124c1bd9e92da4f0fff8bd75bc267f0d 100644
--- a/components/cronet/ios/test/quic_test_server.cc
+++ b/components/grpc_support/test/quic_test_server.cc
@@ -2,7 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "components/cronet/ios/test/quic_test_server.h"
+#include "components/grpc_support/test/quic_test_server.h"
#include <utility>
@@ -10,6 +10,7 @@
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/path_service.h"
+#include "base/strings/stringprintf.h"
#include "base/synchronization/waitable_event.h"
#include "base/threading/thread.h"
#include "net/base/ip_address.h"
@@ -20,14 +21,12 @@
#include "net/tools/quic/quic_in_memory_cache.h"
#include "net/tools/quic/quic_simple_server.h"
-namespace cronet {
+namespace grpc_support {
// This must match the certificate used (quic_test.example.com.crt and
// quic_test.example.com.key.pkcs8).
-const char kTestServerDomain[] = "test.example.com";
-const int kTestServerPort = 6121;
-const char kTestServerHost[] = "test.example.com:6121";
-const char kTestServerUrl[] = "https://test.example.com:6121/hello.txt";
+const char kTestServerHost[] = "test.example.com";
+const char kTestServerUrl[] = "https://test.example.com/hello.txt";
const char kStatusHeader[] = ":status";
@@ -43,6 +42,7 @@ const char kHelloTrailerValue[] = "hello trailer value";
base::Thread* g_quic_server_thread = nullptr;
net::QuicSimpleServer* g_quic_server = nullptr;
+int g_quic_server_port = 0;
void SetupQuicInMemoryCache() {
static bool setup_done = false;
@@ -50,13 +50,13 @@ void SetupQuicInMemoryCache() {
return;
setup_done = true;
net::SpdyHeaderBlock headers;
- headers.AppendValueOrAddHeader(kHelloHeaderName, kHelloHeaderValue);
- headers.AppendValueOrAddHeader(kStatusHeader, kHelloStatus);
+ headers[kHelloHeaderName] = kHelloHeaderValue;
+ headers[kStatusHeader] = kHelloStatus;
net::SpdyHeaderBlock trailers;
- trailers.AppendValueOrAddHeader(kHelloTrailerName, kHelloTrailerValue);
+ trailers[kHelloTrailerName] = kHelloTrailerValue;
net::QuicInMemoryCache::GetInstance()->AddResponse(
- kTestServerHost, kHelloPath, std::move(headers), kHelloBodyValue,
- std::move(trailers));
+ base::StringPrintf("%s", kTestServerHost),
+ kHelloPath, std::move(headers), kHelloBodyValue, std::move(trailers));
}
void StartQuicServerOnServerThread(const base::FilePath& test_files_root,
@@ -64,8 +64,6 @@ void StartQuicServerOnServerThread(const base::FilePath& test_files_root,
DCHECK(g_quic_server_thread->task_runner()->BelongsToCurrentThread());
DCHECK(!g_quic_server);
- // Set up in-memory cache.
- SetupQuicInMemoryCache();
net::QuicConfig config;
// Set up server certs.
base::FilePath directory;
@@ -73,18 +71,22 @@ void StartQuicServerOnServerThread(const base::FilePath& test_files_root,
std::unique_ptr<net::ProofSourceChromium> proof_source(
new net::ProofSourceChromium());
CHECK(proof_source->Initialize(
- directory.Append("quic_test.example.com.crt"),
- directory.Append("quic_test.example.com.key.pkcs8"),
- directory.Append("quic_test.example.com.key.sct")));
+ directory.AppendASCII("quic_test.example.com.crt"),
+ directory.AppendASCII("quic_test.example.com.key.pkcs8"),
+ directory.AppendASCII("quic_test.example.com.key.sct")));
g_quic_server =
new net::QuicSimpleServer(std::move(proof_source), config,
net::QuicCryptoServerConfig::ConfigOptions(),
net::AllSupportedVersions());
- // Start listening.
+ // Start listening on an unbound port.
int rv = g_quic_server->Listen(
- net::IPEndPoint(net::IPAddress::IPv4AllZeros(), kTestServerPort));
+ net::IPEndPoint(net::IPAddress::IPv4AllZeros(), 0));
CHECK_GE(rv, 0) << "Quic server fails to start";
+ g_quic_server_port = g_quic_server->server_address().port();
+
+ SetupQuicInMemoryCache();
+
server_started_event->Signal();
}
@@ -96,24 +98,21 @@ void ShutdownOnServerThread(base::WaitableEvent* server_stopped_event) {
server_stopped_event->Signal();
}
-// Quic server is currently hardcoded to run on port 6121 of the localhost on
-// the device.
bool StartQuicTestServer() {
+ LOG(INFO) << g_quic_server_thread;
DCHECK(!g_quic_server_thread);
g_quic_server_thread = new base::Thread("quic server thread");
base::Thread::Options thread_options;
thread_options.message_loop_type = base::MessageLoop::TYPE_IO;
bool started = g_quic_server_thread->StartWithOptions(thread_options);
DCHECK(started);
- base::FilePath test_files_root;
- if (!PathService::Get(base::DIR_EXE, &test_files_root))
- return false;
+ base::FilePath test_files_root = net::GetTestCertsDirectory();
+
base::WaitableEvent server_started_event(
base::WaitableEvent::ResetPolicy::MANUAL,
base::WaitableEvent::InitialState::NOT_SIGNALED);
g_quic_server_thread->task_runner()->PostTask(
- FROM_HERE, base::Bind(&StartQuicServerOnServerThread,
- test_files_root.Append("net/data/ssl/certificates"),
+ FROM_HERE, base::Bind(&StartQuicServerOnServerThread, test_files_root,
&server_started_event));
server_started_event.Wait();
return true;
@@ -133,4 +132,8 @@ void ShutdownQuicTestServer() {
g_quic_server_thread = nullptr;
}
-} // namespace cronet
+int GetQuicTestServerPort() {
+ return g_quic_server_port;
+}
+
+} // namespace grpc_support
« no previous file with comments | « components/grpc_support/test/quic_test_server.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698