#ifndef NET_WEBSOCKETS_WEBSOCKET_STREAM_CREATE_TEST_BASE_H_
#define NET_WEBSOCKETS_WEBSOCKET_STREAM_CREATE_TEST_BASE_H_
#include <memory>
#include <optional>
#include <string>
#include <utility>
#include <vector>
#include "base/functional/callback.h"
#include "base/memory/raw_ptr.h"
#include "base/run_loop.h"
#include "base/timer/timer.h"
#include "net/base/auth.h"
#include "net/base/net_errors.h"
#include "net/socket/socket_test_util.h"
#include "net/ssl/ssl_info.h"
#include "net/storage_access_api/status.h"
#include "net/test/test_with_task_environment.h"
#include "net/websockets/websocket_event_interface.h"
#include "net/websockets/websocket_test_util.h"
class GURL;
namespace base {
class OneShotTimer;
}
namespace url {
class Origin;
}
namespace net {
class HttpRequestHeaders;
class HttpResponseHeaders;
class IsolationInfo;
class SiteForCookies;
class URLRequest;
class WebSocketStream;
class WebSocketStreamRequest;
struct WebSocketHandshakeRequestInfo;
struct WebSocketHandshakeResponseInfo;
class WebSocketStreamCreateTestBase : public WithTaskEnvironment {
public:
using HeaderKeyValuePair = std::pair<std::string, std::string>;
WebSocketStreamCreateTestBase();
WebSocketStreamCreateTestBase(const WebSocketStreamCreateTestBase&) = delete;
WebSocketStreamCreateTestBase& operator=(
const WebSocketStreamCreateTestBase&) = delete;
virtual ~WebSocketStreamCreateTestBase();
void CreateAndConnectStream(const GURL& socket_url,
const std::vector<std::string>& sub_protocols,
const url::Origin& origin,
const SiteForCookies& site_for_cookies,
StorageAccessApiStatus storage_access_api_status,
const IsolationInfo& isolation_info,
const HttpRequestHeaders& additional_headers,
std::unique_ptr<base::OneShotTimer> timer);
static std::vector<HeaderKeyValuePair> RequestHeadersToVector(
const HttpRequestHeaders& headers);
static std::vector<HeaderKeyValuePair> ResponseHeadersToVector(
const HttpResponseHeaders& headers);
const std::string& failure_message() const { return failure_message_; }
int failure_response_code() const { return failure_response_code_; }
bool has_failed() const { return has_failed_; }
void WaitUntilConnectDone();
void WaitUntilOnAuthRequired();
void WaitUntilOnURLRequestConnected();
std::vector<std::string> NoSubProtocols();
protected:
WebSocketTestURLRequestContextHost url_request_context_host_;
std::unique_ptr<WebSocketStreamRequest> stream_request_;
std::unique_ptr<WebSocketStream> stream_;
std::string failure_message_;
int failure_response_code_ = -1;
bool has_failed_ = false;
std::unique_ptr<WebSocketHandshakeRequestInfo> request_info_;
std::unique_ptr<WebSocketHandshakeResponseInfo> response_info_;
std::unique_ptr<WebSocketEventInterface::SSLErrorCallbacks>
ssl_error_callbacks_;
SSLInfo ssl_info_;
bool ssl_fatal_ = false;
raw_ptr<URLRequest, AcrossTasksDanglingUntriaged> url_request_ = nullptr;
AuthChallengeInfo auth_challenge_info_;
base::OnceCallback<void(const AuthCredentials*)> on_auth_required_callback_;
std::optional<AuthCredentials> auth_credentials_;
int on_auth_required_rv_ = OK;
CompletionOnceCallback on_url_request_connected_callback_;
int on_url_request_connected_rv_ = OK;
base::RunLoop run_loop_waiting_on_url_request_connected_;
base::RunLoop connect_run_loop_;
base::RunLoop run_loop_waiting_for_on_auth_required_;
private:
class TestConnectDelegate;
};
}
#endif