// Copyright 2024 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_TEST_EMBEDDED_TEST_SERVER_CREATE_WEBSOCKET_HANDLER_H_ #define NET_TEST_EMBEDDED_TEST_SERVER_CREATE_WEBSOCKET_HANDLER_H_ #include #include #include "base/functional/callback_forward.h" #include "base/memory/scoped_refptr.h" #include "net/test/embedded_test_server/embedded_test_server.h" #include "net/test/embedded_test_server/websocket_handler.h" namespace net::test_server { class WebSocketHandler; class WebSocketConnection; using WebSocketHandlerCreator = base::RepeatingCallback( scoped_refptr connection)>; // Creates a handler that can be passed to // EmbeddedTestServer::RegisterUpgradeRequestHandler() to implement a // WebSocket protocol endpoint on `handle_path`, which should start with // '/'. `websocket_handler_creator` is called for every valid incoming WebSocket // handshake request on this path. It should create a subclass of // WebSocketHandler and return it. EmbeddedTestServer::HandleUpgradeRequestCallback CreateWebSocketHandler( std::string_view handle_path, WebSocketHandlerCreator websocket_handler_creator, EmbeddedTestServer* server); // Registers a WebSocket handler for the specified subclass of WebSocketHandler. // This template function streamlines registration by eliminating the need for // a separate CreateHandler() method for each handler subclass. Instead, it // binds the subclass directly to the embedded test server's upgrade request // handler. // // Usage Example: // RegisterWebSocketHandler(embedded_test_server, // "/mypath"); // This registers `MyWebSocketHandler` with `embedded_test_server` so that a new // instance is created for each WebSocket handshake on the specified path. // // Template Parameters: // - Handler: Subclass of WebSocketHandler defining the connection behavior. // // Parameters: // - embedded_test_server: The EmbeddedTestServer to register with. // - handle_path: Path where the handler responds to WebSocket requests // (starts with '/'). // // Requirements: // - `Handler` must derive from `WebSocketHandler`. template requires std::is_base_of_v void RegisterWebSocketHandler(EmbeddedTestServer* server, std::string_view handle_path) { const auto websocket_handler_creator = base::BindRepeating([](scoped_refptr connection) -> std::unique_ptr { return std::make_unique(std::move(connection)); }); const auto callback = CreateWebSocketHandler(handle_path, websocket_handler_creator, server); server->RegisterUpgradeRequestHandler(callback); } } // namespace net::test_server #endif // NET_TEST_EMBEDDED_TEST_SERVER_CREATE_WEBSOCKET_HANDLER_H_