mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 10:48:11 +00:00

There were a couple steps missing to close the remote end. Further, we were not removing the session from the list of active sessions.
42 lines
1.3 KiB
C++
42 lines
1.3 KiB
C++
/*
|
|
* Copyright (c) 2022, Florent Castelli <florent.castelli@gmail.com>
|
|
* Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
|
|
* Copyright (c) 2022, Tim Flynn <trflynn89@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibIPC/ConnectionToServer.h>
|
|
#include <LibWeb/WebDriver/Response.h>
|
|
#include <WebContent/Forward.h>
|
|
#include <WebContent/WebDriverClientEndpoint.h>
|
|
#include <WebContent/WebDriverServerEndpoint.h>
|
|
|
|
namespace WebContent {
|
|
|
|
class WebDriverConnection final
|
|
: public IPC::ConnectionToServer<WebDriverClientEndpoint, WebDriverServerEndpoint> {
|
|
C_OBJECT_ABSTRACT(WebDriverConnection)
|
|
|
|
public:
|
|
static ErrorOr<NonnullRefPtr<WebDriverConnection>> connect(PageHost& page_host, String const& webdriver_ipc_path);
|
|
virtual ~WebDriverConnection() = default;
|
|
|
|
private:
|
|
WebDriverConnection(NonnullOwnPtr<Core::Stream::LocalSocket> socket, PageHost& page_host);
|
|
|
|
virtual void die() override { }
|
|
|
|
virtual void close_session() override;
|
|
virtual void set_is_webdriver_active(bool) override;
|
|
virtual Messages::WebDriverClient::NavigateToResponse navigate_to(JsonValue const& payload) override;
|
|
virtual Messages::WebDriverClient::GetCurrentUrlResponse get_current_url() override;
|
|
|
|
ErrorOr<void, Web::WebDriver::Error> ensure_open_top_level_browsing_context();
|
|
|
|
PageHost& m_page_host;
|
|
};
|
|
|
|
}
|